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.)
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 を返します。
例
Example#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_id, true);
// ファイルをアップロードする
if (ftp_put($conn_id, $remote_file, $file, FTP_ASCII)) {
echo "successfully uploaded $file\n";
} else {
echo "There was a problem while uploading $file\n";
}
// 接続を閉じる
ftp_close($conn_id);
?>
ftp_pasv
ybourbeau at edison dot ca
09-Apr-2002 07:28
09-Apr-2002 07:28
04-Apr-2002 09:19
PASV: For ftp users behind firewall, the server LISTEN for a connection.
Non-PASV: The client LISTEN for a connection from server.