|
使用curl將某個頁面下載到本地時,需要將下載到的臨時文件tmpHtml.txt的內容讀取到一個緩沖區中。由于我使用fread()進行讀取,需要傳入要讀取的大小,所以先用filesize(‘./tmpHtml.txt')獲取臨時文件大小。怪異的是,獲取到的臨時文件大小不正確,下斷點調試,在filesize()調用后,手工去硬盤上尋找文件,文件大小與filesize()得到的結果不一樣。
在php.NET上搜索filesize,可以看到函數說明中有這么一句:Note: 此函數的結果會被緩存。參見 clearstatcache() 以獲得更多細節。
再去查閱clearstatcache(),果然找到了原因:
php將緩存這些(提供了函數表供查詢)函數的返回信息以提供更快的性能。然而在某些情況下,你可能想清除被緩存的信息。例如如果在一個腳本中多次檢查同一個文件,而該文件在此腳本執行期間有被刪除或修改的危險時,你需要清除文件狀態緩存。這種情況下,可以用 clearstatcache() 函數來清除被 php 緩存的該文件信息。
2,在UTF-8編碼的php腳本中,對GBK編碼的中文網頁內容做模式匹配時,如何匹配中文。
在昨天的開發中,需要匹配包含GBK編碼字符串‘蘋果'的內容,所以寫出如下代碼:
復制代碼 代碼如下:
$pat = '/<img onclick="zoom/(this, /'(attachments.*?)/'/)".*?alt="蘋果/.jpg" //><//a>/';
$pat = iconv(‘UTF-8', ‘GB2312', $pat);
$ret = preg_match_all($pat, $contents, $matches);
可是死活匹配不上,于是嘗試先將內容轉換成UTF-8編碼,如下:
復制代碼 代碼如下:
$pat = '/<img onclick="zoom/(this, /'(attachments.*?)/'/)".*?alt="蘋果/.jpg" //><//a>/';
$contenst = iconv(‘GB2312', ‘UTF-8', $contents);
$ret = preg_match_all($pat, $contents, $matches);
于是就能匹配上了。但是想不通啊,懷疑這里面有詐。
但悲劇的是,今天又用了第一種方法,又匹配中了。看來問題出在別的地方。
啊!老夫是豬,問題2是由問題1引起的!filesize()獲取的不對,自然匹配不上了!第二種方法匹配上,是在解決問題1之后啊!
3,瀏覽器中審查元素得到的報價圖片下載地址,為何與curl得到的下載地址不同。
可能……最后答案依然是:我是豬。
因為URI對象為:attachment.php?aid=Mzk3MTB8YTg5ZTYyNTJ8MTMyNjcyNDEwMXw5NWYydC9aOUE0a05EVm9ydlErSFBRamZJNWJQL1NHdWJLK3ZraU9GTDZYdnBUdw%3D%3D¬humb=yes
aid是個什么呢?很可能是個與session有關的東東,變一變也很正常的嘛。后來抓看起來像靜態路徑的東東就沒問題了。
以上三個故事中包含兩個悲劇,這就是php初學者必犯的低級錯誤。
php技術:調試一段PHP程序時遇到的三個問題,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。