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
Welcome back! If you're the original bug submitter, here's where you can edit the bug or add additional notes.
If this is not your bug, you can add a comment by following this link.
If this is your bug, but you forgot your password, you can retrieve your password here.
Password:
Status:
Package:
Bug Type:
Summary:
From: michael dot mckeever at bosch dot com
New email:
PHP Version: OS:

 

 [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: Thu Nov 21 10:01:22 2019 UTC