Bulgaria PHP Conference


(PHP 4, PHP 5)

ftp_connectFTP 接続をオープンする


resource ftp_connect ( string $host [, int $port = 21 [, int $timeout = 90 ]] )

ftp_connect() は、指定した host への FTP 接続をオープンします。



FTP サーバーのアドレス。このパラメータには、最後のスラッシュや最初の ftp:// をつけてはいけません。


このパラメータは接続先のポートを指定します。もし指定しなかったり ゼロを指定したりした場合は、デフォルトの FTP ポートである 21 が用いられます。


このパラメータは、以降のネットワーク操作時のタイムアウトを指定します。 指定されなかった場合のデフォルト値は 90 秒です。タイムアウトの変更や 参照は、ftp_set_option()ftp_get_option() を用いていつでも可能です。


成功した場合に FTP ストリームを、エラー時に FALSE を返します。

例1 ftp_connect() の例



// 接続を確立します。できなければ終了します。
$conn_id ftp_connect($ftp_server) or die("Couldn't connect to $ftp_server"); 



add a note add a note

User Contributed Notes 2 notes

sean at boyercentral dot net
5 years ago
Ever needed to create an FTP connection resource defaulted to a particular dir from a URI? Here's a simple function that will take a URI like ftp://username:password@subdomain.example.com/path1/path2/, and return an FTP connection resource.

function getFtpConnection($uri)
// Split FTP URI into:
    // $match[0] = ftp://username:password@sld.domain.tld/path1/path2/
    // $match[1] = ftp://
    // $match[2] = username
    // $match[3] = password
    // $match[4] = sld.domain.tld
    // $match[5] = /path1/path2/
preg_match("/ftp:\/\/(.*?):(.*?)@(.*?)(\/.*)/i", $uri, $match);

// Set up a connection
$conn = ftp_connect($match[1] . $match[4] . $match[5]);

// Login
if (ftp_login($conn, $match[2], $match[3]))
// Change the dir
ftp_chdir($conn, $match[5]);

// Return the resource
return $conn;

// Or retun null
return null;
rainer at justchords dot com
11 years ago
Connecting through a firewall also depends on the type. This is an example for the Secure Gateway FTP. First you have to connect to the firewall, then open a session to the destination ftp server. This looks like this:

// Connect to firewall
$conn_id = ftp_connect("firewall.yournet.com");

// Open a session to an external ftp site
$login_result = ftp_login ($conn_id, "userid@externalhost.com", "password");

// Check open
if ((!$conn_id) || (!$login_result)) {
        echo "Ftp-connect failed!"; die;
    } else {
        echo "Connected.";

// turn on passive mode transfers
ftp_pasv ($conn_id, true) ;

... and go on ...
To Top