php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #69990 file_get_contents broken on symlinks
Submitted: 2015-07-03 18:01 UTC Modified: -
Votes:6
Avg. Score:5.0 ± 0.0
Reproduced:5 of 6 (83.3%)
Same Version:1 (20.0%)
Same OS:3 (60.0%)
From: michael dot mckeever at bosch dot com Assigned:
Status: Open Package: *Directory/Filesystem functions
PHP Version: Irrelevant OS: Windows 7
Private report: No CVE-ID: None
Have you experienced this issue?
Rate the importance of this bug to you:

 [2015-07-03 18:01 UTC] michael dot mckeever at bosch dot com
Description:
------------
I used:
- php 5.5.26 ts 32bit VC11 as SAPI
- apache 2.4.12 32bit VC11
- windows 7 sp1
On Windows 7 (have only tested it on Windows 7) the file_get_contents function does sometimes return false instead of returning the actual file content when used on symlinks. This happens only in conjunction with Apache. The cli versions are not affected. All types of links are affected:
- mklink
- mklink /J
- mklink /D

To repoduce the bug create the three symlink types above to a file of your choice containing the string "asdf" and apply the paths to your the test script below and use the abs.exe command (shipped with apache) to simulate 800 request with a concurency of 200 users:
abs.exe -n 800 -c 200 http://localhost/yourTestScript.php

If needed I can provide a fully virtual machine with the whole reproducable scenario in it (virtual box).

Test script:
---------------
$files =
[
	"file" => "C:/Development/phpdir/phpfile.txt",
	"filelink" => "C:/Development/phpdir/phpfilelink.txt",
	"dirlink" => "C:/Development/phpdirlink/phpfile.txt",
	"dirjunc" => "C:/Development/phpdirjunc/phpfile.txt",
];

foreach($files as $linkType => $filePath) {
	if( @file_get_contents($filePath) !== "asdf" ) {
		if( @file_get_contents("C:/Development/$linkType") === false )
			file_put_contents("C:/Development/$linkType", 0);
		file_put_contents("C:/Development/$linkType", ((int)file_get_contents("C:/Development/$linkType"))+1);
	}
}

Expected result:
----------------
No files should appear in the directory "C:/Development/".

Actual result:
--------------
There are laying three files namely 'filelink', 'dirlink' and 'dirjunc' containing the number of file_get_contents failing to succeed.

Patches

Add a Patch

Pull Requests

Add a Pull Request

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2015-09-02 13:08 UTC] rombismith at cuvox dot de
We're having exactly the same issue, but not on a Win7 but on a WinServer 2008 and WinServer 2008R2.
 
PHP Copyright © 2001-2019 The PHP Group
All rights reserved.
Last updated: Mon Aug 19 12:01:26 2019 UTC