Subversion Repositories php-qbpwcf

Rev

Rev 98 | Rev 237 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
48 liveuser 1
<?php
2
 
3
/*
4
 
5
        QBPWCF, Quick Build PHP website Component base on Fedora Linux.
226 liveuser 6
    Copyright (C) 2014~2025 MIN ZHI, CHEN
48 liveuser 7
 
8
    This file is part of QBPWCF.
9
 
10
    QBPWCF is free software: you can redistribute it and/or modify
11
    it under the terms of the GNU General Public License as published by
12
    the Free Software Foundation, either version 3 of the License, or
13
    (at your option) any later version.
14
 
15
    QBPWCF is distributed in the hope that it will be useful,
16
    but WITHOUT ANY WARRANTY; without even the implied warranty of
17
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18
    GNU General Public License for more details.
19
 
20
    You should have received a copy of the GNU General Public License
21
    along with QBPWCF.  If not, see <http://www.gnu.org/licenses/>.
22
 
23
*/
24
 
25
#使用 qbpwcf 命名空間
26
namespace qbpwcf;
27
 
28
#初始化輸出
29
$output=array();
30
 
31
#取得 lib path
98 liveuser 32
exec("php -f ".escapeshellarg(pathinfo(__FILE__)["dirname"]."/../../../../usr/bin/libexec/folderOfUsrLib.php"),$output,$status);
48 liveuser 33
 
34
#如果執行失敗
35
if($status!==0){
36
 
37
	#debug
38
	var_dump(__LINE__,$output);
39
 
40
	#結束執行,回傳shell 1.
41
	exit(1);
42
 
43
	}#if end
44
 
45
#儲存lib path
46
$folderOfUsrLib=$output[0];
47
 
48
#初始化輸出
49
$output=array();
50
 
51
#以該檔案的實際位置的 lib path 為 include path 首位
98 liveuser 52
exec("cd ".pathinfo(__FILE__)["dirname"]."/../../../../usr/".$folderOfUsrLib."/qbpwcf;pwd;",$output,$status);
48 liveuser 53
set_include_path($output[0].PATH_SEPARATOR.get_include_path());
54
 
55
#匯入套件
56
require_once("allInOne.php");
57
 
58
#qbpwcf用的javascript
59
$qbpwcfJavaScript=javaScript::qbpwcfJavaScript();
60
 
61
#建議的log位置
62
$logFile=$_SERVER["DOCUMENT_ROOT"].$_SERVER["PHP_SELF"].".log";
63
 
64
#要使用的範例name
65
$nameOfSample="20250615";
66
#$nameOfSample="20250630";
67
 
68
#函式說明:
69
#抓取命令列的參數.
70
#回傳結果:
71
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
72
#$reuslt["error"],執行不正常結束的錯訊息陣列.
73
#$result["function"],當前執行的函式名稱.
74
#$result["argu"],使用的參數陣列.
75
#$result["content"],要回傳的參數陣列.
76
#$result["count"],參數的數量.
77
#$result["_GET"],收到的 HTTP GET 參數陣列.
78
#$result["_POST"],收到的 HTTP POST 參數陣列.
79
#必填參數:
80
#無
81
#可省略參數:
82
#$conf["echo"],字串,"true"代表要將抓到的參數一個個印出來,"false"代表用回傳的方式,預設為"false".
83
#$conf["echo"]="false";
84
#$conf["httpGetToArgu"],字串,"true"代表要將 http get 參數變成參數來取得,像是 $_GET["p1"] 會變成 $result["content"]["p1"] 回傳,預設為"false"代表不使用.
85
$conf["httpGetToArgu"]="true";
86
#$conf["httpPostToArgu"],字串,"true"代表要將 http post 參數變成參數來取得,像是 $_POST["p1"] 會變成 $result["content"]["p1"] 回傳,預設為"false"代表不使用.
87
$conf["httpPostToArgu"]="true";
88
#$conf["arguEqual2http"],字串,預設為"false",代表命令列環境的參數依序為程式名稱本身、第n個參數,反之為"true",代表命令列的第一個參數為第n個參數,亦即沒有程式本身名稱的參數.
89
$conf["arguEqual2http"]="true";
90
#參考資料:
91
#無.
92
#備註:
93
#無.
94
$getArgu=cmd::getArgu($conf);
95
unset($conf);
96
 
97
#debug
98
#var_dump($getArgu);exit(1);
99
 
100
#如果執行失敗
101
if($getArgu["status"]==="false"){
102
 
103
	#函式說明:
104
	#撰寫log
105
	#回傳結果:
106
	#$result["status"],狀態,"true"或"false".
107
	#$result["error"],錯誤訊息陣列.
108
	#$result["function"],當前函式的名稱.
109
	#$result["argu"],使用的參數.
110
	#必填參數:
111
	#$conf["path"],字串,log檔案的路徑與名稱.
112
	$conf["path"]=$logFile;
113
	#$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
114
	$conf["content"]=$getArgu;
115
	#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
116
	$conf["fileArgu"]=__FILE__;
117
	#可省略參數:
118
	#$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
119
	#$conf["rewrite"]="false";
120
	#參考資料:
121
	#無.
122
	#備註:
123
	#無.
124
	$record=logs::record($conf);
125
	unset($conf);
226 liveuser 126
 
48 liveuser 127
	#如果寫log失敗
128
	if($record["status"]==="false"){
226 liveuser 129
 
48 liveuser 130
		#印出結果
131
		var_dump($record);
226 liveuser 132
 
48 liveuser 133
		}#if end
226 liveuser 134
 
48 liveuser 135
	#結束執行,回傳錯誤代碼1
136
	exit(1);
137
 
138
	}#if end
226 liveuser 139
 
48 liveuser 140
#如果有指定參數
141
if($getArgu["count"]>0){
142
 
143
	#預設第1個參數為 $nameOfSample 的指定數值
144
	$nameOfSample=$getArgu["content"][0];
145
 
146
	}#if end
147
 
148
#存放範例的資料夾
149
$sampleFolder="mail::pear_smtp_send";
150
 
151
#設置測試案例的檔案名稱與路徑
152
$fileNameOfSample=$sampleFolder."/".$nameOfSample.".php";
153
 
154
#初始化儲存範例代碼
155
$samples=array();
156
 
157
#增加  mail::pear_smtp_send 的範例資訊
158
$samples[]=array("name"=>"20250615","comnent"=>"test send mail");
159
$samples[]=array("name"=>"20250630","comnent"=>"tets send mail to gmail");
160
$samples[]=array("name"=>"20250704","comnent"=>"tets send GPG signed mail");
161
 
162
#針對每個範例資訊
163
foreach($samples as $sample){
164
 
165
	#如果找到對應的範例
166
	if($sample["name"]===$nameOfSample){
226 liveuser 167
 
48 liveuser 168
		#如果存放範例的資料夾不存在
169
		if(!file_exists($sampleFolder)){
226 liveuser 170
 
48 liveuser 171
			#提示訊息
172
			echo "存放範例的資料夾(".$sampleFolder.")不存在".PHP_EOL;
226 liveuser 173
 
48 liveuser 174
			#結束執行,並回傳1給shell
175
			exit(1);
226 liveuser 176
 
48 liveuser 177
			}#if end
226 liveuser 178
 
48 liveuser 179
		#如果對應的範例檔案不存在
180
		if(!file_exists($fileNameOfSample)){
226 liveuser 181
 
48 liveuser 182
			#提示訊息
183
			echo "範例檔案(".$fileNameOfSample.")不存在".PHP_EOL;
226 liveuser 184
 
48 liveuser 185
			#結束執行,並回傳1給shell
186
			exit(1);
226 liveuser 187
 
48 liveuser 188
			}#if end
226 liveuser 189
 
48 liveuser 190
		#匯入範例
191
		require_once($fileNameOfSample);
226 liveuser 192
 
48 liveuser 193
		#結束執行
194
		exit;
226 liveuser 195
 
48 liveuser 196
		}#if end
197
 
198
	}#foreach end
226 liveuser 199
 
48 liveuser 200
#執行到這邊代表沒有對應的範例
201
 
202
#提示範例不存在
203
echo "範例(".$nameOfSample.")不存在".PHP_EOL;
204
 
205
#結束執行,並回傳1給shell
206
exit(1);
207
 
226 liveuser 208
?>