PHPerKaigi 2025

ftp_ssl_connect

(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)

ftp_ssl_connect打开安全 SSL-FTP 连接

说明

ftp_ssl_connect(string $hostname, int $port = 21, int $timeout = 90): FTP\Connection|false

ftp_ssl_connect() 打开到指定 hostname显式 SSL-FTP 连接。即使服务器没有为 SSL-FTP 配置,或者服务器的证书无效,ftp_ssl_connect() 也会成功。只有调用 ftp_login() 时,客户端才会发送对应的 AUTH FTP 命令,因此在上述情况下 ftp_login() 会失败。

注意: 为何本函数有可能不存在?

在 PHP 7.0 之前,只有 ftp 模块和 OpenSSL 模块都静态编译到 PHP 时,ftp_ssl_connect() 才可用;也就是说,在 Windows 平台上,此函数在官方 PHP 编译中未定义。如果需要在 Windows 平台使用本函数,需要自行编译 PHP 二进制文件。

注意:

ftp_ssl_connect() 不是用来连接 sFTP 服务的。 要在 PHP 中使用 sFTP,请参见 ssh2_sftp()

参数

hostname

FTP 服务器地址。 此参数末尾不可以有斜线,开头也不可以有 ftp://

port

要连接的端口。如果省略此参数或设置为 0,将使用 FTP 默认端口 21。

timeout

此参数设置所有后续网络操作的超时时长。 如果省略,默认值为 90 秒。 可以使用 ftp_set_option()ftp_get_option() 函数随时读取或设置超时时长。

返回值

成功时返回 FTP\Connection 实例, 或者在失败时返回 false

更新日志

版本 说明
8.1.0 现在返回 FTP\Connection 实例;之前返回 resource

示例

示例 #1 ftp_ssl_connect() 函数示例

<?php

// 建立基础 SSL 连接
$ftp = ftp_ssl_connect($ftp_server);

// 使用用户名和密码登录
$login_result = ftp_login($ftp, $ftp_user_name, $ftp_user_pass);

if (!
$login_result) {
// 在这种情况下,PHP 会发生 E_WARNING 级别的告警消息
die("can't login");
}

echo
ftp_pwd($ftp); // /

// 关闭 ssl 连接
ftp_close($ftp);
?>

参见

添加备注

用户贡献的备注

此页面尚无用户贡献的备注。
To Top