銆嬬浉淇″ぇ瀹堕兘鏈夎繃杩欐牱鐨勭粡鍘嗭紝鏃犺寮€鍙戦樁娈靛涔堜弗璋紝浠g爜涓婄嚎杩愯杩囩▼涓毦鍏嶄細鍑虹幇涓嶅彲鎺х殑閿欒鎴栧紓甯革紝瀵艰嚧椤甸潰鏄剧ず娌℃湁杈惧埌棰勬湡鐨勬晥鏋滐紝鎵€浠ュ姝ょ被鎯呭喌杩涜鍚堢悊鐨勫鐞嗭紝涓嶄粎鍙互鎻愰珮绯荤粺鐨勫仴澹€э紝杩樺彲浠ュ府鍔╂垜浠揩閫熷畾浣嶉棶棰樸€備粈涔堟槸閿欒锛熶竴鑸槸PHP绋嬪簭鏈韩鐨勯棶棰橀潪娉曡娉曞拰鐜闂瀵艰嚧鐨凱HP閿欒閰嶇疆鍏ㄥ眬閰嶇疆淇敼鍦╬hp.ini鏂囦欢涓紝淇敼鍚庨噸鍚痯hp鏈嶅姟鐢熸晥error_reporting=E_ALL//鏄剧ず鎵€鏈夐敊璇痙isplay_errors=Off//鍏抽棴errorpromptlog_errors=On//鍚敤閿欒鏃ュ織log_errors_max_len=1024//璁剧疆鏃ュ織鐨勬渶澶ч暱搴rror_log=/error.log//閿欒鏃ュ織鏂囦欢鐨勪綅缃甧rror_reporting璁剧疆閿欒鎶ュ憡鐨勭骇鍒€傝鍙傛暟鍙互鏄〃绀轰簩杩涘埗浣嶅煙鐨勪换鎰忔暣鏁帮紝涔熷彲浠ユ槸甯搁噺鍚嶃€傞敊璇骇鍒拰甯搁噺鍦ㄩ瀹氫箟甯搁噺涓畾涔夈€傜▼搴忚繍琛屾椂锛屼篃鍙互閫氳繃error_reporting()鍑芥暟杩涜璁剧疆銆傚父瑙佺骇鍒弿杩癋atalError锛氳嚧鍛介敊璇紙缁堟杩愯锛塒arseError锛氱紪璇戞椂瑙f瀽閿欒锛岃娉曢敊璇紙缁堟杩愯锛塛arningError锛氳鍛婇敊璇紙鏈夋彁绀轰俊鎭紝涓嶄細缁堟杩愯锛塏oticeError锛氶€氱煡閿欒锛堜細鏈夐€氱煡淇℃伅锛屼笉浼氱粓姝㈣繍琛岋級";print_r($aDataParam);exit;returnfalse;},E_ALL);test();//Fatalerror:UncaughtError:Calltoundefinedfunctiontest()echo$a+1;/**Array([errno]=>8[errstr]=>鏈畾涔夌殑鍙橀噺锛歛[errfile]=>/opt/homebrew/var/www/php/error/index.php[errline]=>126)*/鏋佸害鑷笅鑰屼笂鐨勫鐞唕egister_shutdown_function闄勶細瀹樻柟鏂囨。鎴虫垜鐨剆et_error_handler鎹曡幏浜嗗ぇ閮ㄥ垎缁忓父閬囧埌鐨勯敊璇紝鑰屾湭鎹曡幏鐨勮緭鍏ユ槸涓ラ噸閿欒锛堝叾瀹炶繖閮ㄥ垎濡傛灉鑳芥彁鍒扮敓浜х幆澧冪殑璇濓紝灏卞緱鑷繁鍙嶇渷浜嗮煇讹級register_shutdown_function(function(){$error=error_get_last();if($error){//璁板綍鏃ュ織锛岄偖浠舵彁閱拀});test();娉ㄦ剰锛歅HP鑴氭湰鎵ц鏃跺彲浠ュ崟鐙缃紝浼樺厛绾ч珮浜巔hp.iniini_set('display_errors',1);鐨勯厤缃?/閰嶇疆鏂囦欢璁剧疆浜嗛敊璇笉鍙锛屽彲瑙佺殑error_reporting(-1)鍙互浣跨敤ini_set鍛戒护璁剧疆锛?/璁剧疆php閿欒绾у埆-1锛岀敤浜庢樉绀烘墍鏈夌骇鍒殑閿欒閿欒鐨勪竴浜涙寚瀵兼柟閽堬紙闈炲師鍒涳級纭繚PHP鎶ュ憡閿欒鍦ㄥ紑鍙戠幆澧冧腑鏄剧ず閿欒鍦ㄧ敓浜х幆澧冧腑鏃犳硶鏄剧ず閿欒鍦ㄥ紑鍙戝拰鐢熶骇鐜涓兘璁板綍閿欒浠€涔堟槸寮傚父娉涙寚涓€浜涗笉绗﹀悎棰勬湡鐨勪簨鎯咃紝浣嗕笉鏄疨HP璇█寮曡捣鐨勬硶寰嬮€犳垚鐨勯敊璇紱渚嬪锛氭姏鍑洪潪娉曞弬鏁般€丆url璇锋眰銆佽姹傜涓夋柟API绛夊叿浣撲娇鐢╰ry{if('浠栫姱浜嗕竴涓敊璇?){thrownewException('浠栧彂鐜颁簡涓€涓敊璇?,0);}//thrownewException('浠栧彂鐜颁簡涓€涓敊璇?,0);if('鎴戝彂鐜颁簡涓€涓敊璇?){thrownewException('鎴戝彂鐜颁簡涓€涓敊璇?,1);}//thrownewException('浠栧彂鐜颁簡涓€涓敊璇?,0);$result='success';}catch(Exception$exception){$result="閿欒鎻忚堪锛歿$exception->getMessage()}锛岄敊璇唬鐮侊細{$exception->getCode()}".PHP_EOL;}finally{Log::info('logicprocessing',['result'=>$result]);}鍒嗘瀽ExceptionclassExceptionimplementsThrowable{protected$message;//鑷畾涔夊紓甯告彁绀簆rivate$string;//__toString淇℃伅鍙椾繚鎶?code;//鑷畾涔夊紓甯镐唬鐮佷繚鎶?file;//鍙戠敓寮傚父鐨勬枃浠跺悕protected$line;//鍙戠敓寮傚父鐨勪唬鐮佽鍙穚rivate$trace;//鏁扮粍褰㈠紡鐨勫爢鏍堣窡韪猵rivate$previous;//鍦ㄥ叕鍏卞嚱鏁癬_construct($message=null,$code=0,Exception$pprevious=null);//寮傚父鏋勯€犲嚱鏁癴inalprivatefunction__clone()//涓嶅彲澶嶅埗锛屽鏋滃厠闅嗗紓甯哥被浼氱洿鎺ヤ骇鐢熻嚧鍛介敊璇痜inalpublicfunctiongetMessage():string//杩斿洖寮傚父淇℃伅finalpublicfunctiongetCode():int//鍏嬮殕寮傚父finalpublicfunctiongetFile():string//杩斿洖寮傚父鍙戠敓鐨勬枃浠跺悕finalpublicfunctiongetLine():int//杩斿洖寮傚父鍙戠敓鐨勪唬鐮佽鍙穎inalpublicfunctiongetTrace():array//鑾峰彇寮傚父璺熻釜淇℃伅finalpublicfunctiongetPrevious();//涔嬪墠鐨勫紓甯竑inalpublicfunctiongetTraceAsString():string//鑾峰彇瀛楃涓茬被鍨嬬殑寮傚父璺熻釜淇℃伅publicfunction__toString():string//寮傚父瀵硅薄鍙互杞负瀛楃涓瞹鎴戜滑鍙互鐪嬪埌except__construct鍜宊_toString鍙互閲嶅啓閫氳繃鎴戜滑锛屾垜浠笉鑳戒慨鏀瑰叾浠栨柟娉曞拰涓€浜涘睘鎬с€俧inal鍏抽敭瀛楃畝鍗曞洖椤緁inal鍏抽敭瀛楃殑浣滅敤鏄細鐢╢inal淇グ鐨勭被涓嶈兘琚户鎵匡紱鏂规硶涓娇鐢╢inal淇グ鐨勬垚鍛樻柟娉曚笉鑳藉湪瀛愮被涓噸鍐欙紙overridden锛夎嚜瀹氫箟寮傚父//IP闄愬埗绫籧lassIpExceptionextendsException{public$msg;public$code;public$param;publicfunction__construct($message="",$code=0,$param=[]){$this->鍛崇簿=$娑堟伅锛?this->code=$code;$this->param=$param;parent::__construct($this->msg,$this->msg);$this->afterAction();}publicfunction__toString(){return"Illegalrequest:";}//鑷畾涔夊鐞嗛€昏緫publicfunctionafterAction(){if($this->code>=500){Log::ip('閲嶈璁板綍IP',$杩欎釜->鍙傛暟锛夛紱}}}//楠岃瘉绫诲紓甯哥被RuleExceptionextendsException{public$msg;public$code;public$param;publicfunction__construct($message="",$code=0){$this->msg=$message;$this->code=$code;parent::__construct($this->msg,$this->msg);}publicfunction__toString(){return"Illegalrequest:";}}//鏁版嵁鍖呭紓甯革紝褰撴病鏈夊搴旂殑try()catch鎹曡幏鏃讹紝浼氳繘鍏ヨ嚜瀹氫箟澶勭悊鏂规硶set_exception_handler('exception_handler');functionexception_handler($exception){var_dump($exception);}try{if('IPNoRight'){thrownewIpException('ipisrestricted',500,['ip'=>'0.0.0.0']);}if('uidisincorrect'){thrownewRuleException('uidismissing');}}璧朵笂锛圧uleException$ruleException锛墈echo$ruleException銆?ruleException->getMessage();}catch(IpException$ipException){echo$ipException.$ipException->getMessage();}set_exception_handler()璁剧疆榛樿寮傚父澶勭悊绋嬪簭锛屽浜庢湭琚玹ry/catch鍧楁崟鑾风殑寮傚父灏嗗湪璋冪敤exception_handler鍚庝腑姝€傝嚜瀹氫箟寮傚父鍑芥暟锛堥潪鍘熷垱锛夊紑闂師鍒欑紪绋嬫帴鍙o紝渚濊禆鎶借薄鑰屼笉鏄叿浣擄紙姣忎釜缁ф壙Exception鍚庣殑sonException鍙互瀹炵幇鏇村鐨勬寜闇€鍘熷垯锛夊緱澧ㄥ繏灏斿畾寰嬶紙least-knownprinciple锛変竴涓疄浣撳簲璇ュ敖鍙兘灏戝敖鍙兘涓庡叾浠栧疄浣撲氦浜掞紝浣跨郴缁熷姛鑳芥ā鍧楃浉瀵圭嫭绔嬨€俻hp7tipsThrowable缁撳悎涓嬮潰鐨勫眰绾у浘鍙互鏇村ソ鐨勭悊瑙i檮锛氬畼鏂硅В閲婃埑鎴?/php5try{//涓氬姟閿欒}catch(Exception$exception){//鎹曡幏寮傚父閿欒}catch(Error$error){//Catch鍩烘湰閿欒}//>php7try{//涓氬姟閿欒}catch(Throwable$t){//鎹曡幏寮傚父閿欒锛屾崟鑾峰熀鏈敊璇瘆鎬荤粨閫氳繃涓婇潰鐨勪粙缁嶏紝鐩镐俊澶у瀵筆HP閿欒鍜屽紓甯告湁浜嗘洿娣辩殑浜嗚В鍚х悊瑙e畠浠€绘槸鍦ㄦ甯稿紑鍙戜腑浣跨敤锛屼絾涓嶈兘鍏呭垎鍙戞尌鍏舵渶浣虫晥鏋滀篃鏄竴浠朵护浜洪毦杩囩殑浜嬫儏锛涙墍浠ワ紝璧跺揩琛屽姩鍚э紒鍙傝€冩枃妗o細Laravel寮傚父鍒嗘瀽鏂囨。PHP寮傚父涓庨敊璇渶浣冲疄璺礟HP閿欒涓庡紓甯歌瑙o紙PHP7閿欒澶勭悊锛塒HP閿欒涓庡紓甯?/p>
