source: branches/version-2_12-dev/data/class/util/GC_Utils.php @ 21481

Revision 21481, 12.4 KB checked in by Seasoft, 12 years ago (diff)

#1613 (ソース整形・ソースコメントの改善)

  • Zend Framework PHP 標準コーディング規約への準拠を高めた
  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2011 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24/**
25 * 各種ユーティリティクラス.
26 *
27 * @package Util
28 * @author LOCKON CO.,LTD.
29 * @version $Id$
30 */
31class GC_Utils {
32
33    /*----------------------------------------------------------------------
34     * [名称] gfDownloadCsv
35     * [概要] 引数データをCSVとして、クライアントにダウンロードさせる
36     * [引数] 1:ヘッダ文字列 2:CSVデータ
37     * [戻値] -
38     * [依存] -
39     * [注釈] 引数は1,2ともカンマ区切りになっていること
40     *----------------------------------------------------------------------*/
41    function gfDownloadCsv($header, $contents) {
42
43        $fiest_name = date('YmdHis') .".csv";
44
45        /* HTTPヘッダの出力 */
46        Header("Content-disposition: attachment; filename=${fiest_name}");
47        Header("Content-type: application/octet-stream; name=${fiest_name}");
48
49        $return = $header.$contents;
50        if (mb_detect_encoding($return) == CHAR_CODE) {
51            // 文字コード変換
52            $return = mb_convert_encoding($return,'SJIS',CHAR_CODE);
53            // 改行方法の統一
54            $return = str_replace( array("\r\n", "\r"), "\n", $return);
55        }
56        echo $return;
57    }
58
59    /*----------------------------------------------------------------------
60     * [名称] gfSetCsv
61     * [概要] 引数の配列をCSV形式に変換する
62     * [引数] 1:CSVにする配列 2:引数1が連想配列時の添え字を指定した配列
63     * [戻値] CSVデータ
64     * [依存] -
65     * [注釈] -
66     *----------------------------------------------------------------------*/
67    function gfSetCsv($array, $arrayIndex = "") {
68        //引数$arrayIndexは、$arrayが連想配列のときに添え字を指定してやるために使用する
69
70        $return = "";
71        for ($i=0; $i<count($array); $i++) {
72
73            for ($j=0; $j<count($array[$i]); $j++) {
74                if ($j > 0) $return .= ",";
75                $return .= "\"";
76                if ($arrayIndex) {
77                    $return .= mb_ereg_replace("<","<",mb_ereg_replace("\"","\"\"",$array[$i][$arrayIndex[$j]])) ."\"";
78                } else {
79                    $return .= mb_ereg_replace("<","<",mb_ereg_replace("\"","\"\"",$array[$i][$j])) ."\"";
80                }
81            }
82            $return .= "\n";
83        }
84
85        return $return;
86    }
87
88    /*----------------------------------------------------------------------
89     * [名称] gfGetAge
90     * [概要] 日付より年齢を計算する。
91     * [引数] 1:日付文字列(yyyy/mm/dd、yyyy-mm-dd hh:mm:ss等)
92     * [戻値] 年齢の数値
93     * [依存] -
94     * [注釈] -
95     *----------------------------------------------------------------------*/
96    function gfGetAge($dbdate) {
97        $ty = date('Y');
98        $tm = date('m');
99        $td = date('d');
100        list($by, $bm, $bd) = preg_split("/[-/ ]/", $dbdate);
101        $age = $ty - $by;
102        if($tm * 100 + $td < $bm * 100 + $bd) $age--;
103        return $age;
104    }
105
106    /**
107     * ログファイルに変数の詳細を出力
108     *
109     * @param mixed $obj
110     * @return void
111     */
112    function gfDebugLog($obj) {
113        if (DEBUG_MODE === true) {
114            GC_Utils_Ex::gfPrintLog(
115                "*** start Debug ***\n" .
116                print_r($obj, true) .
117                "*** end Debug ***"
118            );
119        }
120    }
121
122    /**
123     * 呼び出し元関数名を返します
124     *
125     * @param int $forLogInfo ログ出力用に利用するかどうか(1:ログ出力用に利用する)
126     * @return string 呼び出し元クラス、関数名、行数の文字列表現
127     */
128    function gfGetCallerInfo($forLogInfo=true) {
129        // バックトレースを取得する
130        $traces = debug_backtrace(false);
131        $bklv = 1;
132        if ($forLogInfo === true) {
133            $bklv = 3;
134            if( ($traces[3]['class'] === 'LC_Page'
135                || $traces[3]['class'] === 'LC_Page_Admin')
136                && $traces[3]['function'] === 'log')
137            {
138                $bklv = 4;
139            }
140        }
141        $str = $traces[$bklv]['class'] . "::" . $traces[$bklv]['function'] . "(" . $traces[$bklv-1]['line'] . ") ";
142        return $str;
143    }
144
145    /**
146     * ログメッセージに、呼び出し元関数名等の情報を付加して返します
147     *
148     * @param string $mess ログメッセージ
149     * @param string $log_level ログレベル('Info' or 'Debug')
150     * @return string ログメッセージに呼び出し元関数名等の情報を付加した文字列
151     */
152    function gfGetLogStr($mess, $log_level='Info') {
153        // メッセージの前に、ログ出力元関数名とログ出力関数呼び出し部分の行数を付与
154        $mess = GC_Utils::gfGetCallerInfo(true) . $mess;
155
156        // ログレベル=Debugの場合は、[Debug]を先頭に付与する
157        if ($log_level === 'Debug') {
158            $mess = "[Debug]" . $mess;
159        }
160
161        return $mess;
162    }
163
164    /**
165     * 管理画面用ログ出力
166     *
167     * 管理画面用ログ出力を行ないます
168     * @param string $mess ログメッセージ
169     * @param string $log_level ログレベル('Info' or 'Debug')
170     * @return void
171     */
172    function gfAdminLog($mess, $log_level='Info') {
173        // ログレベル=Debugの場合は、DEBUG_MODEがtrueの場合のみログ出力する
174        if ($log_level === 'Debug'&& DEBUG_MODE === false) {
175            return;
176        }
177
178        // ログメッセージに、呼び出し元関数名等の情報を付加する
179        $mess = GC_Utils::gfGetLogStr($mess, $log_level);
180
181        // ログ出力
182        // ※現在は管理画面用・フロント用のログ出力とも、同じファイル(site.log)に出力します。
183        //  分けたい場合は、以下の関数呼び出しの第2引数にファイルパスを指定してください
184        GC_Utils_Ex::gfPrintLog($mess);
185    }
186
187    /**
188     * フロント用ログ出力
189     *
190     * フロント用ログ出力を行ないます
191     * @param string $mess ログメッセージ
192     * @param string $log_level ログレベル('Info' or 'Debug')
193     * @return void
194     */
195    function gfFrontLog($mess, $log_level='Info') {
196        // ログレベル=Debugの場合は、DEBUG_MODEがtrueの場合のみログ出力する
197        if ($log_level === 'Debug'&& DEBUG_MODE === false) {
198            return;
199        }
200
201        // ログメッセージに、呼び出し元関数名等の情報を付加する
202        $mess = GC_Utils::gfGetLogStr($mess, $log_level);
203
204        // ログ出力
205        // ※現在は管理画面用・フロント用のログ出力とも、同じファイル(site.log)に出力します。
206        //  分けたい場合は、以下の関数呼び出しの第2引数にファイルパスを指定してください
207        GC_Utils_Ex::gfPrintLog($mess);
208    }
209
210    /*----------------------------------------------------------------------
211     * [名称] gfPrintLog
212     * [概要] ログファイルに日時、処理ファイル名、メッセージを出力
213     * [引数] 表示したいメッセージ
214     * [戻値] なし
215     * [依存] なし
216     * [注釈] -
217     *----------------------------------------------------------------------*/
218    function gfPrintLog($mess, $path = '') {
219        // 日付の取得
220        $today = date("Y/m/d H:i:s");
221        // 出力パスの作成
222        if ($path == "") {
223            $path = LOG_REALFILE;
224        }
225
226        // エスケープされている文字をもとに戻す
227        $trans_tbl = get_html_translation_table (HTML_ENTITIES);
228        $trans_tbl = array_flip ($trans_tbl);
229        $mess = strtr($mess, $trans_tbl);
230
231        $fp = fopen($path, "a+");
232        if ($fp) {
233            fwrite($fp, $today." [".$_SERVER['PHP_SELF']."] ".$mess." from ". $_SERVER['REMOTE_ADDR']. "\n");
234            fclose($fp);
235        }
236
237        // ログテーション
238        GC_Utils_Ex::gfLogRotation(MAX_LOG_QUANTITY, MAX_LOG_SIZE, $path);
239    }
240
241    /**
242     * ログローテーション機能
243     *
244     * XXX この類のローテーションは通常 0 開始だが、本実装は 1 開始である。
245     * この中でログ出力は行なわないこと。(無限ループの懸念あり)
246     * @param integer $max_log 最大ファイル数
247     * @param integer $max_size 最大サイズ
248     * @param string  $path ファイルパス
249     * @return void
250     */
251    function gfLogRotation($max_log, $max_size, $path) {
252
253        // ファイルが存在しない場合、終了
254        if (!file_exists($path)) return;
255
256        // ファイルが最大サイズを超えていない場合、終了
257        if (filesize($path) <= $max_size) return;
258
259        // Windows 版 PHP への対策として明示的に事前削除
260        $path_max = "$path.$max_log";
261        if (file_exists($path_max)) {
262            $res = unlink($path_max);
263            // 削除に失敗時した場合、ログローテーションは見送り
264            if (!$res) return;
265        }
266
267        // アーカイブのインクリメント
268        for ($i = $max_log; $i >= 2; $i--) {
269            $path_old = "$path." . ($i - 1);
270            $path_new = "$path.$i";
271            if (file_exists($path_old)) {
272                rename($path_old, $path_new);
273            }
274        }
275
276        // 現在ファイルのアーカイブ
277        rename($path, "$path.1");
278    }
279
280    /*----------------------------------------------------------------------
281     * [名称] gfMakePassword
282     * [概要] ランダムパスワード生成(英数字)
283     * [引数] パスワードの桁数
284     * [戻値] ランダム生成されたパスワード
285     * [依存] なし
286     * [注釈] -
287     *----------------------------------------------------------------------*/
288    function gfMakePassword($pwLength) {
289
290        // 乱数表のシードを決定
291        srand((double)microtime() * 54234853);
292
293        // パスワード文字列の配列を作成
294        $character = 'abcdefghkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ2345679';
295        $pw = preg_split("//", $character, 0, PREG_SPLIT_NO_EMPTY);
296
297        $password = "";
298        for ($i = 0; $i<$pwLength; $i++) {
299            $password .= $pw[array_rand($pw, 1)];
300        }
301
302        return $password;
303    }
304
305    /*----------------------------------------------------------------------------------------------------------------------
306     * [名称] gfMailHeaderAddr
307     * [概要] 入力されたメールアドレスをメール関数用の宛先に変換
308     * [引数] 「メールアドレス」または「名前<メールアドレス>」、複数アドレス指定時はカンマ区切りで指定する。
309     * [戻値] 「メールアドレス」または「JIS_MIMEにコード変換した名前 <メールアドレス>」、複数アドレス指定時はカンマ区切りで返却する。
310     * [依存] なし
311     * [注釈] -
312     *----------------------------------------------------------------------------------------------------------------------*/
313
314    function gfMailHeaderAddr($str) {
315        $addrs = explode(",", $str); //アドレスを配列に入れる
316        foreach ($addrs as $addr) {
317            if (preg_match("/^(.+)<(.+)>$/", $addr, $matches)) {
318                //引数が「名前<メールアドレス>」の場合
319                $mailaddrs[] = mb_encode_mimeheader(trim($matches[1]))." <".trim($matches[2]).">";
320            } else {
321                //メールアドレスのみの場合
322                $mailaddrs[] =  trim($addr);
323            }
324        }
325        return implode(", ", $mailaddrs); //複数アドレスはカンマ区切りにする
326    }
327}
Note: See TracBrowser for help on using the repository browser.