顯示所有調(diào)試信息
<pre>error_reporting(E_ALL);
ini_set('display_errors', 1);
</pre>
時(shí)間相關(guān)
<pre>
//unix時(shí)間戳
$time = time();
//轉(zhuǎn)成時(shí)間格式
$date = date('Y-m-d H:i:s', $time);
</pre>
date() 函數(shù)默認(rèn)是使用格林威治時(shí)間,解決時(shí)區(qū)問(wèn)題:
- 在頁(yè)頭使用date_default_timezone_set()設(shè)置我的默認(rèn)時(shí)區(qū)為北京時(shí)間,如
<pre>
date_default_timezone_set('PRC');
echo date('Y-m-d H:i:s');
</pre> - 打開(kāi) php.ini 查找 date.timezone 去掉前面的分號(hào),= 后面加 Asia/Shanghai,重啟 http 服務(wù)(未檢驗(yàn))
查看當(dāng)前運(yùn)行 PHP 的用戶
<pre>
<?php
echo shell_exec("id -a");
</pre>
解決 PHP exec() 執(zhí)行耗時(shí)的 SHELL 命令時(shí)候,導(dǎo)致 ajax 鎖死的問(wèn)題
場(chǎng)景:通過(guò) PHP 調(diào)用 linux shell 命令來(lái)執(zhí)行前端文件打包,整個(gè)過(guò)程需要 30~40 秒,初衷是先發(fā)一個(gè) ajax 請(qǐng)求去啟動(dòng) shell 命令,然后開(kāi)一個(gè) ajax 去輪詢(xún)打包是否結(jié)束。
最初 PHP 是這樣寫(xiě)的:
<pre>$shell = 'sudo sh /var/www/build/build_alpha/buildtool';
exec($shell, $output, $return_var);
</pre>
發(fā)現(xiàn)啟動(dòng) shell 命令的請(qǐng)求,會(huì)一直等 30 多秒,shell 執(zhí)行完之后才響應(yīng),我輪詢(xún)就沒(méi)有用了。一度考慮用 fastcgi_finish_request() 來(lái)解決,無(wú)果。最后的解決方案是,讓 shell 命令在后臺(tái)執(zhí)行,給命令后加上 > /dev/null &
就可以了
<pre>
$shell = 'sudo sh /var/www/build/build_alpha/buildtool > /dev/null &';
exec($shell, $output, $return_var);
</pre>
json_encode() 格式化
這樣就能顯示中文和換行了
<pre>json_encode($arr, JSON_UNESCAPED_UNICODE|JSON_PRETTY_PRINT);</pre>