source: branches/feature-module-update/data/class/util/GC_Utils.php @ 15078

Revision 15078, 9.6 KB checked in by nanasess, 17 years ago (diff)

r15064 から svn cp
とりあえず暫定コミット.

  • UTF-8 に変更
  • slib.php, glib.php のクラス化
  • LC_Page の抽象化(一部)
Line 
1<?php
2/*
3 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8/**
9 * 各種ユーティリティクラス.
10 *
11 * @package Util
12 * @author LOCKON CO.,LTD.
13 * @version $Id$
14 */
15class GC_Utils {
16
17    /*----------------------------------------------------------------------
18     * [名称] gfDownloadCsv
19     * [概要] 引数データをCSVとして、クライアントにダウンロードさせる
20     * [引数] 1:ヘッダ文字列 2:CSVデータ
21     * [戻値] -
22     * [依存] -
23     * [注釈] 引数は1,2ともカンマ区切りになっていること
24     *----------------------------------------------------------------------*/
25    function gfDownloadCsv($header, $contents){
26
27        $fiest_name = date("YmdHis") .".csv";
28
29        /* HTTPヘッダの出力 */
30        Header("Content-disposition: attachment; filename=${fiest_name}");
31        Header("Content-type: application/octet-stream; name=${fiest_name}");
32
33        $return = $header.$contents;
34        if (mb_detect_encoding($return) == CHAR_CODE){                      //文字コード変換
35            $return = mb_convert_encoding($return,'SJIS',CHAR_CODE);
36            $return = str_replace( array( "\r\n", "\r" ), "\n", $return);   // 改行方法の統一
37        }
38        echo $return;
39    }
40
41    /*----------------------------------------------------------------------
42     * [名称] gfSetCsv
43     * [概要] 引数の配列をCSV形式に変換する
44     * [引数] 1:CSVにする配列 2:引数1が連想配列時の添え字を指定した配列
45     * [戻値] CSVデータ
46     * [依存] -
47     * [注釈] -
48     *----------------------------------------------------------------------*/
49    function gfSetCsv( $array, $arrayIndex = "" ){
50        //引数$arrayIndexは、$arrayが連想配列のときに添え字を指定してやるために使用する
51
52        $return = "";
53        for ($i=0; $i<count($array); $i++){
54
55            for ($j=0; $j<count($array[$i]); $j++ ){
56                if ( $j > 0 ) $return .= ",";
57                $return .= "\"";
58                if ( $arrayIndex ){
59                    $return .= mb_ereg_replace("<","<",mb_ereg_replace( "\"","\"\"",$array[$i][$arrayIndex[$j]] )) ."\"";
60                } else {
61                    $return .= mb_ereg_replace("<","<",mb_ereg_replace( "\"","\"\"",$array[$i][$j] )) ."\"";
62                }
63            }
64            $return .= "\n";
65        }
66
67        return $return;
68    }
69
70    /*----------------------------------------------------------------------
71     * [名称] gfGetAge
72     * [概要] 日付より年齢を計算する。
73     * [引数] 1:日付文字列(yyyy/mm/dd、yyyy-mm-dd hh:mm:ss等)
74     * [戻値] 年齢の数値
75     * [依存] -
76     * [注釈] -
77     *----------------------------------------------------------------------*/
78    function gfGetAge($dbdate)
79    {
80        $ty = date("Y");
81        $tm = date("m");
82        $td = date("d");
83        list($by, $bm, $bd) = split("[-/ ]", $dbdate);
84        $age = $ty - $by;
85        if($tm * 100 + $td < $bm * 100 + $bd) $age--;
86        return $age;
87    }
88
89    /*----------------------------------------------------------------------
90     * [名称] gfDebugLog
91     * [概要] ログファイルに変数の詳細を出力する。
92     * [引数] 対象となる変数
93     * [戻値] なし
94     * [依存] gfPrintLog
95     * [注釈] -
96     *----------------------------------------------------------------------*/
97    function gfDebugLog($obj){
98            gfPrintLog("*** start Debug ***");
99            ob_start();
100            print_r($obj);
101            $buffer = ob_get_contents();
102            ob_end_clean();
103            $fp = fopen(LOG_PATH, "a+");
104            fwrite( $fp, $buffer."\n" );
105            fclose( $fp );
106            gfPrintLog("*** end Debug ***");
107
108            // ログテーション
109            gfLogRotation(MAX_LOG_QUANTITY, MAX_LOG_SIZE, LOG_PATH);
110    }
111
112    /*----------------------------------------------------------------------
113     * [名称] gfPrintLog
114     * [概要] ログファイルに日時、処理ファイル名、メッセージを出力
115     * [引数] 表示したいメッセージ
116     * [戻値] なし
117     * [依存] なし
118     * [注釈] -
119     *----------------------------------------------------------------------*/
120    function gfPrintLog($mess, $path = '') {
121        // 日付の取得
122        $today = date("Y/m/d H:i:s");
123        // 出力パスの作成
124        if ($path == "") {
125            $path = LOG_PATH;
126        }
127
128        // エスケープされている文字をもとに戻す
129        $trans_tbl = get_html_translation_table (HTML_ENTITIES);
130        $trans_tbl = array_flip ($trans_tbl);
131        $mess = strtr($mess, $trans_tbl);
132
133        $fp = fopen($path, "a+");
134        if($fp) {
135            fwrite( $fp, $today." [".$_SERVER['PHP_SELF']."] ".$mess." from ". $_SERVER['REMOTE_ADDR']. "\n" );
136            fclose( $fp );
137        }
138
139        // ログテーション
140        gfLogRotation(MAX_LOG_QUANTITY, MAX_LOG_SIZE, $path);
141    }
142
143    /**
144     * ログローテーション機能
145     *
146     * @param integer $max_log 最大ファイル数
147     * @param integer $max_size 最大サイズ
148     * @param string  $path ファイルパス
149     * @return void なし
150     */
151    function gfLogRotation($max_log, $max_size, $path) {
152
153        // ディレクトリ名を取得
154        $dirname = dirname($path);
155        // ファイル名を取得
156        $basename = basename($path);
157
158        // ファイルが最大サイズを超えていないかチェック
159        if(filesize($path) > $max_size) {
160            if ($dh = opendir($dirname)) {
161                while (($file = readdir($dh)) !== false) {
162                    // ログローテーションにて作成されたファイルを取得
163                    if(ereg("^". $basename . "\." , $file)) {
164                        $arrLog[] = $file;
165                    }
166                }
167
168                // ファイルログが最大個数なら以上なら古いファイルから削除する
169                $count = count($arrLog);
170                if($count >= $max_log) {
171                    $diff = $count - $max_log;
172                    for($i = 0; $diff >= $i ; $i++) {
173                        unlink($dirname. "/" .array_pop($arrLog));
174                    }
175                }
176
177                // ログファイルの添え字をずらす
178                $count = count($arrLog);
179                for($i = $count; 1 <= $i; $i--) {
180                    $move_number = $i + 1;
181
182                    if(file_exists("$path.$move_number")) unlink("$path.$move_number");
183                    copy("$dirname/" . $arrLog[$i - 1], "$path.$move_number");
184
185                }
186                $ret = copy($path, "$path.1");
187
188                // 新規ログファイルを作成
189                if($ret) {
190                    unlink($path);
191                    touch($path);
192                }
193            }
194        }
195    }
196
197    /*----------------------------------------------------------------------
198     * [名称] gfMakePassword
199     * [概要] ランダムパスワード生成(英数字)
200     * [引数] パスワードの桁数
201     * [戻値] ランダム生成されたパスワード
202     * [依存] なし
203     * [注釈] -
204     *----------------------------------------------------------------------*/
205    function gfMakePassword($pwLength) {
206
207        // 乱数表のシードを決定
208        srand((double)microtime() * 54234853);
209
210        // パスワード文字列の配列を作成
211        $character = "abcdefghkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ2345679";
212        $pw = preg_split("//", $character, 0, PREG_SPLIT_NO_EMPTY);
213
214        $password = "";
215        for($i = 0; $i<$pwLength; $i++ ) {
216            $password .= $pw[array_rand($pw, 1)];
217        }
218
219        return $password;
220    }
221
222    /*----------------------------------------------------------------------
223     * [名称] sf_explodeExt
224     * [概要] ファイルの拡張子取得
225     * [引数] ファイル名
226     * [戻値] 拡張子
227     * [依存] なし
228     * [注釈] -
229     *----------------------------------------------------------------------*/
230    function gf_explodeExt($fileName) {
231        $ext1 = explode(".", $fileName);
232        $ext2 = $ext1[count($ext1) - 1];
233        $ext2 = strtolower($ext2);
234        return $ext2;
235    }
236
237
238    /*----------------------------------------------------------------------------------------------------------------------
239     * [名称] gfMailHeaderAddr
240     * [概要] 入力されたメールアドレスをメール関数用の宛先に変換
241     * [引数] 「メールアドレス」または「名前<メールアドレス>」、複数アドレス指定時はカンマ区切りで指定する。
242     * [戻値] 「メールアドレス」または「JIS_MIMEにコード変換した名前 <メールアドレス>」、複数アドレス指定時はカンマ区切りで返却する。
243     * [依存] なし
244     * [注釈] -
245     *----------------------------------------------------------------------------------------------------------------------*/
246
247    function gfMailHeaderAddr($str) {
248        $addrs = explode(",", $str); //アドレスを配列に入れる
249        foreach ($addrs as $addr) {
250            if (preg_match("/^(.+)<(.+)>$/", $addr, $matches)) {
251                //引数が「名前<メールアドレス>」の場合
252                $mailaddrs[] = mb_encode_mimeheader(trim($matches[1]))." <".trim($matches[2]).">";
253            } else {
254                //メールアドレスのみの場合
255                $mailaddrs[] =  trim($addr);
256            }
257        }
258        return implode(", ", $mailaddrs); //複数アドレスはカンマ区切りにする
259    }
260}
261?>
Note: See TracBrowser for help on using the repository browser.