(PECL ssh2 >= 0.10)
ssh2_publickey_add — Añade una clave pública autorizada
$pkey
,$algoname
,$blob
,$overwrite
= false
,$attributes
= ?Nota: El subsistema de clave pública es utilizado para administrar claves públicas en un servidor al que el cliente ya está autenticado. Para autenticar a un sistema remoto usando autenticación de clave pública, use la función ssh2_auth_pubkey_file() en cambio.
pkey
Recurso Publickey Subsystem creado por ssh2_publickey_init().
algoname
Algoritmo de clave pública (ejemplo): ssh-dss, ssh-rsa
blob
Blob de clave pública como datos binarios sin tratar
overwrite
Si la clave especificada ya existe, ¿debería ser sobrescrita?
attributes
Array asociativo de atributos para asignar a esta clave pública. Consulte ietf-secsh-publickey-subsystem para una lista de los atributos soportados. Para marcar un atributo como obligatorio, anteponga un asterisco a su nombre. Si el servidor no es capaz de soportar un atributo marcado como obligatorio, abandonará el proceso de adición.
Ejemplo #1 Adición de una clave pública con ssh2_publickey_add()
<?php
$ssh2 = ssh2_connect('shell.example.com', 22);
ssh2_auth_password($ssh2, 'jdoe', 'password');
$pkey = ssh2_publickey_init($ssh2);
$keyblob = base64_decode('
AAAAB3NzaC1yc2EAAAABIwAAAIEA5HVt6VqSGd5PTrLRdjNONxXH1tVFGn0
Bd26BF0aCP9qyJRlvdJ3j4WBeX4ZmrveGrjMgkseSYc4xZ26sDHwfL351xj
zaLpipu\BGRrw17mWVBhuCExo476ri5tQFzbTc54VEHYckxQ16CjSTibI5X
69GmnYC9PNqEYq/1TP+HF10=');
ssh2_publickey_add($pkey, 'ssh-rsa', $keyblob, false, array('comment'=>"John's Key"));
?>