Subversion Repositories qbpwcf-lib(archive)

Rev

Rev 822 | Details | Compare with Previous | Last modification | View Log | RSS feed

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