downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

ftp_put> <ftp_nlist
[edit] Last updated: Fri, 10 Feb 2012

view this page in

ftp_pasv

(PHP 4, PHP 5)

ftp_pasvパッシブモードをオンまたはオフにする

説明

bool ftp_pasv ( resource $ftp_stream , bool $pasv )

ftp_pasv() はパッシブモードをオンまたはオフにします。 パッシブモードでは、データ接続はサーバではなくクライアントにより 初期化されます。クライアントがファイアウォールの向こうにある場合に 必要となるでしょう。

ftp_pasv() をコールできるのは、 ログインに成功した後だけであることに注意しましょう。 それ以外の場合は、この関数のコールは失敗します。

パラメータ

ftp_stream

FTP 接続のリンク ID 。

pasv

TRUE, の場合はパッシブモードをオンに、そうでない場合はオフにします。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。

例1 ftp_pasv() の例

<?php
$file 
'somefile.txt';
$remote_file 'readme.txt';

// 接続を確立する
$conn_id ftp_connect($ftp_server);

// ユーザ名とパスワードでログインする
$login_result ftp_login($conn_id$ftp_user_name$ftp_user_pass);

// パッシブモードをオンにする
ftp_pasv($conn_idtrue);

// ファイルをアップロードする
if (ftp_put($conn_id$remote_file$fileFTP_ASCII)) {
 echo 
"successfully uploaded $file\n";
} else {
 echo 
"There was a problem while uploading $file\n";
}

// 接続を閉じる
ftp_close($conn_id);
?>



ftp_put> <ftp_nlist
[edit] Last updated: Fri, 10 Feb 2012
 
add a note add a note User Contributed Notes ftp_pasv
mac at codegreene dot com 09-Jul-2010 03:20
I found one place that required passive mode to function properly, but the initial error manifested itself in an odd way:

PHP Warning:  ftp_put(): TYPE is now ASCII in <file.php> on line <#>

or

PHP Warning:  ftp_put(): TYPE is now 8 BIT BINARY in <file.php> on line <#>

The other symptom is that it was taking a long time, perhaps the 90 seconds that the timeout was set to. No errors occurred upon connect, just when I tried ftp_put().

Once I turned on ftp_pasv() it worked, both in the place where active mode worked, and on the server where active mode wouldn't work.
Anonymous 04-Sep-2009 10:45
If you find that you are receiving "Illegal PORT command" errors you may want to try enabling passive mode.
ybourbeau at edison dot ca 08-Apr-2002 03:28
Directly from bsd FTP manual pages:

The PASV command requests that the remote server open a port for the data connection and return the address of that port.  The remote server listens on that port and the client connects to it.

                 When using the more traditional PORT command, the client listens on a port and sends that address to the remote server, who connects back to it.  Passive mode is useful when using ftp through a gateway router or host that controls the directionality of traffic.  (Note that though ftp servers are required to support the PASV command by RFC 1123, some do not.)
03-Apr-2002 04:19
PASV: For ftp users behind firewall, the server LISTEN for a connection.

Non-PASV: The client LISTEN for a connection from server.

 
show source | credits | stats | sitemap | contact | advertising | mirror sites