Subversion Repositories qbpwcf-lib(archive)

Rev

Rev 844 | Rev 910 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php

/*

        QBPWCF, Quick Build PHP website Component base on Fedora Linux.
    Copyright (C) 2015~2025 Min-Jhin,Chen

    This file is part of QBPWCF.

    QBPWCF is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    QBPWCF is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with QBPWCF.  If not, see <http://www.gnu.org/licenses/>.

*/
namespace qbpwcf;

/*
類別說明:
用於改變php執行環境的類別.
備註:
無.
*/
class config{

        /*
        #函式說明:
        #當前類別被呼叫的靜態方法不存在時,將會執行該函數,回報該方法不存在.
        #回傳結果:
        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
        #$reuslt["error"],執行不正常結束的錯訊息陣列.
        #$result["function"],當前執行的函式名稱.
        #必填參數:
        #$method,物件,為物件實體或類別名稱,會自動置入該參數.
        #$arguments,陣列,為呼叫方法時所用的參數.
        #參考資料:
        #__call=>http://php.net/manual/en/language.oop5.overloading.php#object.callstatic
        */
        public function __call($method,$arguments){
                
                #取得當前執行的函式
                $result["function"]=__FUNCTION__;
                
                #設置執行不正常
                $result["status"]="false";
                
                #設置執行錯誤
                $result["error"][]=__NAMESPACE__ ."/".$method."() 不存在!";
                
                #設置所丟入的參數
                $result["error"][]=$arguments;
                
                #回傳結果
                return $result;
                
                }#function __call end
                
        /*
        #函式說明:
        #當前類別被呼叫的靜態方法不存在時,將會執行該函數,回報該方法不存在.
        #回傳結果:
        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
        #$reuslt["error"],執行不正常結束的錯訊息陣列.
        #$result["function"],當前執行的函式名稱.
        #必填參數:
        #$method,物件,為物件實體或類別名稱,會自動置入該參數.
        #$arguments,陣列,為呼叫方法時所用的參數.
        #參考資料:
        #__call=>http://php.net/manual/en/language.oop5.overloading.php#object.callstatic
        */
        public static function __callStatic($method,$arguments){
                
                #取得當前執行的函式
                $result["function"]=__FUNCTION__;
                
                #設置執行不正常
                $result["status"]="false";
                
                #設置執行錯誤
                $result["error"][]="欲呼叫的". __NAMESPACE__ ."/".$method."() 不存在!";
                
                #設置所丟入的參數
                $result["error"][]=$arguments;
                
                #回傳結果
                return $result;
                
                }#function __callStatic end

        /*
        #函式說明:
        #延長php的執行時間,每呼叫一次會初始化執行時間爲0,然後設定下次可以執行多久.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #必填參數:
        #$conf["sec"],整數,要延長多少執行時間,單位爲秒
        $conf["sec"]=30;
        #可省略參數:
        #無.
        #備註:
        #無.
        #參考資料:
        #http://php.net/manual/en/function.set-time-limit.php
        */
        public static function delayRunTimeExectionMax(&$conf){
                
                #初始化要回傳的內容
                $result=array();
                
                #記錄當前執行的函數名稱
                $result["function"]=__FUNCTION__;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
                        
                        }#if end

                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["variableCheck::checkArguments"]["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("sec");
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("integer");
                #$conf["variableCheck::checkArguments"]["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"],必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true"。
                $conf["variableCheck::checkArguments"]["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("asc");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array("false");
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);

                #如果檢查參數失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;

                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;

                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #初始化執行時間爲0,然後再延長$conf["sec"] 秒
                $setupResult=set_time_limit($conf["sec"]);
                
                #如果爲 FALSE
                if($setupResult==FALSE){
                        
                        #設置執行不正常
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"]="初始與重置執行時間上限失敗";
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #執行到這邊代表執行正常
                $result["status"]="true";
                
                #回傳結果
                return $result;
                
                }#function delayRunTimeExectionMax end
                
        /*
        #函式說明:
        #顯示目前的php設定值
        #回傳的結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["content"],常用的設定值的內容、也可指定想要看的設定值內容.
        #必填參數:
        #無.
        #可省略參數:
        #$conf["settingsName"],字串陣列,自己想要看的設定值內容,預設為array("display_errors","upload_max_filesize","post_max_size","output_buffering","session.auto_start","memory_limit").
        #$conf["settingsName"]=array();
        #$conf["showAll"],字串,是否要取得所有設定,"true"代表要,會覆寫$conf["settingsName"]的設定,"false"代表不要,預設為"fale".
        #$conf["showAll"]="";
        #參考資料:
        #http://www.php.net/manual/en/function.ini-get.php
        #http://www.php.net/manual/en/function.ini-get-all.php
        #備註:
        #無.
        */
        public static function showSettings(&$conf){
                
                #初始化要回傳的內容
                $result=array();
                
                #記錄當前執行的函數名稱
                $result["function"]=__FUNCTION__;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
                        
                        }#if end

                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["variableCheck::checkArguments"]["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("default");
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string");
                #$conf["variableCheck::checkArguments"]["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"],必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true"。
                $conf["variableCheck::checkArguments"]["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("settingsName","showAll");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("array","string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(array("display_errors","upload_max_filesize","post_max_size","output_buffering","session.auto_start","memory_limit"),"false");
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);

                #如果檢查參數失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;

                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;

                        #回傳結果
                        return $result;
                        
                        }#if end
                
                #如果要顯示所有設定
                if($conf["showAll"]==="true"){
                        
                        #取得設定值
                        $config=ini_get_all();
                        
                        #如果取得設定值失敗
                        if($config==FALSE){
                                
                                #設置執行不正常
                                $result["status"]="true";
                                                
                                #設置錯誤訊息
                                $result["error"][]="取得所有設定值失敗";               
                                                        
                                #回傳結果
                                return $result;
                                
                                }#if end
                                
                        #反之
                        else{
                                
                                #取得設定值
                                $result["content"]=&$config;
                                
                                }#else end                                                                      
                        
                        }#if end
                
                #反之
                else{
                        
                        #針對每個要顯示的設定值
                        foreach($conf["settingsName"] as $key=>$value){
                                
                                #檢查設定值
                                $config=ini_get($value);
                                
                                #如果取得設定值失敗
                                if($config==FALSE){
                                        
                                        #設置執行不正常
                                        $result["status"]="true";
                                                        
                                        #設置錯誤訊息
                                        $result["error"][]="參數「".$value."」不存在";           
                                                                
                                        #回傳結果
                                        return $result;
                                        
                                        }#if end
                                
                                #反之
                                else{
                                        
                                        #取得設定值
                                        $result["content"][$value]=$config;
                                        
                                        }#else end
                                                                
                                }#foreach end
                        
                        }#else 
                
                #設置執行正常
                $result["status"]="true";
                
                #回傳結果
                return $result;
                                        
                }#function showSettings end
        
        /*      
        #函式說明:
        #將php設定檔常用的設定進行調整使之變成適用於開發模式、釋出模式、或自訂要調整哪些設定值
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #必填參數:
        #$conf["mode"],參數設定的模式,"release"代表是指共一般使用所需;"develop"代表是在開發狀態下所需;"custom"代表自訂參數設定內容
        $conf["mode"]="release";
        #可省略參數:
        #$conf["customSettings"],要自訂的參數與其數值,例如array("display_errors=On").
        #$conf["customSettings"]=array();
        #參考資料:
        #ini_set=>http://www.php.net/manual/en/function.ini-set.php
        #各個參數適用的修改方式=>http://www.php.net/manual/en/ini.list.php
        #各個參數適用的修改方式的解說=>http://hi.baidu.com/richardali/item/d28104083c70c638a2332a60
        #備註:
        #使用該函式後,網頁會無法顯示。
        */
        public static function changeSettings(&$conf){
                
                #初始化要回傳的結果
                $result=array();

                #儲存當前執行的函數
                $result["function"]=__FUNCTION__;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
        
                        }#if end
        
                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("mode");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string");
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["canBeEmptyString"],必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true"。
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("customSettings");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null);
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果檢查失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #依據模式來進行設定
                switch($conf["mode"]){
                        
                        #如果是給大家正式使用的狀況
                        case "release":
                        
                                #設置設定值
                                
                                #關閉顯示錯誤訊息
                                $conf["customSettings"][]="display_errors=Off";
                                
                                #初始化計數為0
                                $count=0;
                        
                                #針對每個 $conf["customSettings"]
                                foreach($conf["customSettings"] as $configStr){
                                        
                                        #用 "=" 分割設定字串
                                        #函式說明:
                                        #將固定格式的字串分開,並回傳分開的結果。
                                        #回傳的參數:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["oriStr"],要分割的原始字串內容
                                        #$result["dataArray"],爲分割好字串的陣列內容,$result["dataArray"][$i]爲第($i+1)段的內容。
                                        #$result["dataCounts"],爲總共分成幾段
                                        #必填參數:
                                        $conf["stringProcess::spiltString"]["stringIn"]=$configStr;#要處理的字串。
                                        $conf["stringProcess::spiltString"]["spiltSymbol"]="=";#爲以哪個符號作爲分割
                                        #備註:
                                        #建議新增如果透過" "分割後的內容含有""的元素,將其移除,並將後面有內容的元素補上,key也重新排序。
                                        $spiltString=stringProcess::spiltString($conf["stringProcess::spiltString"]);
                                        unset($conf["stringProcess::spiltString"]);
                                        
                                        #如果分割設定值字串失敗
                                        if($spiltString["status"]=="false"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #如果只有一段內容
                                        if($spiltString["dataCounts"]=="1"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="設定值字串「".$configStr."」必須要用「=」來間隔設定屬性與其數值";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #設定暫時的設定值
                                        $oldConfigValue=ini_set($spiltString["dataArray"][0],$spiltString["dataArray"][1]);
                                        
                                        #如果設定失敗
                                        if($oldConfigValue===false){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="將屬性「".$spiltString["dataArray"][0]."」設定為「".$spiltString["dataArray"][1]."」失敗";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #反之儲存舊的永久設地數值
                                        else{
                                                
                                                #取得舊的設定值
                                                $result["config"][$count]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                $result["config"][$spiltString["dataArray"][0]]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                                                                
                                                #取得新的設定值
                                                $result["config"][$count]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                $result["config"][$spiltString["dataArray"][0]]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                
                                                #計數加1
                                                $count++;
                                                
                                                }#else end
                                        
                                        }#foreach end
                                                
                                #跳出switch
                                break;
                                
                        #如果是開發狀態下
                        case "develop";
                        
                                #設置設定值
                                
                                #開啟顯示錯誤訊息
                                $conf["customSettings"][]="display_errors=On";
                                
                                #關閉使用記憶體的上限
                                $conf["customSettings"][]="memory_limit=-1";
                                
                                #關閉php script執行的時間上限
                                $conf["customSettings"][]="max_execution_time=0";
                                
                                #初始化計數為0
                                $count=0;
                        
                                #針對每個 $conf["customSettings"]
                                foreach($conf["customSettings"] as $configStr){
                                        
                                        #用 "=" 分割設定字串
                                        #函式說明:
                                        #將固定格式的字串分開,並回傳分開的結果。
                                        #回傳的參數:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["oriStr"],要分割的原始字串內容
                                        #$result["dataArray"],爲分割好字串的陣列內容,$result["dataArray"][$i]爲第($i+1)段的內容。
                                        #$result["dataCounts"],爲總共分成幾段
                                        #必填參數:
                                        $conf["stringProcess::spiltString"]["stringIn"]=$configStr;#要處理的字串。
                                        $conf["stringProcess::spiltString"]["spiltSymbol"]="=";#爲以哪個符號作爲分割
                                        #備註:
                                        #建議新增如果透過" "分割後的內容含有""的元素,將其移除,並將後面有內容的元素補上,key也重新排序。
                                        $spiltString=stringProcess::spiltString($conf["stringProcess::spiltString"]);
                                        unset($conf["stringProcess::spiltString"]);
                                        
                                        #如果分割設定值字串失敗
                                        if($spiltString["status"]=="false"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #如果只有一段內容
                                        if($spiltString["dataCounts"]=="1"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="設定值字串「".$configStr."」必須要用「=」來間隔設定屬性與其數值";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #設定暫時的設定值
                                        $oldConfigValue=ini_set($spiltString["dataArray"][0],$spiltString["dataArray"][1]);
                                        
                                        #如果設定失敗
                                        if($oldConfigValue===false){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="將屬性「".$spiltString["dataArray"][0]."」設定為「".$spiltString["dataArray"][1]."」失敗";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #反之儲存舊的永久設地數值
                                        else{
                                                
                                                #取得舊的設定值
                                                $result["config"][$count]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                $result["config"][$spiltString["dataArray"][0]]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                                                                
                                                #取得新的設定值
                                                $result["config"][$count]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                $result["config"][$spiltString["dataArray"][0]]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                
                                                #計數加1
                                                $count++;
                                                
                                                }#else end
                                        
                                        }#foreach end           
                                                                
                                #跳出switch
                                break;
                                
                        #如果是自訂設定值的狀態
                        case "custom":
                                        
                                #初始化計數為0
                                $count=0;
                        
                                #針對每個 $conf["customSettings"]
                                foreach($conf["customSettings"] as $configStr){
                                        
                                        #用 "=" 分割設定字串
                                        #函式說明:
                                        #將固定格式的字串分開,並回傳分開的結果。
                                        #回傳的參數:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["oriStr"],要分割的原始字串內容
                                        #$result["dataArray"],爲分割好字串的陣列內容,$result["dataArray"][$i]爲第($i+1)段的內容。
                                        #$result["dataCounts"],爲總共分成幾段
                                        #必填參數:
                                        $conf["stringProcess::spiltString"]["stringIn"]=$configStr;#要處理的字串。
                                        $conf["stringProcess::spiltString"]["spiltSymbol"]="=";#爲以哪個符號作爲分割
                                        #備註:
                                        #建議新增如果透過" "分割後的內容含有""的元素,將其移除,並將後面有內容的元素補上,key也重新排序。
                                        $spiltString=stringProcess::spiltString($conf["stringProcess::spiltString"]);
                                        unset($conf["stringProcess::spiltString"]);
                                        
                                        #如果分割設定值字串失敗
                                        if($spiltString["status"]=="false"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #如果只有一段內容
                                        if($spiltString["dataCounts"]=="1"){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="設定值字串「".$configStr."」必須要用「=」來間隔設定屬性與其數值";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #設定暫時的設定值
                                        $oldConfigValue=ini_set($spiltString["dataArray"][0],$spiltString["dataArray"][1]);
                                        
                                        #如果設定失敗
                                        if($oldConfigValue===false){
                                                
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"][]="將屬性「".$spiltString["dataArray"][0]."」設定為「".$spiltString["dataArray"][1]."」失敗";
                                                
                                                #回傳結果
                                                return $result;
                                                
                                                }#if end
                                                
                                        #反之儲存舊的永久設地數值
                                        else{
                                                
                                                #取得舊的設定值
                                                $result["config"][$count]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                $result["config"][$spiltString["dataArray"][0]]["oldValue"]=$spiltString["dataArray"][0]."=".$oldConfigValue;
                                                                                                
                                                #取得新的設定值
                                                $result["config"][$count]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                $result["config"][$spiltString["dataArray"][0]]["newValue"]=$spiltString["dataArray"][0]."=".$spiltString["dataArray"][1];
                                                
                                                #計數加1
                                                $count++;
                                                
                                                }#else end
                                        
                                        }#foreach end
                                                                
                                #跳出switch
                                break;
                        
                        #如果不是以上狀況,那就是參數錯誤       
                        default :
                        
                                #設置錯誤訊息
                                $result["error"][]="\$conf[\"mode\"]模式設定錯誤";
                        
                                #設置執行失敗
                                $result["status"]="false";
                        
                                #回傳結果
                                return $result;
                        
                        }#switch end
                        
                #設置執行正常
                $result["status"]="true";
        
                #回傳結果
                return $result;
                
                }#funciton changeSettings end
                
        /*
        #函式說明:
        #依照條件增加記憶體的上限.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["argu"],使用的參數.
        #$result["content"],提示訊息.
        #$result["stdout"],若有serverCache參數,則會回傳該項目,代表執行程式過程中的標準輸出.
        #$result["stderr"],若有serverCache參數,則會回傳該項目,代表執行程式過程中的非標準輸出.
        #$result["cache"],若有serverCache參數,則會回傳該項目,代表執行本函式程式的回傳結果.
        #必填參數:
        #無.
        #可省略參數:
        #$conf["stepAmount"],一次要增加多少上限,預設為當前環境的上限,單位位M(Mega Bytes).
        #$conf["stepAmount"]="";
        #$conf["whenAviMemLessThan"],字串整數,什麼時候要增加記憶體,預設為可用的記憶體不超過10%時,亦即10;範圍為1~50,亦即範圍為1~50%.
        #$conf["whenAviMemLessThan"]="10"
        #$conf["client"],陣列,若本函式作為 sock::unixDomainSockServer 的 funcToRunWhenIdle 參數,則此為所有用戶的資訊.
        #$conf["client"]=;
        #$conf["serverCache"],陣列,若本函式作為 sock::unixDomainSockServer 的 funcToRunWhenIdle 參數,則此為
        #$conf["serverCache"]=;
        #參考資料:
        #https://www.php.net/manual/en/function.memory-get-usage.php
        #https://www.php.net/manual/en/ini.core.php#ini.memory-limit
        #https://www.php.net/manual/en/function.ini-set.php
        #備註:
        #無.
        */
        public static function autoAddMemory(&$conf=array()){
        
                #初始化要回傳的結果
                $result=array();

                #取得當前執行的函數名稱
                $result["function"]=__FUNCTION__;
                
                #取得參數
                $result["argu"]=$conf;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){

                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if(is_null($conf)){

                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";

                                }#if end

                        #回傳結果
                        return $result;

                        }#if end
                
                #函式說明:
                #顯示目前的php設定值
                #回傳的結果:
                #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前執行的函數名稱.
                #$result["content"],常用的設定值的內容、也可指定想要看的設定值內容.
                #必填參數:
                #無.
                #可省略參數:
                #$conf["settingsName"],字串陣列,自己想要看的設定值內容,預設為array("display_errors","upload_max_filesize","post_max_size","output_buffering","session.auto_start","memory_limit").
                $conf["config::showSettings"]["settingsName"]=array("memory_limit");
                #$conf["showAll"],字串,是否要取得所有設定,"true"代表要,會覆寫$conf["settingsName"]的設定,"false"代表不要,預設為"fale".
                #$conf["showAll"]="";
                #參考資料:
                #http://www.php.net/manual/en/function.ini-get.php
                #http://www.php.net/manual/en/function.ini-get-all.php
                #備註:
                #無.
                $showSettings=config::showSettings($conf["config::showSettings"]);
                unset($conf["config::showSettings"]);
                
                #如果執行失敗
                if($showSettings["status"]==="false"){
                
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置錯誤資訊
                        $result["error"]=$showSettings;
                
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #取得系統設定的php記憶體上限
                $phpMaxMemInConfig=$showSettings["content"]["memory_limit"];
                
                #如果單位是M
                #函式說明:
                #取得符合特定字首與字尾的字串
                #回傳結果:
                #$result["status"],若爲"true"則代表執行正常;若爲"false"則代表執行失敗。
                #$result["function"],當前執行的函數名稱.
                #$result["error"],錯誤訊息陣列.
                #$result["founded"],若為"true"則代表有找到符合字首條件的結果;若爲"false"則代表沒有找到。
                #$result["content"],符合條件的字串,去掉字首字尾後的結果.
                #$result["returnString"],爲符合字首字、尾條件的字串內容。
                #$result["argu"],使用的參數.
                #必填參數:
                #$conf["checkString"],字串,要檢查的字串.
                $conf["stringProcess::getMeetConditionsString"]["checkString"]=$phpMaxMemInConfig;
                #可省略參數:
                #$conf["frontWord"],字串,用來檢查字首應該要有什麼字串,預設不指定.
                #$conf["stringProcess::getMeetConditionsString"]["frontWord"]="";
                #$conf["tailWord"],字串,用來檢查字尾應該要有什麼字串,預設不指定.
                $conf["stringProcess::getMeetConditionsString"]["tailWord"]="M";
                #參考資料:
                #str_spilt(),可以將字串依照字母分割成一個個陣列字串。
                #備註:
                #無.
                $getMeetConditionsString=search::getMeetConditionsString($conf["stringProcess::getMeetConditionsString"]);
                unset($conf["stringProcess::getMeetConditionsString"]);
                
                #如果執行失敗
                if($getMeetConditionsString["status"]==="false"){
                
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置錯誤資訊
                        $result["error"]=$getMeetConditionsString;
                
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果是M結尾
                if($getMeetConditionsString["founded"]==="true"){
                
                        #轉換為bytes
                        $phpMaxMemInConfig=$getMeetConditionsString["content"]*1024*1024;
                
                        }#if end
                                
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("stepAmount");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                #$conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                #$conf["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                #$conf["canNotBeEmpty"]=array();
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                $conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("stepAmount","whenAviMemLessThan");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("stepAmount","whenAviMemLessThan","client","serverCache");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string","string","array","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array($phpMaxMemInConfig,"10",null,null);
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
                
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #如果有 serverCache
                if(isset($conf["serverCache"])){
                
                        /* debug
                        
                        #函式說明:
                        #撰寫log
                        #回傳結果:
                        #$result["status"],狀態,"true"或"false".
                        #$result["error"],錯誤訊息陣列.
                        #$result["function"],當前函式的名稱.
                        #$result["argu"],使用的參數.
                        #$result["content"],要寫入log的內容字串.
                        #必填參數:
                        #$conf["path"],字串,log檔案的路徑與名稱.
                        $conf["logs::record"]["path"]="/tmp/config::autoAddMemory.log";
                        #$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
                        $conf["logs::record"]["content"]=$conf["serverCache"];
                        #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                        $conf["logs::record"]["fileArgu"]=__FILE__;
                        #可省略參數:
                        #$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
                        #$conf["rewrite"]="false";
                        #$conf["returnOnly"],預設為"false",會寫入到log檔案.若為"true"則不會寫入log.
                        #$conf["returnOnly"]="true";
                        #參考資料:
                        #無.
                        #備註:
                        #無.
                        $record=logs::record($conf["logs::record"]);
                        unset($conf["logs::record"]);
                                                                                                
                        #如果執行失敗
                        if($record["status"]==="false"){
                        
                                #設置執行錯誤識別
                                $result["status"]="false";
                        
                                #設置執行錯誤
                                $result["error"]=$record;
                        
                                #回傳結果
                                return $result;
                        
                                }#if end
                        
                        */
                
                        #記錄回傳的參考
                        #$result["cache"]=&$result;
                
                        #如果有 clientSide
                        if(isset($conf["serverCache"]["clientSide"])){
                                
                                #如果有 addOnProcessFunc
                                if(isset($conf["serverCache"]["clientSide"]["addOnProcessFunc"])){
                                
                                        #如果有 addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon
                                        if(isset($conf["serverCache"]["clientSide"]["addOnProcessFunc"]["\qbpwcf\sock::addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon"])){
                                        
                                                /* debug
                                                                        
                                                #函式說明:
                                                #撰寫log
                                                #回傳結果:
                                                #$result["status"],狀態,"true"或"false".
                                                #$result["error"],錯誤訊息陣列.
                                                #$result["function"],當前函式的名稱.
                                                #$result["argu"],使用的參數.
                                                #$result["content"],要寫入log的內容字串.
                                                #必填參數:
                                                #$conf["path"],字串,log檔案的路徑與名稱.
                                                $conf["logs::record"]["path"]="/tmp/config::autoAddMemory.log";
                                                #$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
                                                $conf["logs::record"]["content"]=$conf["serverCache"]["clientSide"]["addOnProcessFunc"]["\qbpwcf\sock::addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon"];
                                                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                                $conf["logs::record"]["fileArgu"]=__FILE__;
                                                #可省略參數:
                                                #$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
                                                #$conf["rewrite"]="false";
                                                #$conf["returnOnly"],預設為"false",會寫入到log檔案.若為"true"則不會寫入log.
                                                #$conf["returnOnly"]="true";
                                                #參考資料:
                                                #無.
                                                #備註:
                                                #無.
                                                $record=logs::record($conf["logs::record"]);
                                                unset($conf["logs::record"]);
                                                                                                                        
                                                #如果執行失敗
                                                if($record["status"]==="false"){
                                                
                                                        #設置執行錯誤識別
                                                        $result["status"]="false";
                                                
                                                        #設置執行錯誤
                                                        $result["error"]=$record;
                                                
                                                        #回傳結果
                                                        return $result;
                                                
                                                        }#if end
                                                
                                                */
                                        
                                                #如果有程式在背景執行
                                                if(isset($conf["serverCache"]["clientSide"]["addOnProcessFunc"]["\qbpwcf\sock::addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon"]["content"])){
                                                
                                                        #如果該程序資訊存在
                                                        if(isset($conf["serverCache"]["clientSide"]["addOnProcessFunc"]["\qbpwcf\sock::addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon"]["content"][0])){
                                                                        
                                                                #另存程序變數參考
                                                                $process=&$conf["serverCache"]["clientSide"]["addOnProcessFunc"]["\qbpwcf\sock::addOnProcessFuncForUnixDomainSockServerInRunWithAutoAddMemoryDaemon"]["content"][0];
                                                                
                                                                /* debug
                                                                        
                                                                #函式說明:
                                                                #撰寫log
                                                                #回傳結果:
                                                                #$result["status"],狀態,"true"或"false".
                                                                #$result["error"],錯誤訊息陣列.
                                                                #$result["function"],當前函式的名稱.
                                                                #$result["argu"],使用的參數.
                                                                #$result["content"],要寫入log的內容字串.
                                                                #必填參數:
                                                                #$conf["path"],字串,log檔案的路徑與名稱.
                                                                $conf["logs::record"]["path"]="/tmp/config::autoAddMemory.log";
                                                                #$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
                                                                $conf["logs::record"]["content"]=$process;
                                                                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                                                $conf["logs::record"]["fileArgu"]=__FILE__;
                                                                #可省略參數:
                                                                #$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
                                                                #$conf["rewrite"]="false";
                                                                #$conf["returnOnly"],預設為"false",會寫入到log檔案.若為"true"則不會寫入log.
                                                                #$conf["returnOnly"]="true";
                                                                #參考資料:
                                                                #無.
                                                                #備註:
                                                                #無.
                                                                $record=logs::record($conf["logs::record"]);
                                                                unset($conf["logs::record"]);
                                                                                                                                        
                                                                #如果執行失敗
                                                                if($record["status"]==="false"){
                                                                
                                                                        #設置執行錯誤識別
                                                                        $result["status"]="false";
                                                                
                                                                        #設置執行錯誤
                                                                        $result["error"]=$record;
                                                                
                                                                        #回傳結果
                                                                        return $result;
                                                                
                                                                        }#if end
                                                                
                                                                */
                                                                
                                                                #取得標準輸出
                                                                $result["stdout"]=$process["content"];
                                                                
                                                                #取得非標準輸出
                                                                $result["error"]=$process["error"];
                                                                
                                                                #如果標準輸出是 reource
                                                                if(gettype($process["content"])==="resource"){
                                                                
                                                                        #取得程式執行過程產生的標準輸出
                                                                        $result["stdout"]=stream_get_contents($process["content"]);
                                                                        
                                                                        }#if end
                                                                
                                                                #如果非標準輸出是 reource
                                                                if(gettype($process["error"])==="resource"){
                                                                        
                                                                        #取得程式執行過程產生的標準輸出
                                                                        $result["error"]=stream_get_contents($process["error"]);
                                                                        
                                                                        }#if end
                                                                        
                                                                #如果記錄上顯示該程序尚在執行中
                                                                if($process["proc_get_status"]["running"]===true){
                                                                
                                                                        #嘗試取得該程序的狀態
                                                                        $proc_get_status=proc_get_status($process["process"]);
                                                                
                                                                        #如果已經結束執行
                                                                        if($proc_get_status["running"]===false){
                                                                        
                                                                                #設置要結束執行unix domain server
                                                                                $result["exit"]="true";
                                                                                
                                                                                #設置執行正常
                                                                                $result["status"]="true";
                                                                                
                                                                                }#if end
                                                                        
                                                                        }#if end
                                                                        
                                                                #反之代表程序已經結束
                                                                else{
                                                                
                                                                        #設置要結束執行unix domain server
                                                                        $result["exit"]="true";
                                                                        
                                                                        #設置執行正常
                                                                        $result["status"]="true";
                                                                        
                                                                        }#else end
                                                                
                                                                /* debug
                                                                        
                                                                #函式說明:
                                                                #撰寫log
                                                                #回傳結果:
                                                                #$result["status"],狀態,"true"或"false".
                                                                #$result["error"],錯誤訊息陣列.
                                                                #$result["function"],當前函式的名稱.
                                                                #$result["argu"],使用的參數.
                                                                #$result["content"],要寫入log的內容字串.
                                                                #必填參數:
                                                                #$conf["path"],字串,log檔案的路徑與名稱.
                                                                $conf["logs::record"]["path"]="/tmp/config::autoAddMemory.log";
                                                                #$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
                                                                $conf["logs::record"]["content"]=$result;
                                                                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                                                $conf["logs::record"]["fileArgu"]=__FILE__;
                                                                #可省略參數:
                                                                #$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
                                                                #$conf["rewrite"]="false";
                                                                #$conf["returnOnly"],預設為"false",會寫入到log檔案.若為"true"則不會寫入log.
                                                                #$conf["returnOnly"]="true";
                                                                #參考資料:
                                                                #無.
                                                                #備註:
                                                                #無.
                                                                $record=logs::record($conf["logs::record"]);
                                                                unset($conf["logs::record"]);
                                                                                                                                        
                                                                #如果執行失敗
                                                                if($record["status"]==="false"){
                                                                
                                                                        #設置執行錯誤識別
                                                                        $result["status"]="false";
                                                                
                                                                        #設置執行錯誤
                                                                        $result["error"]=$record;
                                                                
                                                                        #回傳結果
                                                                        return $result;
                                                                
                                                                        }#if end
                                                                
                                                                */
                                                                
                                                                }#if end
                                                
                                                        }#if end
                                        
                                                }#if end
                                
                                        }#if end
                        
                                }#if end
                
                        }#if end
                
                #如果參數 whenAviMemLessThan 不為 
                $whenAviMemLessThan=(int)($conf["whenAviMemLessThan"]);
                
                #如果小於1
                if($whenAviMemLessThan<1){
                
                        #設置為1
                        $whenAviMemLessThan=1;
                
                        }#if end
                        
                #如果大於50
                else if($whenAviMemLessThan>50){
                
                        #設置為50
                        $whenAviMemLessThan=50;
                
                        }#if end
                
                #計算需要增加記憶體的門檻
                $condition=$phpMaxMemInConfig*$whenAviMemLessThan/100;
                        
                #get memeory usage
                $memUsedInBytes=\memory_get_usage();
                
                #如果使用的記憶體已經達到門檻
                if($memUsedInBytes>=$condition){
                
                        #計算新的記憶體上限
                        $newMemoryLimit=$phpMaxMemInConfig+$stepAmount;
                
                        #依照 stepAmount 來增加可用記憶體的上限
                        $return=\ini_set("memory_limit",$stepAmount);
                
                        #如果設置失敗
                        if($return===false){
                        
                                #設置執行失敗
                                $result["status"]="false";

                                #設置執行錯誤訊息
                                $result["error"][]="加大記憶體上限失敗";
                                
                                #cache
                                $result["cache"]=&$result;
                                
                                #回傳結果
                                return $result;
                        
                                }#if end
                                
                        #設置正常訊息
                        $result["content"]="memeory_limit changed from ".$return." to ".$newMemoryLimit;
                                        
                        }#if end
                        
                #提示未改變
                $result["content"]="memeory_limit not changed"; 
                        
                #設置執行正常
                $result["status"]="true";
                
                #cache
                $result["cache"]=&$result;
                
                #回傳結果
                return $result;
                
                }#function autoAddMemory end
        
        /*
        #函式說明:
        #建立供 apache 讀取的設定檔案.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["content"],定義對應的內容.
        #必填參數:
        #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
        $conf["fileArgu"]=__FILE__;
        #$conf["configFileAddr"],字串,定義檔位置與名稱
        $conf["configFileAddr"]="";
        #$conf["content"],陣列,要儲存的key -> value 陣列.
        $conf["content"]=array("169.254.1.1"=>array("groupName"=>"local"));
        #可省略參數:
        #$conf["web"],是要取得網路上的檔案則為"true";反之則為"false",預設為後者.
        #$conf["web"]="false";
        #參考資料:
        #無.
        #備註:
        #檔案內容的格式為多行json編碼然後url編碼然後base64編碼後的內容,每行代表一組定義.每組定義的json格式為php多維陣列所組成.
        */
        public static function create(&$conf=array()){
        
                #初始化要回傳的結果
                $result=array();

                #儲存當前執行的函數
                $result["function"]=__FUNCTION__;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
        
                        }#if end
        
                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("fileArgu","configFileAddr","content");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string","string","array");
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                $conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("web");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array("false");
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果檢查失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #debug
                #var_dump($conf["content"]);exit;       
                        
                #函式說明:
                #將字串寫入到檔案
                #回傳結果:
                #$result["status"],"true"表示檔案寫入成功,"false"表示檔案寫入失敗.
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前執行的函數名稱.
                #$result["fileInfo"],實際上寫入的檔案資訊陣列.
                #$result["fileInfo"]["createdFileName"],建立好的檔案名稱.
                #$result["fileInfo"]["createdFilePath"],檔案建立的路徑.
                #$result["fileInfo"]["createdFilePathAndName"].建立好的檔案名稱與路徑.
                #$result["argu"],使用的參數.
                #必填參數:
                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                $conf["fileAccess::writeTextIntoFile"]["fileArgu"]=$conf["fileArgu"];
                #可省略參數:
                #$conf["fileName"],字串,爲要編輯的檔案名稱,預設為隨機產生的檔案名稱.
                $conf["fileAccess::writeTextIntoFile"]["fileName"]=$conf["configFileAddr"];
                #$conf["inputString"],字串,爲要寫入到裏面的內容,若要每筆資料寫入後換行,則可以在字串內容後面加上 \r\n 即可,預設為"".
                $conf["fileAccess::writeTextIntoFile"]["inputString"]=base64_encode(urlencode(json_encode($conf["content"])));
                #$conf["writeMethod"],字串,爲檔案撰寫的方式,可省略,是複寫'a'還是,重新寫入'w',預設爲'w',重新寫入.
                #$conf["writeMethod"]="a";
                #$conf["checkRepeat"],字串,"true"代表建立檔案之前要先檢查檔案是否存在,若存在則在原名稱後面加上從(1)開始的編號.
                #$conf["checkRepeat"]="";
                #$conf["filenameExtensionStartPoint"],字串,檔案的副檔名是從倒數第幾個小數點(dot)開始,預設為"1",最後一個小數點,必須與$conf["checkRepeat"]搭配才會生效.
                #$conf["filenameExtensionStartPoint"]="";
                #$conf["repeatNameRule"],字串,遇到相同名稱的檔案要如何加上識別的編號,編號用「\$i」表示,預設為"(\$i)",必須與$conf["checkRepeat"]搭配才會生效.
                #$conf["repeatNameRule"]="";
                #$conf["web"],檔案是否位於網站上"true",若是在檔案系統則為"false",預設為"true".
                $conf["fileAccess::writeTextIntoFile"]["web"]="false";
                #參考資料:
                #無.
                #備註:
                #無.
                $writeTextIntoFile=fileAccess::writeTextIntoFile($conf["fileAccess::writeTextIntoFile"]);
                unset($conf["fileAccess::writeTextIntoFile"]);
        
                #如果執行敗
                if($writeTextIntoFile["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$writeTextIntoFile;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #設置定義正常
                $result["status"]="true";
        
                #回傳結果
                return $result;
        
                }#function create end
        
        /*
        #函式說明:
        #提供post的變數查尋定義檔,給予回應.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["argu"],使用的參數陣列.
        #$result["founded"],"true"代表有找到定義,"false"代表沒有找到定義.
        #$result["content"],定義對應的內容.
        #必填參數:
        #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
        $conf["fileArgu"]=__FILE__;
        #$conf["configFileAddr"],字串/陣列,若為字串則為定義檔位置與名稱;若為陣列則為實際的定義檔案內容(每個元素代表一個設定對應的內容).
        $conf["configFileAddr"]="";
        #可省略參數:
        #$conf["web"],是要取得網路上的檔案則為"true";反之則為"false",預設為後者.
        #$conf["web"]="false";
        #參考資料:
        #無.
        #備註:
        #檔案內容的格式為多行json編碼然後url編碼然後base64編碼後的內容,每行代表一組定義.每組定義的json格式為php多維陣列所組成.
        */
        public static function server(&$conf=array()){
        
                #初始化要回傳的結果
                $result=array();

                #儲存當前執行的函數
                $result["function"]=__FUNCTION__;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
        
                        }#if end
        
                #記錄所使用的參數
                $result["argu"]=$conf;
        
                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("fileArgu","configFileAddr");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string",null);
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["canBeEmptyString"],必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true"。
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("web");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array("false");
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果檢查失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #debug
                #var_dump($checkArguments);exit;
                
                #儲存key的結構
                $keys=array();
                
                #如果沒有 post 變數存在
                if(count($_POST)<1){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"][]="沒有post變數";
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #debug
                #var_dump($_POST);exit;
                
                #取得第一層key
                $layer=array_keys($_POST)[0];
                
                #取得數值內容
                $values=$_POST[$layer];
                
                #如果該層級內容形態是陣列
                while(gettype($values)==="array"){
                
                        #抓取查尋的key結構
                        $keys[]=$layer;
                        
                        #取得新層級的key
                        $layer=array_keys($values)[0];
                        
                        #取得新的內容
                        $values=$values[$layer];
                        
                        }#while end
                        
                #取得最後一層的key
                $keys[]=$layer;
                
                #debug
                #var_dump($keys);exit;
                
                #設置預設的定義內容
                $result["content"]="undefined";
        
                #如果configFileAddr是字串
                if(gettype($conf["configFileAddr"])==="string"){
                
                        #代表為檔案位置
                        
                        #函式說明:
                        #依據行號分隔抓取檔案的內容,結果會回傳一個陣列
                        #回傳的變數說明:
                        #$result["status"],執行是否成功,"true"代表成功;"fasle"代表失敗.
                        #$result["error"],錯誤訊息提示.
                        #$result["warning"],警告訊息.
                        #$result["function"],當前執行的函數名稱.
                        #$result["fileContent"],爲檔案的內容陣列.
                        #$result["lineCount"],爲檔案內容總共的行數.
                        #$result["fullContent"],為檔案的完整內容.
                        #$result["base64data"],為檔案的base64內容.
                        #$result["mimeType"],為檔案的mime type.
                        #必填的參數:
                        #$conf["filePositionAndName"],字串,爲檔案的位置以及名稱.
                        $conf["fileAccess::getFileContent"]["filePositionAndName"]=$conf["configFileAddr"];
                        #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                        $conf["fileAccess::getFileContent"]["fileArgu"]=$conf["fileArgu"];
                        #可省略參數:
                        #$conf["web"],是要取得網路上的檔案則為"true";反之則為"false".
                        $conf["fileAccess::getFileContent"]["web"]=$conf["web"];
                        #參考資料:
                        #file(),取得檔案內容的行數.
                        #file=>http:#php.net/manual/en/function.file.php
                        #rtrim(),剔除透過file()取得每行內容結尾的換行符號.
                        #filesize=>http://php.net/manual/en/function.filesize.php
                        $getFileContent=fileAccess::getFileContent($conf["fileAccess::getFileContent"]);
                        unset($conf["fileAccess::getFileContent"]);
                        
                        #如果讀取檔案失敗
                        if($getFileContent["status"]==="false"){
                        
                                #設置錯誤識別
                                $result["status"]="false";
                                
                                #設置錯誤訊息
                                $result["error"]=$getFileContent;
                                
                                #回傳結果
                                return $result;
                        
                                }#if end
                        
                        #debug
                        #var_dump($getFileContent);
                        #var_dump(base64_decode($getFileContent));
                        #var_dump(urldecode(base64_decode($getFileContent)));
                        #var_dump(json_decode(urldecode(base64_decode($getFileContent))));
                        #exit;
                        
                        #針對每行
                        foreach($getFileContent["fileContent"] as $line){
                        
                                #解析內容
                                $def=(array)json_decode(urldecode(base64_decode($line)));
                                        
                                #debug
                                #var_dump($def);exit;
                                #var_dump($keys[$i]);exit;
                                        
                                #初始化要找到的層級
                                $i=0;
                        
                                #如果有所屬的層級
                                while(isset($def[$keys[$i]])){
                                
                                        #取得層級所屬的內容
                                        $def=(array)$def[$keys[$i]];
                                
                                        #debug
                                        #var_dump($def);exit;
                                
                                        #如果還不是最後一個key層級
                                        if(isset($keys[$i+1])){
                                        
                                                #層級加一
                                                $i++;
                                        
                                                }#if end
                                
                                        #反之是最後一個key的層級了
                                        else{
                                        
                                                #設置定義的內容
                                                $result["content"]=$def;
                                        
                                                #設置有找到定義
                                                $result["founded"]="true";
                                        
                                                #設置定義正常
                                                $result["status"]="true";
                                        
                                                #回傳結果
                                                return $result;
                                        
                                                }#else end
                                
                                        }#while end
                                        
                                #到這邊代表沒有符合的元素
                        
                                }#foreach end
                
                        }#if end
        
                #反之如果為array
                else if(gettype($conf["configFileAddr"])==="array"){
                
                        #針對每行
                        foreach($conf["configFileAddr"] as $configName=>$def){
                        
                                #debug
                                #var_dump($def);exit;
                                #var_dump($keys[$i]);exit;
                                        
                                #初始化要找到的層級
                                $i=0;
                        
                                #如果有所屬的層級
                                while(isset($def[$keys[$i]])){
                                
                                        #取得層級所屬的內容
                                        $def=(array)$def[$keys[$i]];
                                
                                        #debug
                                        #var_dump($def);exit;
                                
                                        #如果還不是最後一個key層級
                                        if(isset($keys[$i+1])){
                                        
                                                #層級加一
                                                $i++;
                                        
                                                }#if end
                                
                                        #反之是最後一個key的層級了
                                        else{
                                        
                                                #設置定義的內容
                                                $result["content"]=$def;
                                        
                                                #設置有找到定義
                                                $result["founded"]="true";
                                        
                                                #設置定義正常
                                                $result["status"]="true";
                                        
                                                #回傳結果
                                                return $result;
                                        
                                                }#else end
                                
                                        }#while end
                                        
                                #到這邊代表沒有符合的元素
                        
                                }#foreach end
                
                        }#if end
                        
                #反之如果為其他形態
                else{
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"][]="configFileAddr的形態只能為string或array";
                        
                        #回傳結果
                        return $result;
                
                        }#else end
                        
                #設置定義正常
                $result["status"]="true";
        
                #設置沒有找到定義
                $result["founded"]="false";
        
                #回傳結果
                return $result;
        
                }#function server end
        
        /*
        #函式說明:
        #查尋有使用 server 函式提供組態設定檔的服務,取得key的value.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["argu"],使用的參數.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["rawContent"],得到的原始訊息.
        #$result["content"],用json_decode後的結果;若"inBg"為"true",則其每個元素為其指令執行的結果訊息陣列,key為"status"代表執行是否正常的識別;key為"statusCode"代表程式結束後回傳給對應executeBy程式的數值;key為"output"代表標準輸出,若為resource,則代表為pipe;key為"error"代表非標準輸出,若為resource,則代表為pipe;key為"input"代表成功輸入的指令;key為"process"代表該程序經proc_open後的process source;key為"proc_get_status"代表程序的資訊.
        #必填參數:
        #$conf["server"],字串,組態服務設定服務的網址
        $conf["server"]="";
        #$conf["postName"],字串,POST變數的名稱,亦即要查尋的定義名稱.
        $conf["postName"]="";
        #$conf["fileArgu"],字串,變數__FILE__的內容.
        $conf["fileArgu"]=__FILE__;
        #可省略參數:
        #$conf["cache"],字串,預設為"true",代表會啟用cache服務;反之為"false".
        #$conf["cache"]="false";
        #$conf["clientCacheDaemonSock"],字串,提供cache服務的 unix domain socket 檔案位置,預設為套件根目錄底下的"var/config::client/clientCacheDaemon.sock";.
        #$conf["clientCacheDaemonSock"]="";
        #$conf["inBg"],字串,預設為"false",代表在前景執行;反之為"true"代表在背景中執行,會強制將"cache"參數設為"false".
        #$conf["inBg"]="true";
        #參考資料:
        #無.
        #備註:
        #目前僅能跟server函式提供的服務對接.
        */
        public static function client(&$conf=array()){
        
                #初始化要回傳的結果
                $result=array();

                #儲存當前執行的函數
                $result["function"]=__FUNCTION__;

                #取得參數
                $result["argu"]=$conf;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){
                        
                        #設置執行失敗
                        $result["status"]="false";
                        
                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if($conf==null){
                                
                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";
                                
                                }#if end

                        #回傳結果
                        return $result;
        
                        }#if end
        
                #檢查參數
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容。
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$reuslt["error"],執行不正常結束的錯訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBtCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBtCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBtCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填寫的參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("server","postName","fileArgu");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); 
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string","string","string");
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可以省略的參數:
                #$conf["canBeEmptyString"],必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true"。
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["skipableVariableName"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("cache","clientCacheDaemonSock","inBg");
                #$conf["skipableVariableType"],爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double"); 
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string","string","string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array("true",null,"false");
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料來源:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果檢查失敗
                if($checkArguments["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                #如果檢查不通過
                if($checkArguments["passed"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
                
                #如果要在背景執行
                if($conf["inBg"]==="true"){
                
                        #函式說明:
                        #運行curl cmd
                        #回傳結果:
                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                        #$result["error"],錯誤訊息陣列.
                        #$result["function"],當前執行的函式名稱.
                        #$result["founded"],識別網址找不找得到.
                        #$result["content"],取得的回應內容陣列;若$conf["bgInProc"]為"true",則每個元素為其指令執行的結果訊息陣列,key為"status"代表執行是否正常的識別;key為"statusCode"代表程式結束後回傳給對應executeBy程式的數值;key為"output"代表標準輸出,若為resource,則代表為pipe;key為"error"代表非標準輸出,若為resource,則代表為pipe;key為"input"代表成功輸入的指令;key為"process"代表該程序經proc_open後的process source;key為"proc_get_status"代表程序的資訊.
                        #$result["fullContent"],取得回應的完整字串內容.
                        #$result["cookie"],cookie檔案的位置與名稱.
                        #$result["cmd"],執行的command.
                        #$result["argu],使用的參數.
                        #必填參數:
                        #$conf["url"],字串,目標url.
                        $conf["cmd::curlCmd"]["url"]=$conf["server"];
                        #$conf["fileArgu"],字串,變數__FILE__的內容.
                        $conf["cmd::curlCmd"]["fileArgu"]=$conf["fileArgu"];
                        #可省略參數:
                        #$conf["header"],字串陣列,要傳送的header.
                        #$conf["header"]=array();
                        #$conf["allowAnySSLcertificate"],字串,是否允許不可信任的SSL憑證,預設為"true".
                        #$conf["allowAnySSLcertificate"]="";
                        #$conf["postVar"],字串陣列,每個要傳送的post變數名稱(陣列的key值)與數值.
                        $conf["cmd::curlCmd"]["postVar"]=array($conf["postName"]=>"");
                        #$conf["rawPost"]="字串",要傳送的raw post內容.
                        #$conf["rawPost"]="";
                        #$conf["urlEncode"],字串,post的內容是否要url_encode,"true"代表要,預設為"false"代表不要.
                        #$conf["urlEncode"]="false";
                        #$conf["agent"],字串,user agent的名稱.
                        #$conf["agent"]="";
                        #$conf["cookie"],字串,cookie位置與檔案位置.
                        #$conf["cookie"]="";
                        #$conf["forceNewCookie"],字串,是否要重置cookie,"true"代表要,"false"代表不要,預設為"false".
                        #$conf["forceNewCookie"]="";
                        #$conf["inBg"],字串,"true"代表要在背景中執行;反之則為"false".
                        #$conf["inBg"]="true";
                        #$conf["bgInPorc"],字串,若跟inBg一樣為"true",則會透過proc放在背景執行且回傳proc資訊,以便監控執行狀況.預設為"false",不使用proc.
                        $conf["catchWebContent::curlCmd"]["bgInProc"]="true";
                        #參考資料:
                        #無.
                        #備註:
                        #無.
                        $curlCmd=catchWebContent::curlCmd($conf["catchWebContent::curlCmd"]);
                        unset($conf["catchWebContent::curlCmd"]);
                
                        #如果執行失敗
                        if($curlCmd["status"]==="false"){
                        
                                #設置錯誤識別
                                $result["status"]="false";
                                
                                #設置錯誤訊息
                                $result["error"]=$curlCmd;
                                
                                #回傳結果
                                return $result;
                        
                                }#if end
                
                        #設置proc資訊
                        $result["content"]=$curlCmd["content"];
                
                        #設置執行正常
                        $result["status"]="true";
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #如果沒有設置 cacheFile
                if(!isset($conf["cacheFile"])){
                
                        #取得以該檔案為准的實際位置 lib path
                        exec("cd ".pathinfo(__FILE__)["dirname"].";pwd;",$output,$status);
                        
                        #初始化之
                        $conf["clientCacheDaemonSock"]=$output[0]."/var/config::client/clientCacheDaemon.sock";
                
                        }#if end
                
                #如果有要使用cache
                if($conf["cache"]==="true"){
                
                        #查詢 cahce 內容
                        #連線到 sock::unixDomainSocketServer 產生的  unix domain socket,傳送指定的訊息.
                        #回傳結果:
                        #$result["status"],"true"代表執行正常;"false"代表執行不正常.
                        #$result["error"],錯誤訊息陣列.
                        #$result["function"],當前執行的函式名稱.
                        #$result["argu"],使用的參數.
                        #$result["content"],得到的回應.
                        #必填參數:
                        #$conf["msg"],陣列,要傳送的訊息,其主$conf["msg"]["id"],是無法指定的.
                        $conf["sock::sendAnyMsgToQBPWCFunixSocket"]["msg"]=array("postName"=>$conf["postName"],"server"=>$conf["server"]);
                        #可省略參數:
                        #$conf["sock"],字串,要連線的 usr/bin/qbpwcf-sock.php 所產生的 unix domain socket 路徑與名稱,預設為 qbpwcf_usock_path.
                        $conf["sock::sendAnyMsgToQBPWCFunixSocket"]["sock"]=$conf["clientCacheDaemonSock"];
                        #參考資料:
                        #無.
                        #備註:
                        #無.
                        $sendAnyMsgToQBPWCFunixSocket=sock::sendAnyMsgToQBPWCFunixSocket($conf["sock::sendAnyMsgToQBPWCFunixSocket"]);
                        unset($conf["sock::sendAnyMsgToQBPWCFunixSocket"]);
                
                        #如果執行失敗
                        if($sendAnyMsgToQBPWCFunixSocket["status"]=="false"){
                                
                                #設置錯誤識別
                                $result["status"]="false";
                                
                                #設置錯誤訊息
                                $result["error"]=$sendAnyMsgToQBPWCFunixSocket;
                                
                                #回傳結果
                                return $result;
                                
                                }#if end
                                
                        #如果執行失敗
                        if($sendAnyMsgToQBPWCFunixSocket["status"]==="false"){
                                
                                #設置錯誤識別
                                $result["status"]="false";
                                
                                #設置錯誤訊息
                                $result["error"]=$sendAnyMsgToQBPWCFunixSocket;
                                
                                #回傳結果
                                return $result;
                                
                                }#if end
                        
                        #debug
                        #var_dump(__LINE__,$sendAnyMsgToQBPWCFunixSocket);
                        
                        #設置回應的內容
                        $result["rawContent"]=$sendAnyMsgToQBPWCFunixSocket["content"];
                
                        #設置解析好的json回應內容
                        $result["content"]=json_decode($sendAnyMsgToQBPWCFunixSocket["content"]);
                        
                        #設置執行正常
                        $result["status"]="true";
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #函式說明:
                #運行curl cmd
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["content"],取得的回應內容陣列.
                #$result["fullContent"],取得回應的完整字串內容.
                #$result["cookie"],cookie檔案的位置與名稱.
                #$result["cmd"],執行的command.
                #$result["argu],使用的參數.
                #必填參數:
                #$conf["url"],字串,目標url.
                $conf["cmd::curlCmd"]["url"]=$conf["server"];
                #$conf["fileArgu"],字串,變數__FILE__的內容.
                $conf["cmd::curlCmd"]["fileArgu"]=$conf["fileArgu"];
                #可省略參數:
                #$conf["header"],字串陣列,要傳送的header.
                #$conf["header"]=array();
                #$conf["allowAnySSLcertificate"],字串,是否允許不可信任的SSL憑證,預設為"true".
                #$conf["allowAnySSLcertificate"]="";
                #$conf["postVar"],字串陣列,每個要傳送的post變數名稱(陣列的key值)與數值.
                $conf["cmd::curlCmd"]["postVar"]=array($conf["postName"]=>"");
                #$conf["rawPost"]="字串",要傳送的raw post內容.
                #$conf["rawPost"]="";
                #$conf["urlEncode"],字串,post的內容是否要url_encode,"true"代表要,預設為"false"代表不要.
                #$conf["urlEncode"]="false";
                #$conf["agent"],字串,user agent的名稱.
                #$conf["agent"]="";
                #$conf["cookie"],字串,cookie位置與檔案位置.
                #$conf["cookie"]="";
                #$conf["forceNewCookie"],字串,是否要重置cookie,"true"代表要,"false"代表不要,預設為"false".
                #$conf["forceNewCookie"]="";
                #$conf["inBg"],字串,"true"代表要在背景中執行;反之則為"false".
                #$conf["inBg"]="true";
                #備註:
                #無.
                $curlCmd=catchWebContent::curlCmd($conf["cmd::curlCmd"]);
                unset($conf["cmd::curlCmd"]);
        
                #如果執行失敗
                if($curlCmd["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$curlCmd;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #設置執行正常
                $result["status"]="true";
        
                #設置回應的內容
                $result["rawContent"]=$curlCmd["fullContent"];
        
                #設置解析好的json回應內容
                $result["content"]=json_decode($curlCmd["fullContent"]);
                
                #回傳結果
                return $result;
        
                }#function client end
        
        /*
        #函式說明:
        #給clientCacheDaemon用的addOnProcessFunc,處理來自config::client有使用cache的要求.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["warning"],警告訊息陣列.
        #必填參數:
        #$conf["request"],陣列,收到的訊息.
        #$conf["request"]=array();
        #$conf["request"]["postName"],字串,要查詢的索引.
        #$conf["request"]["postName"]="";
        #$conf["request"]["server"],字串,要去哪個config server查詢.
        #$conf["request"]["server"]="";
        #$conf["request"]["id"],字串,用來識別用戶的uuid.
        #$conf["request"]["id"]="";
        #$conf["socket"],client的socket
        #$conf["socket"]=;
        #$conf["info"],陣列,sock跟cache file path資訊.
        #$conf["info"]=array();
        #$conf["info"]["sock"],字串,unix domain socket addr.
        #$conf["info"]["sock"]=;
        #$conf["info"]["cacheFilePath"],字串,cache file path.
        #$conf["info"]["cacheFilePath"]=;
        #$conf["info"]["checkVersionInterval"],字串,距離最後一次取得資料的時間多久就要檢查是否有新資料,預設為60秒.
        #$conf["info"]["checkVersionInterval"]="60";
        #$conf["clientCache"],陣列.存放跟取得快取的陣列.
        #$conf["clientCache"]=array();
        #$conf["last_req_time"],字串,存放上次執行的unixtime.
        #$conf["last_req_time"]="";
        #可省略參數:
        #無.
        #參考資料:
        #無.
        #備註:
        #無,
        */
        public static function addOnProcessFuncForClientCacheDaemon(&$conf){
        
                #debug
                #var_dump(__LINE__,"into function ".__FUNCTION__);
        
                #初始化結果
                $result=array();

                #取得當前執行的函數名稱
                $result["function"]=__FUNCTION__;

                #取得參數
                $result["argu"]=$conf;

                #如果 $conf 不為陣列
                if(gettype($conf)!=="array"){

                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if(is_null($conf)){

                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";

                                }#if end

                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end

                        #回傳結果
                        return $result;

                        }#if end
        
                #debug
                #var_dump(__LINE__,"檢查 參數");
        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("socket","request","info","clientCache","last_req_time");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("resource","array","array","array","integer");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                $conf["variableCheck::checkArguments"]["canNotBeEmpty"]=array("socket","info");
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                #$conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","request");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("resource","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
        
                #debug
                #var_dump(__LINE__,"檢查  request 參數");
        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf["request"];
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("id","postName","server");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string","string","string");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                $conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                #$conf["variableCheck::checkArguments"]["canNotBeEmpty"]=array("sock");
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                #$conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","request");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("resource","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf["info"];
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("sock","cacheFilePath","checkVersionInterval");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string","string","string");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                $conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                #$conf["variableCheck::checkArguments"]["canNotBeEmpty"]=array("sock");
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                #$conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","request");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("resource","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end
        
                #判斷 client cahce 有無指定來源的資料
                
                #debug
                #var_dump(__LINE__,"判斷 client cahce 有無指定來源的資料");
                
                #來源
                #$conf["request"]["server"];
                
                #debug
                #var_dump(__LINE__,$conf["request"]["server"]);
                
                #索引
                #$conf["request"]["postName"];
                
                #debug
                #var_dump(__LINE__,$conf["request"]["postName"]);
                
                #如果存在
                if(isset($conf["clientCache"]["share"]["configs"])){
                
                        #debug
                        #var_dump(__LINE__,$conf["clientCache"]["share"]["configs"]);
                
                        #如果有對應來源的資料
                        if(isset($conf["clientCache"]["share"]["configs"][$conf["request"]["server"]])){
                        
                                #如果有該索引的資料
                                if(isset($conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]])){
                                
                                        #如果存在 content 跟 time
                                        if( isset($conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["content"]) && isset($conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["time"]) ){
                                        
                                                #取得 content
                                                $result["content"]=json_decode($conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["content"]);
                                        
                                                #記錄多少秒未更新
                                                $secsNoUpdate=time()-$conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["time"];
                                        
                                                #記錄資料過期多少秒
                                                $secsExpired=$secsNoUpdate-$conf["info"]["checkVersionInterval"];
                                        
                                                #提示資料超過期限未更新
                                                if($secsNoUpdate>$conf["info"]["checkVersionInterval"]){
                                                
                                                        #設置警告訊息
                                                        $result["warning"][]="data expired for ".$secsExpired." secs";
                                                
                                                        }#if end 
                                                        
                                                #設置執行正常
                                                $result["status"]="true";
                        
                                                #debug
                                                #var_dump(__LINE__,$result,json_encode($result));
                        
                                                #回傳給用戶 - start
                                                
                                                #初始化要回傳的訊息
                                                $msg=array();
                                                
                                                #設置回傳的內容
                                                $msg["content"]=$result["content"];
                                                
                                                #設置回傳的狀態
                                                $msg["status"]=$result["status"];
                                                
                                                #寫入回應的內容
                                                fwrite($conf["socket"],json_encode($msg).PHP_EOL);
                                        
                                                #結束回應
                                                fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                                        
                                                #關閉socket連線,將回應輸出.
                                                fclose($conf["socket"]);
                                                
                                                #回傳給用戶 - end
                        
                                                #回傳結果
                                                return $result;
                        
                                                }#if end
                                
                                        }#if end
                        
                                }#if end
                
                        }#if end
                        
                #執行到這邊代表沒有資料
                
                #函式說明:
                #查尋有使用 server 函式提供組態設定檔的服務,取得key的value.
                #回傳結果:
                #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前執行的函數名稱.
                #$result["rawContent"],得到的原始訊息.
                #$result["content"],用json_decode後的結果.
                #必填參數:
                #$conf["server"],字串,組態服務設定服務的網址
                $conf["config::client"]["server"]=$conf["request"]["server"];
                #$conf["postName"],字串,POST變數的名稱,亦即要查尋的定義名稱.
                $conf["config::client"]["postName"]=$conf["request"]["postName"];
                #$conf["fileArgu"],字串,變數__FILE__的內容.
                $conf["config::client"]["fileArgu"]=__FILE__;
                #可省略參數:
                #$conf["cache"],字串,預設為"true",代表會啟用cache服務;反之為"false".
                $conf["config::client"]["cache"]="false";
                #$conf["clientCacheDaemonSock"],字串,提供cache服務的 unix domain socket 檔案位置,預設為套件根目錄底下的"var/config::client/clientCacheDaemon.sock";.
                #$conf["clientCacheDaemonSock"]="";
                #參考資料:
                #無.
                #備註:
                #目前僅能跟server函式提供的服務對接.
                $client=config::client($conf["config::client"]);
                unset($conf["config::client"]);
        
                #debug
                #var_dump(__LINE__,$client);
        
                /*
        
                #debug
                #函式說明:
                #撰寫log
                #回傳結果:
                #$result["status"],狀態,"true"或"false".
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前函式的名稱.
                #$result["argu"],使用的參數.
                #$result["content"],要寫入log的內容字串.
                #必填參數:
                #$conf["path"],字串,log檔案的路徑與名稱.
                $conf["config::record"]["path"]="/tmp/test.log";
                #$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
                $conf["config::record"]["content"]=$client;
                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                $conf["config::record"]["fileArgu"]=__FILE__;
                #可省略參數:
                #$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
                #$conf["rewrite"]="false";
                #$conf["returnOnly"],預設為"false",會寫入到log檔案.若為"true"則不會寫入log.
                #$conf["returnOnly"]="true";
                #參考資料:
                #無.
                #備註:
                #無.
                config::record($conf["config::record"]);
                unset($conf["config::record"]);
                
                */
        
                #如果執行失敗
                if($client["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$client;
                        
                        #回傳給用戶 - start
                                        
                        #寫入回應的內容
                        fwrite($conf["socket"],json_encode($result).PHP_EOL);
                
                        #結束回應
                        fwrite($conf["socket"],PHP_EOL.PHP_EOL);
                
                        #關閉socket連線,將回應輸出.
                        fclose($conf["socket"]);
                        
                        #回傳給用戶 - end
                        
                        #回傳結果
                        return $result;
                
                        }#if end

                #新增 client cache 內容
                $conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["content"]=$client["rawContent"];

                #更新 client cache 的最後更新時間
                $conf["clientCache"]["share"]["configs"][$conf["request"]["server"]][$conf["request"]["postName"]]["time"]=time();

                #debug
                #var_dump(__LINE__,$conf["clientCache"]["share"]["configs"]);

                #初始化要傳遞的訊息
                $msg=array();

                #設置 msg content
                $msg["content"]=$client["rawContent"];
                
                #設置 msg status
                $msg["status"]="true";
                
                #設置執行正常
                $result["status"]="true";

                #回傳給用戶 - start
                
                #寫入回應的內容
                fwrite($conf["socket"],json_encode($msg).PHP_EOL);
        
                #結束回應
                fwrite($conf["socket"],PHP_EOL.PHP_EOL);
        
                #關閉socket連線,將回應輸出.
                fclose($conf["socket"]);
                
                #回傳給用戶 - end

                #回傳結果
                return $result;
        
                }#function addOnProcessFuncForClientCacheDaemon end
        
        /*
        #函式說明:
        #給clientCacheDaemon用的funcToRunWhenIdle,處理來自config::client產生的cache內容,若過期就更新,若跟cache檔案不同就更新檔案,若有cache檔案但尚未cache住就cache之.
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #$result["warning"],警告訊息陣列.
        #必填參數:
        #$conf["client"],陣列,用戶的socket.
        #$conf["client"]=array();
        #$conf["info"],陣列,sock跟cache file path資訊.
        #$conf["info"]=array();
        #$conf["info"]["sock"],字串,unix domain socket addr.
        #$conf["info"]["sock"]=;
        #$conf["info"]["cacheFilePath"],字串,cache file path.
        #$conf["info"]["cacheFilePath"]=;
        #$conf["info"]["checkVersionInterval"],字串,距離最後一次取得資料的時間多久就要檢查是否有新資料,預設為60秒.
        #$conf["info"]["checkVersionInterval"]="60";
        #$conf["serverCache"],陣列.存放跟取得快取的陣列.
        #$conf["serverCache"]=array();
        #可省略參數:
        #無.
        #參考資料:
        #無.
        #備註:
        #無,
        */
        public static function funcToRunWhenIdleForClientCacheDaemon(&$conf){
        
                $result=array();

                #取得當前執行的函數名稱
                $result["function"]=__FUNCTION__;

                #取得參數
                $result["argu"]=$conf;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){

                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if(is_null($conf)){

                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";

                                }#if end

                        #回傳結果
                        return $result;

                        }#if end
        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("client","info","serverCache");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("array","array","array");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                #$conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                $conf["variableCheck::checkArguments"]["canNotBeEmpty"]=array("info");
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                #$conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","request");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("resource","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
        
                #debug
                #var_dump(__LINE__,$conf);
        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf["info"];
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableName"]=array("sock","cacheFilePath","checkVersionInterval");
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                $conf["variableCheck::checkArguments"]["mustBeFilledVariableType"]=array("string","string","string");
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                $conf["variableCheck::checkArguments"]["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                #$conf["variableCheck::checkArguments"]["canNotBeEmpty"]=array("sock");
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                #$conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                #$conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","request");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                #$conf["variableCheck::checkArguments"]["skipableVariableType"]=array("resource","array");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                #$conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
        
                #另存 cacheFilePath
                $cacheFilePath=$conf["info"]["cacheFilePath"];
        
                #另存 checkVersionInterval
                $checkVersionInterval=$conf["info"]["checkVersionInterval"];
        
                #檢查之前執行的 config:client - start
        
                #如果有儲存之前執行的 config:client
                if(isset($conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"])){
                
                        #針對每個 proc 
                        foreach($conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"] as $index => $porc){
                        
                                #如果程序已經結束
                                if($porc["proc_get_status"]["running"]===false){
                                
                                        #如果程序正常結束
                                        if($porc["proc_get_status"]["exitcode"]===0){
                                        
                                                #取得輸出
                                                $clientConfigRes=stream_get_contents($porc["content"]);
                                        
                                                #set json string content
                                                $conf["serverCache"]["clientSide"]["share"]["configs"][$porc["server"]][$proc["postName"]]["content"]=$clientConfigRes;
                                                                                        
                                                }#if end
                                
                                        #移除之
                                        unset($conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"][$index]);
                                
                                        }#if end
                                 
                                #反之
                                else {
                                
                                        #更新 proc_get_status
                                        $conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"][$index]["proc_get_status"]=proc_get_status($porc["process"]);
                                
                                        }#else end
                        
                                }#foreach end
                
                        #儲存 procs 的元素數量
                        $procsCount=count($conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"]);
                
                        #如果有proc尚未結束
                        if($procsCount>0){
                        
                                #提示之
                                echo "尚有 ".$procsCount." 個取得 config 的程序執行中".PHP_EOL;
                                
                                #設置執行正常
                                $result["status"]="true";
                                
                                #回傳結果
                                return $result;
                        
                                }#if end
                        
                        }#if end
        
                #檢查之前執行的 config:client - end
        
                #檢查有每個 cache 檔案,若沒有對應的 clientCache,則 cache 之. - start
                
                #函式說明:
                #取得目錄底下的詳細資訊.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],錯誤訊息.
                #$result["function"],當前執行的函數名稱.
                #$result["size"],該清單的大小,單位為bytes.
                #$result["dataCount"],該清單的長度.
                #$result["content"],指定目錄底下的所有檔案資訊.
                #$result["content"][$i]["nType&permission"],第$i個節點類型、權限.
                #$result["content"][$i]["nType"],第$i個節點類型.
                #$result["content"][$i]["permission"],第$i個節點權限.
                #$result["content"][$i]["ownByUser"],第$i個節點擁有者賬號.
                #$result["content"][$i]["ownByGroup"],第$i個節點擁有者群組.
                #$result["content"][$i]["bytes"],第$i個節點大小.
                #$result["content"][$i]["date"],第$i個節點最後變更日期.
                #$result["content"][$i]["time"],第$i個節點最後異動時間.
                #$result["content"][$i]["timeDetail"],第$i個節點最後異動詳細時間.
                #$result["content"][$i]["timezone"],第$i個節點的時區.
                #$result["content"][$i]["name"],第$i個節點的名稱.
                #必填參數:
                #$conf["path"],字串,要檢視的路徑.
                $conf["fileAccess::ls"]["path"]=$cacheFilePath;
                #可省略參數:
                #無.
                #參考資料:
                #https://www.businessweekly.com.tw/careers/Blog/14307
                #備註:
                #清單要不包含 "."開頭 跟 "~" 開頭
                $ls=fileAccess::ls($conf["fileAccess::ls"]);
                unset($conf["fileAccess::ls"]);
                
                #如果執行失敗
                if($ls["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$ls;
                        
                        #debug
                        var_dump(__LINE__,$result);
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #針對每個節點
                foreach($ls["content"] as $nodeInfo){
                
                        #檔案名稱
                        #$nodeInfo["name"]
                
                        #已經chche後的檔案陣列
                        #$conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["cachedFile"]
                
                        #如果沒有已經cache的項目
                        if(!isset($conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"])){
                        
                                #初始化之
                                $conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["cachedFile"]=array();
                        
                                }#if end
                
                        #函式說明:
                        #檢查一個數值是否與陣列裏面的元素相同,找到一個相符合的元素後就會停止搜尋.
                        #回傳結果:
                        #$result["status"],"true"表示執行正確,"false"表示執行錯誤.
                        #$result["founded"],"true"表示有找到相同的,"false"表示沒有找到相同的.
                        #$result["error"],錯誤訊息
                        #$result["function"],當前執行的函數名稱
                        #$result["argv"],使用的參數
                        #$result["equalVarName"],相等的變數名稱或key.
                        #$result["equalVarValue"],相等的變數數值內容.
                        #必填參數:
                        #$conf["conditionElement"],字串,條件元素,要等於的元素內容.
                        $conf["search::getEqualVar"]["conditionElement"]=$nodeInfo["name"];
                        #$conf["compareElements"],字串陣列,要比對的陣列變數內容.
                        $conf["search::getEqualVar"]["compareElements"]=$conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["cachedFile"];
                        #可省略參數:
                        #無.
                        #參考資料:
                        #無.
                        #備註:
                        #無.
                        $getEqualVar=search::getEqualVar($conf["search::getEqualVar"]);
                        unset($conf["search::getEqualVar"]);
                        
                        #debug
                        #var_dump(__LINE__,$getEqualVar);
                        
                        #如果執行失敗
                        if($getEqualVar["status"]==="false"){
                        
                                #設置錯誤識別
                                $result["status"]="false";
                                
                                #設置錯誤訊息
                                $result["error"]=$getEqualVar;
                                
                                #debug
                                var_dump(__LINE__,$result);
                                
                                #回傳結果
                                return $result;
                        
                                }#if end
                        
                        #如果已經cache過
                        if($getEqualVar["founded"]==="true"){
                        
                                #換下個檔案
                                continue;
                        
                                }#if end
                        
                        #debug
                        #var_dump(__LINE__,$getEqualVar);
                        
                        #如果是檔案
                        if($nodeInfo["nType"]==="-"){
                        
                                #debug
                                #var_dump(__LINE__,"檢測尚未cache的檔案",$nodeInfo);
                                                
                                #判斷是否為cache檔案,範例:"client::config-cache-".urlencode($conf["request"]["postName"])." from ".urlencode($conf["request"]["server"]).".json";
                                #函式說明:
                                #檢查字串是否符合指定格式
                                #回傳結果:
                                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                #$result["passed"],檢查是否通過,"true"代表通過,"false"代表不通過.
                                #$result["content"],詳細結果訊息陣列,若passed為"false"則會有該內容.
                                #$result["newInputArgu"],剩下尚未檢驗格式的input.
                                #$result["function"],當前執行的函數.
                                #$result["error"],涵式錯誤訊息陣列.
                                #必填參數:
                                #$conf["input"],字串,要檢查格式的字串.
                                $conf["variableCheck::checkStringFormat"]["input"]=$nodeInfo["name"];
                                #可省略參數:
                                #$conf["equalWith"],字串,輸入字串是否等於該參數內容.
                                #$conf["variableCheck::checkStringFormat"]["equalWith"]=".json";
                                #$conf["startWith"],字串,開頭要是什麼字串內容.
                                $conf["variableCheck::checkStringFormat"]["startWith"]="client::config-cache-";
                                #$conf["endWith"],字串,結尾要是什麼字串內容.
                                $conf["variableCheck::checkStringFormat"]["endWith"]=".json";
                                #$conf["centerWith"],字串,非開頭(預設無,若有指定startWith參數,則為該參數內容)跟結尾(預設無,若有指定endWith參數,則為該參數內容)的內容中要有什麼字串.
                                $conf["variableCheck::checkStringFormat"]["centerWith"]=" from https";
                                #$conf["length"],字串整數,字串的長度要多少(bytes).
                                #$conf["length"]="";
                                #$conf["lengthGrapheme"],字串整數,字串的長度要多少字位(grapheme).
                                #$conf["lengthGrapheme"]="";
                                #$conf["section"],字串陣列,元素數量代表,輸入字串的格式可以區分成多少段.每個元素為本函式的參數陣列剔除input跟section參數.
                                #$conf["section"]=array();
                                #參考資料:
                                #grapheme_strlen=>https://www.php.net/manual/en/function.grapheme-strlen.php
                                #grapheme/字位/可以書寫的最小單位=>https://zh.wikipedia.org/zh-tw/%E5%AD%97%E4%BD%8D
                                #grapheme_substr=>https://www.php.net/manual/en/function.grapheme-substr.php
                                #備註:
                                #無.
                                $checkStringFormat=variableCheck::checkStringFormat($conf["variableCheck::checkStringFormat"]);
                                unset($conf["variableCheck::checkStringFormat"]);
                        
                                #debug
                                #var_dump(__LINE__,$checkStringFormat);
                        
                                #如果執行失敗
                                if($checkStringFormat["status"]==="false"){
                                
                                        #設置錯誤識別
                                        $result["status"]="false";
                                        
                                        #設置錯誤訊息
                                        $result["error"]=$checkStringFormat;
                                        
                                        #debug
                                        var_dump(__LINE__,$result);
                                        
                                        #回傳結果
                                        return $result;
                                
                                        }#if end
                                        
                                #如果是符合的暫存檔案
                                if($checkStringFormat["passed"]==="true"){
                                
                                        #解析對應的 postName 與 server - start
                                        
                                        #函式說明:
                                        #將字串特定關鍵字與其前面的內容剔除
                                        #回傳結果:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列.
                                        #$result["warning"],警告訊息鎮列.
                                        #$result["founded"],有無找到定字串"true"代表有,"false"代表沒有.
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["argu"],使用的參數.
                                        #$result["oriStr"],要處理的原始字串內容.
                                        #$result["content"],處理好的的字串內容.        
                                        #必填參數:
                                        #$conf["stringIn"],字串,要處理的字串.
                                        $conf["stringProcess::delStrBeforeKeyWord"]["stringIn"]=$nodeInfo["name"];
                                        #$conf["keyWord"],字串,特定字串.
                                        $conf["stringProcess::delStrBeforeKeyWord"]["keyWord"]="client::config-cache-";
                                        #可省略參數:
                                        #$conf["recursive"],字串,預設為"false"代表找到一個關鍵字就會停止;"true"代表會即重複執行,知道沒有關鍵字為止.
                                        #$conf["recursive"]="true";
                                        #$conf["lastResult"],陣列,本函式前次執行的結果,若沒有找到關鍵字,則回改回傳該內容.
                                        #$conf["lastResult"]=$delStrBeforeKeyWord;
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #無.
                                        $delStrBeforeKeyWord=stringProcess::delStrBeforeKeyWord($conf["stringProcess::delStrBeforeKeyWord"]);
                                        unset($conf["stringProcess::delStrBeforeKeyWord"]);
                                        
                                        #如果執行失敗
                                        if($delStrBeforeKeyWord["status"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrBeforeKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #如果沒有關鍵字
                                        if($delStrBeforeKeyWord["founded"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrBeforeKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #函式說明:
                                        #將字串特定關鍵字與其後面的內容剔除
                                        #回傳結果:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列.
                                        #$result["warning"],警告訊息鎮列.
                                        #$result["founded"],有無找到定字串"true"代表有,"false"代表沒有.
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["oriStr"],要處理的原始字串內容.
                                        #$result["content"],處理好的的字串內容.
                                        #$result["argu"],使用的參數.
                                        #必填參數:
                                        #$conf["stringIn"],字串,要處理的字串.
                                        $conf["stringProcess::delStrAfterKeyWord"]["stringIn"]=$delStrBeforeKeyWord["content"];
                                        #$conf["keyWord"],字串,特定字串.
                                        $conf["stringProcess::delStrAfterKeyWord"]["keyWord"]=".json";
                                        #可省略參數:
                                        #$conf["deleteLastRepeatedOne"],字串,預設為"false";若為"true"則代表連續遇到同 $conf["keyWord"] 的內容,要將移除內容的起點往後移動到為後一個 $conf["keyWord"].
                                        $conf["stringProcess::delStrAfterKeyWord"]["deleteLastRepeatedOne"]="true";
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #無.
                                        $delStrAfterKeyWord=stringProcess::delStrAfterKeyWord($conf["stringProcess::delStrAfterKeyWord"]);
                                        unset($conf["stringProcess::delStrAfterKeyWord"]);
                                        
                                        #如果執行失敗
                                        if($delStrAfterKeyWord["status"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrAfterKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                                
                                        #如果沒有關鍵字
                                        if($delStrAfterKeyWord["founded"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrAfterKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #另存postName與server的字串
                                        $postNameAndServerStr=$delStrAfterKeyWord["content"];
                                        
                                        #用 " from " 來切割
                                        #函式說明:
                                        #將固定格式的字串分開,並回傳分開的結果.
                                        #回傳結果:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["argu"],使用的參數.
                                        #$result["oriStr"],要分割的原始字串內容
                                        #$result["dataArray"],爲分割好字串的陣列內容,$result["dataArray"][$i]爲第($i+1)段的內容。
                                        #$result["dataCounts"],爲總共分成幾段
                                        #$result["found"],是否有在$conf["stringIn"]找到$conf["spiltSymbol"],"true"代表有找到,"false"代表沒有找到.
                                        #必填參數:
                                        #$conf["stringIn"],字串,要處理的字串.
                                        $conf["stringProcess::spiltString"]["stringIn"]=$postNameAndServerStr;
                                        #$conf["spiltSymbol"],字串,爲以哪個符號作爲分割.
                                        $conf["stringProcess::spiltString"]["spiltSymbol"]=" from ";
                                        #可省略參數:
                                        #$conf["allowEmptyStr"],是否允許分割出來空字串,預設為"false"不允許;"true"代表允許.
                                        $conf["stringProcess::spiltString"]["allowEmptyStr"]="false";
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #無.
                                        $spiltString=stringProcess::spiltString($conf["stringProcess::spiltString"]);
                                        unset($conf["stringProcess::spiltString"]);
                                        
                                        #如果執行失敗
                                        if($spiltString["status"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #debug
                                                var_dump(__LINE__,$resutl);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                                
                                        #如果沒有應該要存在的關鍵字
                                        if($spiltString["found"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #如果沒有切割出2兩段以上
                                        if($spiltString["dataCounts"]<2){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$spiltString;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #取得解析好的來源(urlencoded)
                                        $server=$spiltString["dataArray"][$spiltString["dataCounts"]-1];
                                        
                                        #函式說明:
                                        #將字串特定關鍵字與其後面的內容剔除
                                        #回傳結果:
                                        #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                                        #$result["error"],錯誤訊息陣列.
                                        #$result["warning"],警告訊息鎮列.
                                        #$result["founded"],有無找到定字串"true"代表有,"false"代表沒有.
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["oriStr"],要處理的原始字串內容.
                                        #$result["content"],處理好的的字串內容.
                                        #$result["argu"],使用的參數.
                                        #必填參數:
                                        #$conf["stringIn"],字串,要處理的字串.
                                        $conf["stringProcess::delStrAfterKeyWord"]["stringIn"]=$postNameAndServerStr;
                                        #$conf["keyWord"],字串,特定字串.
                                        $conf["stringProcess::delStrAfterKeyWord"]["keyWord"]=" from ".$server;
                                        #可省略參數:
                                        #$conf["deleteLastRepeatedOne"],字串,預設為"false";若為"true"則代表連續遇到同 $conf["keyWord"] 的內容,要將移除內容的起點往後移動到為後一個 $conf["keyWord"].
                                        $conf["stringProcess::delStrAfterKeyWord"]["deleteLastRepeatedOne"]="true";
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #無.
                                        $delStrAfterKeyWord=stringProcess::delStrAfterKeyWord($conf["stringProcess::delStrAfterKeyWord"]);
                                        unset($conf["stringProcess::delStrAfterKeyWord"]);
                                        
                                        #如果執行失敗
                                        if($delStrAfterKeyWord["status"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrAfterKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                                
                                        #如果沒有關鍵字
                                        if($delStrAfterKeyWord["founded"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$delStrAfterKeyWord;
                                                
                                                #debug
                                                var_dump(__LINE__,$resutl);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                        
                                        #另存postName與server的字串
                                        $postName=$delStrAfterKeyWord["content"];
                                        
                                        #解析對應的 postName 與 server - end
                                        
                                        #如果對應該cache檔案的cache不存在
                                        if(!isset($conf["serverCache"]["clientSide"]["share"]["configs"][urldecode($server)][$postName])){
                                        
                                                #讀取其json
                                                #函式說明:
                                                #依據行號分隔抓取檔案的內容,結果會回傳一個陣列
                                                #回傳的變數說明:
                                                #$result["status"],執行是否成功,"true"代表成功;"fasle"代表失敗.
                                                #$result["error"],錯誤訊息提示.
                                                #$result["warning"],警告訊息.
                                                #$result["function"],當前執行的函數名稱.
                                                #$result["fileContent"],爲檔案的內容陣列.
                                                #$result["lineCount"],爲檔案內容總共的行數.
                                                #$result["fullContent"],為檔案的完整內容.
                                                #$result["base64data"],為檔案的base64內容.
                                                #$result["mimeType"],為檔案的mime type.
                                                #必填參數:
                                                #$conf["filePositionAndName"],字串,爲檔案的位置以及名稱.
                                                $conf["fileAccess::getFileContent"]["filePositionAndName"]=$cacheFilePath.$nodeInfo["name"];
                                                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                                $conf["fileAccess::getFileContent"]["fileArgu"]=__FILE__;
                                                #可省略參數:
                                                #$conf["web"],是要取得網路上的檔案則為"true";反之預設為"false".
                                                $conf["fileAccess::getFileContent"]["web"]="false";
                                                #$conf["createIfnotExist"],字串,預設為"false"代表檔案不存在也不需要建立;反之為"true".
                                                $conf["fileAccess::getFileContent"]["createIfnotExist"]="false";
                                                #參考資料:
                                                #file(),取得檔案內容的行數.
                                                #file=>http:#php.net/manual/en/function.file.php
                                                #rtrim(),剔除透過file()取得每行內容結尾的換行符號.
                                                #filesize=>http://php.net/manual/en/function.filesize.php
                                                #參考資料:
                                                #無.
                                                #備註:
                                                #無.
                                                $getFileContent=fileAccess::getFileContent($conf["fileAccess::getFileContent"]);
                                                unset($conf["fileAccess::getFileContent"]);
                                        
                                                #如果執行失敗
                                                if($getFileContent["status"]==="false"){
                                                
                                                        #設置錯誤識別
                                                        $result["status"]="false";
                                                        
                                                        #設置錯誤訊息
                                                        $result["error"]=$getFileContent;
                                                        
                                                        #debug
                                                        var_dump(__LINE__,$result);
                                                        
                                                        #回傳結果
                                                        return $result;
                                                
                                                        }#if end

                                                #debug
                                                #var_dump(__LINE__,$getFileContent);

                                                #set json string content
                                                $conf["serverCache"]["clientSide"]["share"]["configs"][urldecode($server)][$postName]["content"]=$getFileContent["fullContent"];
                                                
                                                #設置已經有 cache 成檔案
                                                $conf["serverCache"]["clientSide"]["share"]["configs"][urldecode($server)][$postName]["cachedFile"]="true";
                                                
                                                #set cached file
                                                $conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["cachedFile"][]=$nodeInfo["name"];
                                                
                                                #debug
                                                #var_dump(__LINE__,$conf["serverCache"]);
                                                
                                                }#if end
                                
                                        }#if end
                        
                                }#if end
                
                        }#foreach end
                
                #檢查有每個 cache 檔案,若沒有對應的 clientCache,則cache 之. - end
                
                #檢查每個 clientCache 若過期則更新之. - start
                
                #如果沒有 $conf["serverCache"]["clientSide"]["share"]
                if(!isset($conf["serverCache"]["clientSide"]["share"])){
                
                        #初始化之
                        $conf["serverCache"]["clientSide"]["share"]["configs"]=array();
                
                        }#if end
                
                #針對每個 client site 的 share configs 變數
                foreach($conf["serverCache"]["clientSide"]["share"]["configs"] as $serverUrl => $postNames){
                
                        #針對該site每個config資訊
                        foreach($postNames as $configName => $configVal){
                
                                #如果沒有最後更新時間
                                if(!isset($postNames["time"])){
                                
                                        #設置最後更新時間
                                        $conf["serverCache"]["clientSide"]["share"]["configs"][$serverUrl][$configName]["time"]=time();
                                
                                        #換下一個 postName
                                        continue;
                                
                                        }#if end
                
                                #如果過期了
                                if( time()-$postNames["time"]>$checkVersionInterval ){
                                
                                        #嘗試從網路取得config
                                        #函式說明:
                                        #查尋有使用 server 函式提供組態設定檔的服務,取得key的value.
                                        #回傳結果:
                                        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
                                        #$result["error"],錯誤訊息陣列.
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["rawContent"],得到的原始訊息.
                                        #$result["content"],用json_decode後的結果;若"inBg"為"true",則其每個元素為其指令執行的結果訊息陣列,key為"status"代表執行是否正常的識別;key為"statusCode"代表程式結束後回傳給對應executeBy程式的數值;key為"output"代表標準輸出,若為resource,則代表為pipe;key為"error"代表非標準輸出,若為resource,則代表為pipe;key為"input"代表成功輸入的指令;key為"process"代表該程序經proc_open後的process source;key為"proc_get_status"代表程序的資訊.
                                        #必填參數:
                                        #$conf["server"],字串,組態服務設定服務的網址
                                        $conf["config::client"]["server"]=$serverUrl;
                                        #$conf["postName"],字串,POST變數的名稱,亦即要查尋的定義名稱.
                                        $conf["config::client"]["postName"]=$configName;
                                        #$conf["fileArgu"],字串,變數__FILE__的內容.
                                        $conf["config::client"]["fileArgu"]=__FILE__;
                                        #可省略參數:
                                        #$conf["cache"],字串,預設為"true",代表會啟用cache服務;反之為"false".
                                        $conf["config::client"]["cache"]="false";
                                        #$conf["clientCacheDaemonSock"],字串,提供cache服務的 unix domain socket 檔案位置,預設為套件根目錄底下的"var/config::client/clientCacheDaemon.sock";.
                                        #$conf["clientCacheDaemonSock"]="";
                                        #$conf["inBg"],字串,預設為"false",代表在前景執行;反之為"true"代表在背景中執行,會強制將"cache"參數設為"false".
                                        $conf["config::client"]["inBg"]="true";
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #目前僅能跟server函式提供的服務對接.
                                        $client=config::client($conf["config::client"]);
                                        unset($conf["config::client"]);
                                        
                                        #若從網路取得成功
                                        if($client["status"]==="true"){
                                                
                                                #另存來源
                                                $client["content"]["server"]=$serverUrl;
                                                
                                                #另存 configName
                                                $client["content"]["postName"]=$configName;
                                                
                                                #儲存起來下次再看跑完沒
                                                $conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["procs"][]=$client["content"];
                                                
                                                #換處理下個 configName
                                                continue;
                                        
                                                }#if end        
                                                
                                        #執行到這邊代表從網路取得失敗
                                        
                                        #將事件記錄起來
                                        var_dump(__FILE__,__LINE__,$client);
                                
                                        }#if end
                
                                }#foreach end
        
                        }#foreach end
                
                #檢查每個 clientCache 若過期則更新之. - end
                
                #檢查每個 clientCache 若無對應 cache file 則產生之. - start
                
                #針對每個 client site 的 share configs 變數
                foreach($conf["serverCache"]["clientSide"]["share"]["configs"] as $serverUrl => $postNames){
                
                        #針對該site每個postName資訊
                        foreach($postNames as $configName => $configVal){
                        
                                #expected cache file name
                                #$cacheFilePath."client::config-cache-".$configName." from ".$serverUrl.".json";
                                
                                #realistic cache file name
                                #$cacheFilePath."client::config-cache-".urlencode($configName)." from ".urlencode($serverUrl).".json";
                                
                                #函式說明:
                                #檢查多個檔案與資料夾是否存在.
                                #回傳的結果:
                                #$result["status"],執行正常與否,"true"代表正常,"false"代表不正常.
                                #$result["error"],錯誤訊息陣列.
                                #$resutl["function"],當前執行的涵式名稱.
                                #$result["argu"],使用的參數.
                                #$result["allExist"],所有檔案皆存在的識別,"true"代表皆存在,"false"代表沒有全部都存在.
                                #$result["varName"][$i],爲第$i個資料夾或檔案的路徑與名稱。
                                #$result["varNameFullPath"][$i],爲第$i個資料夾或檔案的完整檔案系統路徑與名稱,如果不存在則代表路徑是網址.
                                #$result["varNameWebPath"][$i],為第$i個資料夾或檔案的網址,若"web"參數為"true",才會有該內容.
                                #$result["varExist"][$i],爲第$i個資料夾或檔案是否存在,"true"代表存在,"false"代表不存在。
                                #必填參數:
                                #$conf["fileArray"],陣列字串,要檢查是否存在的檔案有哪些,須爲一維陣列數值。
                                $conf["fileAccess::checkMultiFileExist"]["fileArray"]=array($cacheFilePath."client::config-cache-".urlencode($configName)." from ".urlencode($serverUrl).".json");
                                #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                $conf["fileAccess::checkMultiFileExist"]["fileArgu"]=__FILE__;
                                #可省略參數:
                                #$conf["disableWebSearch"],"字串",是否取消「當檔案找不到時,改用catchWebContent類別的wget函數來檢查檔案是否存在於網路上」的功能,"false"不取消,若要取消該功能請設為"true",若抓到的內容為空字串則會視為檔案不存在,預設為"true".
                                $conf["fileAccess::checkMultiFileExist"]["disableWebSearch"]="true";
                                #$conf["userDir"],字串,網頁是否置放於家目錄底下,"true"為是,"false"為不是,預設為"true".
                                $conf["fileAccess::checkMultiFileExist"]["userDir"]="false";
                                #$conf["web"],字串,檔案是放在web就是"true",反之為檔案系統"false",預設為"true".
                                $conf["fileAccess::checkMultiFileExist"]["web"]="false";
                                #參考資料:
                                #http://php.net/manual/en/function.file-exists.php
                                #http://php.net/manual/en/control-structures.foreach.php
                                #備註:
                                #函數file_exists檢查的路徑為檔案系統的路徑
                                #$result["varName"][$i]結果未實作
                                $checkMultiFileExist=fileAccess::checkMultiFileExist($conf["fileAccess::checkMultiFileExist"]);
                                unset($conf["fileAccess::checkMultiFileExist"]);
                        
                                #如果執行失敗
                                if($checkMultiFileExist["status"]==="false"){
                                
                                        #設置錯誤識別
                                        $result["status"]="false";
                                        
                                        #設置錯誤訊息
                                        $result["error"]=$checkMultiFileExist;
                                        
                                        #debug
                                        var_dump(__LINE__,$result);
                                        
                                        #回傳結果
                                        return $result;
                                
                                        }#if end
                        
                                #如果 cache file 不存在
                                if($checkMultiFileExist["allExist"]==="false"){
                                
                                        #函式說明:
                                        #將字串寫入到檔案
                                        #回傳結果:
                                        #$result["status"],"true"表示檔案寫入成功,"false"表示檔案寫入失敗.
                                        #$result["error"],錯誤訊息陣列.
                                        #$result["function"],當前執行的函數名稱.
                                        #$result["fileInfo"],實際上寫入的檔案資訊陣列.
                                        #$result["fileInfo"]["createdFileName"],建立好的檔案名稱.
                                        #$result["fileInfo"]["createdFilePath"],檔案建立的路徑.
                                        #$result["fileInfo"]["createdFilePathAndName"].建立好的檔案名稱與路徑.
                                        #$result["argu"],使用的參數.
                                        #必填參數:
                                        #$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
                                        $conf["fileAccess::writeTextIntoFile"]["fileArgu"]=__FILE__;
                                        #可省略參數:
                                        #$conf["fileName"],字串,爲要編輯的檔案名稱,預設為隨機產生的檔案名稱.
                                        $conf["fileAccess::writeTextIntoFile"]["fileName"]=$cacheFilePath."client::config-cache-".urlencode($configName)." from ".urlencode($serverUrl).".json";
                                        #$conf["inputString"],字串,爲要寫入到裏面的內容,若要每筆資料寫入後換行,則可以在字串內容後面加上 \r\n 即可,預設為"".
                                        $conf["fileAccess::writeTextIntoFile"]["inputString"]=$conf["serverCache"]["clientSide"]["share"]["configs"][$serverUrl][$configName]["content"];
                                        #$conf["writeMethod"],字串,爲檔案撰寫的方式,可省略,是複寫'a'還是,重新寫入'w',預設爲'w',重新寫入.
                                        #$conf["writeMethod"]="a";
                                        #$conf["checkRepeat"],字串,"true"代表建立檔案之前要先檢查檔案是否存在,若存在則在原名稱後面加上從(1)開始的編號.
                                        #$conf["checkRepeat"]="";
                                        #$conf["filenameExtensionStartPoint"],字串,檔案的副檔名是從倒數第幾個小數點(dot)開始,預設為"1",最後一個小數點,必須與$conf["checkRepeat"]搭配才會生效.
                                        #$conf["filenameExtensionStartPoint"]="";
                                        #$conf["repeatNameRule"],字串,遇到相同名稱的檔案要如何加上識別的編號,編號用「\$i」表示,預設為"(\$i)",必須與$conf["checkRepeat"]搭配才會生效.
                                        #$conf["repeatNameRule"]="";
                                        #$conf["web"],檔案是否位於網站上"true",若是在檔案系統則為"false",預設為"true".
                                        $conf["fileAccess::writeTextIntoFile"]["web"]="false";
                                        #參考資料:
                                        #無.
                                        #備註:
                                        #無.
                                        $writeTextIntoFile=fileAccess::writeTextIntoFile($conf["fileAccess::writeTextIntoFile"]);
                                        unset($conf["fileAccess::writeTextIntoFile"]);
                                
                                        #如果執行失敗
                                        if($writeTextIntoFile["status"]==="false"){
                                        
                                                #設置錯誤識別
                                                $result["status"]="false";
                                                
                                                #設置錯誤訊息
                                                $result["error"]=$writeTextIntoFile;
                                                
                                                #debug
                                                var_dump(__LINE__,$result);
                                                
                                                #回傳結果
                                                return $result;
                                        
                                                }#if end
                                                
                                        #設置已經有 cache 成檔案
                                        $conf["serverCache"]["clientSide"]["share"]["configs"][$serverUrl][$configName]["cachedFile"]="true";
                                                
                                        #set cached file
                                        $conf["serverCache"]["serverSide"]["config::funcToRunWhenIdleForClientCacheDaemon"]["cachedFile"][]="client::config-cache-".urlencode($configName)." from ".urlencode($serverUrl).".json";
                                
                                        }#if end
                        
                                }#foreach end
                                
                        }#foreach end
        
                #檢查每個 clientCache 若無對應 cache file 則產生之. - end
                
                #設置執行正常
                $result["status"]="true";
                
                #回傳結果
                return $result;
        
                }#function funcToRunWhenIdleForClientCacheDaemon end
        
        /*
        #函式說明:
        #處理來自config::client有使用cache的要求,其為常駐的unix domain socket
        #回傳結果:
        #$result["status"],執行是否正常,"true"為正常,"false"為不正常.
        #$result["error"],錯誤訊息陣列.
        #$result["function"],當前執行的函數名稱.
        #必填參數:
        #無.
        #可省略參數:
        #$conf["sock"],字串,unix doamin socket的位置,預設為套件根目錄底下的"var/config::client/clientCacheDaemon.sock".
        #$conf["sock"]="";
        #$conf["cacheFilePath"],字串,cache的檔案位置,預設為套件根目錄底下的"var/config::client/",
        #$conf["cacheFilePath"]="";
        #$conf["checkVersionInterval"],字串,距離最後一次取得資料的時間多久就要檢查是否有新資料,預設為60秒.
        #$conf["checkVersionInterval"]="60";
        #參考資料:
        #無.
        #備註:
        #無,
        */
        public static function clientCacheDaemon(&$conf){
         
                #初始化要回傳的結果
                $result=array();

                #取得當前執行的函數名稱
                $result["function"]=__FUNCTION__;

                #取得參數
                $result["argu"]=$conf;

                #如果 $conf 不為陣列
                if(gettype($conf)!="array"){

                        #設置執行失敗
                        $result["status"]="false";

                        #設置執行錯誤訊息
                        $result["error"][]="\$conf變數須為陣列形態";

                        #如果傳入的參數為 null
                        if(is_null($conf)){

                                #設置執行錯誤訊息
                                $result["error"][]="\$conf變數不得為null,請檢查函數「".$result["function"]."」的參數設置有無正確!";

                                }#if end

                        #回傳結果
                        return $result;

                        }#if end
        
                #函式說明:
                #檢查必填與可省略的參數,可省略參數可指定預設要給與什麼數值內容.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
                #$result["error"],執行不正常結束的錯訊息陣列.
                #$result["simpleError"],簡單表示的錯誤訊息.
                #$result["function"],當前執行的函式名稱.
                #$result["argu"],設置給予的參數.
                #$result["passed"],識別要檢查的全體變數是否存在以及型態是否正確的變數,"true"代表檢查全部通過;"false"代表檢查不通過
                #$result[$shouldBeCheckedVarName]["varExist"],所檢查的變數是否存在,"false"代表不存在;"true"代表存在
                #$result[$shouldBeCheckedVarName]["varType"],所檢查的變數型態是否正確,"false"代表錯誤;"true"代表正確
                #$result[$shouldBeCheckedVarName]["error"],每個參數設定的錯誤訊息
                #$result["shouldNotBeEmpty"],不應該為空字串或控陣列的變數.
                #$result["argu"],字串陣列,目前輸入的參數名稱陣列.
                #$result["legalVarName"],字串陣列,合法可用的參數名稱陣列.
                #$result["notNeedVar"],字串陣列,多餘的參數名稱.
                #必填參數:
                #$conf["varInput"],陣列變數,要檢查的陣列變數,請在要檢查的參數前面加上&,這樣變動的結果才能被套用。
                $conf["variableCheck::checkArguments"]["varInput"]=&$conf;
                #$conf["referenceVarKey"],字串,$conf參數後面的key值,用於移除不要的參考陣列.
                $conf["variableCheck::checkArguments"]["referenceVarKey"]="variableCheck::checkArguments";
                #可省略參數:
                #$conf["mustBeFilledVariableName"],爲必填參數的變數名稱陣列,形態爲陣列變數,元素數量需要跟"mustBeFilledVariableType"參數的元素數量一致,例如: $conf["mustBeFilledVariableName"] = array("id","account","password");
                #$conf["mustBeFilledVariableName"]=array();
                #$conf["mustBeFilledVariableType"],爲必填參數的變數陣列應該爲何種變數形態,形態爲陣列,元素數量需要跟"mustBeFilledVariableName"參數的元素數量一致,例如: $conf["mustBeFilledVariableType"] = array("string",integer,"double","resource","object"); , null代表不指定變數形態.
                #$conf["mustBeFilledVariableType"]=array();
                #$conf["canBeEmptyString"],字串,必填變數內容如果是空字串就不能算是有設置的話,請設為"false",預設爲"true",可以為空字串.
                #$conf["canBeEmptyString"]="false";
                #$conf["canNotBeEmpty"],字串陣列,哪些必填參數的內容不得為空字串或空陣列,僅當$conf["canBeEmptyString"]為"true"時會生效.
                #$conf["canNotBeEmpty"]=array();
                #$conf["canBeEmpty"],字串陣列,哪些必填參數的內容可為空字串或空陣列,僅當$conf["canBeEmptyString"]為"false"時會生效.
                #$conf["canBeEmpty"]=array();
                #$conf["skipableVariableCanNotBeEmpty"],字串陣列,哪些可省略參數不可以為空字串或空陣列.
                $conf["variableCheck::checkArguments"]["skipableVariableCanNotBeEmpty"]=array("sock","cacheFilePath","checkVersionInterval");
                #$conf["skipableVariableName"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableName"] = array("id","account","password");
                $conf["variableCheck::checkArguments"]["skipableVariableName"]=array("sock","cacheFilePath","checkVersionInterval");
                #$conf["skipableVariableType"],陣列字串,爲可省略參數的變數名稱陣列,形態爲陣列變數,例如: $conf["skipableVariableType"] = array("string",integer,"double");
                $conf["variableCheck::checkArguments"]["skipableVariableType"]=array("string","string","string");
                #$conf["skipableVarDefaultValue"],字串陣列,每個不存在的可省略變數要初始化為什麼,null與代表不指定,若預設值是參數之一,請將$conf["mustBeFilledVar"]改成"\$conf["\mustBeFilledVar\"]".
                $conf["variableCheck::checkArguments"]["skipableVarDefaultValue"]=array(null,null,"60");
                #$conf["disallowAllSkipableVarIsEmpty"],字串,是否允許每個可省略參數都為空字串,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmpty"]="";
                #$conf["disallowAllSkipableVarIsEmptyArray"],字串,是否允許每個可省略參數都為空陣列,預設為"true"允許,反之為"false".
                #$conf["disallowAllSkipableVarIsEmptyArray"]="";
                #$conf["disallowAllSkipableVarNotExist"],字串,是否不允許每個可省略參數都不存在,預設為"false"代表允許,反之為"true".
                #$conf["disallowAllSkipableVarNotExist"]="";
                #$conf["arrayCountEqualCheck"],字串陣列,為檢查哪些陣列參數的元素數量要一樣,$conf["arrayCountEqualCheck"][$i]=array()為第$i組key為哪些的變數其元素數量要相等.
                #$conf["arrayCountEqualCheck"][]=array();
                #參考資料:
                #array_keys=>http://php.net/manual/en/function.array-keys.php
                #備註:
                #無.
                $checkArguments=variableCheck::checkArguments($conf["variableCheck::checkArguments"]);
                unset($conf["variableCheck::checkArguments"]);
        
                #如果執行失敗
                if($checkArguments["status"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                        
                #如果檢查不通過
                if($checkArguments["passed"]==="false"){
                
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$checkArguments;
                        
                        #回傳結果
                        return $result;
                
                        }#if end
                
                #函式說明:
                #取得目前瀏覽的頁面的路徑或執行的php程式路徑.
                #回傳結果:
                #$result["status"],執行是否正常,"true"代表執行成功,"false"代表執行失敗.
                #$result["error"],錯誤訊息.
                #$result["function"],檔前執行的函數名稱.
                #$result["content"],目前瀏覽的頁面的路徑或執行的php程式路徑.
                #$result["serverIp"],取得伺服器ip.
                #$result["scheme"],取得與伺服器連線所使用的通訊協定.
                #必填參數:
                $conf["csInformation::getPathOfThisPhpFile"]["type"]="pathOnly";#想要取得的路徑類型,"full"代表完整路徑,"pathOnly"代表只要路徑,"lastLayer"代表上一層目錄的名稱
                #必填參數:
                #無.
                #可省略參數:
                #無.
                #參考資料:
                #http://blog.longwin.com.tw/2009/01/php-get-directory-file-path-dirname-2008/
                #備註:
                #無.
                $getPathOfThisPhpFile=csInformation::getPathOfThisPhpFile($conf["csInformation::getPathOfThisPhpFile"]);
                unset($conf["csInformation::getPathOfThisPhpFile"]);
        
                #如果執行失敗
                if($getPathOfThisPhpFile["status"]=="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$getPathOfThisPhpFile;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
                        
                #如果沒有設定 sock
                if(!isset($conf["sock"])){
                
                        #設置預設的cache檔案名稱
                        $conf["sock"]=$getPathOfThisPhpFile["content"]."var/config::client/clientCacheDaemon.sock";
                        
                        }#if end
                
                #如果 無設置 cacheFilePath
                if(!isset($conf["cacheFilePath"])){
                
                        #設置預設的 cacheFilePath 
                        $conf["cacheFilePath"]=$getPathOfThisPhpFile["content"]."var/config::client/";
                
                        }#if end
                
                #函式說明:
                #建立 unix domain socket server, 僅提供具備檔案存取權限的用戶使用,預設提供可以下達任何指令的功能.
                #回傳結果:
                #$result["status"],"true"代表執行正常;"false"代表執行不正常.
                #$result["error"],錯誤訊息陣列.
                #$result["function"],當前執行的函式名稱.
                #$result["serverCache"],函式結束前,儲存在serverCache的內容,若有元素"exit"存在則代表是正常結束.
                #必填參數:
                #$conf["sock"],字串,socket檔案要放在哪邊,名稱為何.
                $conf["sock::unixDomainSockServer"]["sock"]=$conf["sock"];
                #$conf["fileArgu"],字串,變數__FILE__的內容.
                $conf["sock::unixDomainSockServer"]["fileArgu"]=__FILE__;
                #可省略參數:
                #$conf["changeOwner"],字串,要將socket檔案的擁有着權限進行修改."user.group"代表擁有者帳號為user,群組為group.
                #$conf["sock::unixDomainSockServer"]["changeOwner"]="root.root";
                #$conf["changePermission"],字串,要將socket檔案的權限設為多少.ex: "0666"(所有帳戶都有存取的權限) 或 "0660"(僅有擁有者與群組帳戶有存取的權限) 或 "0600"(只有擁有者有權限執行).
                #$conf["sock::unixDomainSockServer"]["changePermission"]="0666";
                #$conf["sessionTimeout"],字串,當連線結束後於下一次連線間隔多久就算session timeout,server端會將記錄移除,client端需要重新拿取id,預設為300秒.
                #$conf["sessionTimeout"]="300";
                #$conf["addOnProcessFunc"],字串陣列,增加用於處理 json request 的函式名稱,給予的參數為array("request"=>收到的json訊息,"sock"=>用戶的socket),若收到的不是json而是"quit"則代表用戶要結束連線;若收到的是$shutdownStr則代表要結束本函式.回傳的內容必須為陣列,例如 $res["continue"]="true"代表要繼續執行下一個addOnProcessFunc;"false"代表代表到此為止. $res["content"]="replaced content";代表要將收到的訊息取代成"replaced content". 最少要有回傳 $res["status"]數值"true"代表執行正常;"false"代表執行不正常.
                $conf["sock::unixDomainSockServer"]["addOnProcessFunc"]=array("\qbpwcf\\config::addOnProcessFuncForClientCacheDaemon");
                #$conf["funcToRunWhenIdle"],字串陣列,當沒有事件產生時,要執行的函式名稱,給予參數為array("client"=>所有用戶,"clientCache"=>$result["serverCache"]["clientSide"]["addOnProcessFunc"][$funcToRunWhenIdle],"serverCache"=>$result["serverCache"]["serverSide"]["funcToRunWhenIdle"][$funcToRunWhenIdle]).
                $conf["sock::unixDomainSockServer"]["funcToRunWhenIdle"]=array("\qbpwcf\\config::funcToRunWhenIdleForClientCacheDaemon");
                #$conf["paramsForFuncToRunWhenIdle"],2維陣列,每個元素代表指定給予funcToRunWhenIdle參數中的指定元素的參數.
                #$conf["paramsForFuncToRunWhenIdle"]=array();
                #$conf["infoToFunction"],陣列,需要增加給addOnProcessFunc跟funcToRunWhenIdle函式的資訊,在函式中其參數的info鍵值.
                $conf["sock::unixDomainSockServer"]["infoToFunction"]=array("sock"=>$conf["sock"],"cacheFilePath"=>$conf["cacheFilePath"],"checkVersionInterval"=>$conf["checkVersionInterval"]);
                #$conf["shutdownStrAddr"],字串,儲存收到用戶傳什麼樣的字串會結束本函式的檔案位置與名稱,預設為 $conf["sock"].".shutdown".
                #$conf["shutdownStrAddr"]="";
                #參考資料:
                #http://php.net/manual/en/function.stream-socket-server.php
                #備註:
                #無.
                $unixDomainSockServer=sock::unixDomainSockServer($conf["sock::unixDomainSockServer"]);
                unset($conf["sock::unixDomainSockServer"]);
                
                #如果執行失敗
                if($unixDomainSockServer["status"]==="false"){
                        
                        #設置錯誤識別
                        $result["status"]="false";
                        
                        #設置錯誤訊息
                        $result["error"]=$unixDomainSockServer;
                        
                        #回傳結果
                        return $result;
                        
                        }#if end
        
                }#function clientCacheDaemon end
        
        }#class config end

?>