ID:               42096
 Comment by:       thinktank2002 at netcologne dot de
 Reported By:      michael202 at gmx dot de
 Status:           Open
 Bug Type:         Streams related
 Operating System: Windows only
 PHP Version:      5.2.3
 New Comment:

I can confirm this behavior. Tested with PHP 5.2.0 on Windows XP. And
the bug appears not only when using is_dir, it appears also using
is_file.

To make it clear: both functions are working well. But they produce
network errors. 

I used this code:

$path = '\\\\Ralf\\postbox\\Public\\xy\\';
if ( is_dir( $path ) ) {
echo 'found';
}

You can see it well using wireshark. Extract:

Tree Connect AndX Request, Path: \\RALF\IPC$
Tree Connect AndX Response

Tree Connect AndX Request, Path: \\RALF\POSTBO
Tree Connect AndX Response, Error: STATUS_BAD_NETWORK_NAME

Trans2 Request, QUERY_PATH_INFO, Query File Basic Info, Path: 
Trans2 Response, QUERY_PATH_INFO

Trans2 Request, FIND_FIRST2, Pattern: \Public
Trans2 Response, FIND_FIRST2, Files: Public

Trans2 Request, QUERY_PATH_INFO, Query File Basic Info, Path: \Public
Trans2 Response, QUERY_PATH_INFO

and so on...


Previous Comments:
------------------------------------------------------------------------

[2007-07-25 14:43:22] michael202 at gmx dot de

tested with php5.2-win32-latest.zip
from today morning 2007-07-25 08h08

error is still in there

------------------------------------------------------------------------

[2007-07-25 11:56:38] [EMAIL PROTECTED]

Please try using this CVS snapshot:

  http://snaps.php.net/php5.2-latest.tar.gz
 
For Windows (zip):
 
  http://snaps.php.net/win32/php5.2-win32-latest.zip

For Windows (installer):

  http://snaps.php.net/win32/php5.2-win32-installer-latest.msi

Some fixes regarding this and other issue alike where fixed recently.

------------------------------------------------------------------------

[2007-07-25 08:48:13] michael202 at gmx dot de

Description:
------------
calling is_dir() with an UNC path truncates each part of the path. The
last character is missing.

This results in unnecessary errors (on the host side) and slowdowns (on
client side).


Reproduce code:
---------------
windows only (php 5.2.3, Windows XP with cmd.exe) and linux host.

<?php
$p = '\\hostA\volumeB\dirC';
echo(is_dir($p) . "\n");

and then trace network IO for service/port SMB.

Beware of posssible side effects though caching of SMB connections

Expected result:
----------------
no error messages in /var/log/messages on 'hostA'

Actual result:
--------------
I traced these SMB Commands sent over the network:

Connect AndX Request \\hostA\IPC$
Connect AndX Request \\hostA\volume -> STATUS_BAD_NETWORK_NAME
FindFirst2, Pattern: \dir

these are in /var/log/messages in 'hostA'
  ... smbd/service.c:make_connection(252)
  ... couldn't find service volume




I think this is another problem with tsrm_virtual_cwd.c where around
line 500 state_cwd_length is set to 2 if a slash is found at the
beginning. Perhaps the existence of UNC paths is not checked for.



------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=42096&edit=1

Reply via email to