Home  >  Article  >  Backend Development  >  Three problems encountered when debugging a PHP program_PHP Tutorial

Three problems encountered when debugging a PHP program_PHP Tutorial

WBOY
WBOYOriginal
2016-07-21 15:21:22778browse

1, filesize() function returns wrong value.
When using curl to download a page locally, you need to read the contents of the downloaded temporary file tmpHtml.txt into a buffer. Since I use fread() to read, I need to pass in the size to be read, so I first use filesize(‘./tmpHtml.txt’) to get the temporary file size. The weird thing is that the size of the temporary file obtained is incorrect. I set a breakpoint to debug and manually search for the file on the hard disk after calling filesize(). The file size is different from the result obtained by filesize().
Search filesize on php.net, and you can see this sentence in the function description: Note: The results of this function will be cached. See clearstatcache() for more details.
Looking up clearstatcache() again, I found the reason:
PHP will cache the return information of these (function tables are provided for query) functions to provide faster performance. In some cases, however, you may want to clear cached information. For example, if you check the same file multiple times in a script and the file is in danger of being deleted or modified during the execution of the script, you need to clear the file status cache. In this case, you can use the clearstatcache() function to clear the file information cached by PHP.
2. In a UTF-8 encoded PHP script, how to match Chinese when pattern matching GBK encoded Chinese web content.
In yesterday's development, we needed to match content containing the GBK encoded string 'Apple', so we wrote the following code:

Copy code The code is as follows:

$pat = '//';
$pat = iconv('UTF-8', 'GB2312', $pat);
$ret = preg_match_all($pat, $contents, $matches);

But there was no match, so I tried to convert the content into UTF-8 encoding first, as follows:
Copy code The code is as follows :

$pat = '/< /a>/';
$contenst = iconv('GB2312', 'UTF-8', $contents);
$ret = preg_match_all($pat, $contents, $matches);

Then it will be matched. But I can’t figure it out, and I suspect there’s some fraud involved.
But the tragedy is that I used the first method again today and got matched again. It seems the problem lies elsewhere.
Ah! I am a pig, problem 2 is caused by problem 1! The filesize() is obtained incorrectly, so naturally it cannot be matched! The second method is matched after solving problem 1!

3. Why is the download address of the quote image obtained by inspecting the element in the browser different from the download address obtained by curl.
Maybe... the final answer is still: I am a pig.
Because the URI object is: attachment.php? aid=Mzk3MTB8YTg5ZTYyNTJ8MTMyNjcyNDEwMXw5NWYydC9aOUE0a05EVm9ydlErSFBRamZJNWJQL1NHdWJLK3ZraU9GTDZYdnBUdw%3D%3D¬humb=yes
What is aid? It's probably something related to session, and it's normal for it to change. Later, it was no problem to capture something that looked like a static path.

The above three stories contain two tragedies. These are stupid mistakes that PHP beginners must make.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/324920.htmlTechArticle1, the filesize() function returns an incorrect value. When using curl to download a page locally, you need to read the contents of the downloaded temporary file tmpHtml.txt into a buffer. Since I use...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn