ssh2://

ssh2://安全外壳协议 2

说明

ssh2.shell://ssh2.exec://ssh2.tunnel://ssh2.sftp://ssh2.scp:// (PECL)

注意: 该封装器默认没有激活
为了使用 ssh2.*:// 封装协议,必须从 » PECL 中安装有效的 » SSH2 扩展。

除了支持传统的 URI 登录信息,ssh2 封装协议也支持通过 URL 的主机(host)部分来复用打开连接。

用法

  • ssh2.shell://user:pass@example.com:22/xterm
  • ssh2.exec://user:pass@example.com:22/usr/local/bin/somecmd
  • ssh2.tunnel://user:pass@example.com:22/192.168.0.1:14
  • ssh2.sftp://user:pass@example.com:22/path/to/filename

可选项

封装协议概要
属性ssh2.shellssh2.execssh2.tunnelssh2.sftpssh2.scp
allow_url_fopen 影响YesYesYesYesYes
允许读取YesYesYesYesYes
允许写入YesYesYesYesNo
允许追加NoNoNoYes(当服务器支持的时候)No
允许同时读和写YesYesYesYesNo
支持 stat()NoNoNoYesNo
支持 unlink()NoNoNoYesNo
支持 rename()NoNoNoYesNo
支持 mkdir()NoNoNoYesNo
支持 rmdir()NoNoNoYesNo

上下文选项(Context)
名称用法默认
session重复使用预连接的 ssh2 资源 
sftp重复使用预先分配的 sftp 资源 
methods密钥交换(key exchange)、主机密钥(hostkey)、cipher、压缩和 MAC 方法 
callbacks  
username以该用户名连接 
password使用的密码来进行密码验证 
pubkey_file用于验证的公钥(public key)文件 
privkey_file用于验证的私钥(private key)文件 
env需要设置的环境变量的关联数组 
term在分配一个 pty 时请求的终端类型 
term_width在分配一个 pty 时请求的终端宽度 
term_height在分配一个 pty 时请求的终端宽度高度 
term_unitsterm_width 和 term_height 的单位SSH2_TERM_UNIT_CHARS

示例

示例 #1 从一个活跃的连接中打开流

<?php
$session
= ssh2_connect('example.com', 22);
ssh2_auth_pubkey_file($session, 'username', '/home/username/.ssh/id_rsa.pub',
'/home/username/.ssh/id_rsa', 'secret');
$stream = fopen("ssh2.tunnel://$session/remote.example.com:1234", 'r');
?>

示例 #2 $session 变量必须保持可用!

为了使用 ssh2.*://$session 封装协议, 必须保留 $session 资源变量。下面的代码就不会有预期的效果:

<?php
$session
= ssh2_connect('example.com', 22);
ssh2_auth_pubkey_file($session, 'username', '/home/username/.ssh/id_rsa.pub',
'/home/username/.ssh/id_rsa', 'secret');
$connection_string = "ssh2.sftp://$session/";
unset(
$session);
$stream = fopen($connection_string . "path/to/file", 'r');
?>

unset() 会关闭 session,因为 $connection_string 不保存对 $session 变量的引用,只是源自它的字符串转换。当离开(像函数)作用域隐性调用 unset() 时,也会发生这种情况。

To Top