Core points
- PHP's SSH2 extension (a wrapper for libssh2) provides multiple functions for securely transferring files using protocols such as SCP and SFTP. The SSH2 package is required to be installed to use these functions.
- Authentication can be achieved using username/password or public/private key authentication. Functions
ssh2_auth_password()
andssh2_auth_pubkey_file()
return a boolean value indicating whether authentication is successful. - After successful authentication, you can use the SCP function to perform file transfer operations. The SFTP function provides more features, including changing file or directory permissions, getting information about files, creating directories, renaming projects, and deleting projects.
- This article provides code snippets for creating auxiliary classes to simplify the execution of these commands, including classes for executing SCP calls and SFTP calls, parent classes for common functions, and encapsulating authentication information (passwords) and keys) class.
In today's world, third-party integration and content sharing are very common, so it is crucial to understand and use protocols such as SCP and SFTP. PHP's SSH2 extension (a wrapper for libssh2, implementing the SSH2 protocol) provides multiple functions that can be used to safely transfer files. To get started with these functions, you obviously need to install the SSH2 package. Since it is a PECL extension, the installation process will depend on the operating system you choose. Please follow the guide on php.net.
Create a connection
Let's start by connecting to the SSH service. It's very simple to establish a connection:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_password($conn, 'username', 'password'); ?>
Some administrators prefer to use public and private keys to verify logins. If the service is configured and you want to connect this way, you should use the following method instead:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_pubkey_file( $conn, 'username', '/home/username/.ssh/id_rsa.pub', '/home/username/.ssh/id_rsa' ); ?>
Whether you are using username/password or public/private key authentication, ssh2_auth_password()
and ssh2_auth_pubkey_file()
return a Boolean value indicating whether the authentication is successful.
Execute basic commands
After successfully verifying the server identity, you can perform file transfer operations. The SCP function allows you to send or receive files like this:
<?php // 发送文件 ssh2_scp_send($conn, '/local/filename', '/remote/filename', 0644); // 获取文件 ssh2_scp_recv($conn, '/remote/filename', '/local/filename'); ?>
ssh2_scp_send()
There is also an additional parameter that you can specify file permissions when copying files to the remote server. The SFTP function provides more functions; you can change file or directory permissions, get information about files, create directories, rename projects, delete projects, and more. They work very similarly to the SCP functions above, but before using these functions, additional connections must be made via ssh2_sftp()
:
<?php $sftp = ssh2_sftp($conn); // 创建一个新文件夹 ssh2_sftp_mkdir($sftp, '/home/username/newdir'); // 重命名文件夹 ssh2_sftp_rename($sftp, '/home/username/newdir', '/home/username/newnamedir'); // 删除新文件夹 ssh2_sftp_rmdir($sftp, '/home/username/newnamedir'); // 创建符号链接 ssh2_sftp_symlink($sftp, '/home/username/myfile', '/var/www/myfile'); // 删除文件 ssh2_sftp_unlink($sftp, '/home/username/myfile'); ?>
ssh2_sftp()
Accepts the connection resource and returns an SFTP resource for future ssh2_sftp_*
calls. These calls then return a Boolean value, allowing you to determine if the operation is successful.
Using the wrapping function
When there is no specific file management function in SFTP or SCP, you can usually use a stream wrapper to use the core file system function. Here are some examples:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_password($conn, 'username', 'password'); ?>
Before performing any of these calls, you must connect to the SSH and SFTP server because it uses the previously created $sftp
variable.
Integrate all content
Now that you can connect, verify identity, and run commands on an SSH server, we can create some auxiliary classes to simplify the execution of these commands: a class for executing SCP calls and a class for SFTP calls, a class for executing SSH calls, a Parent classes for common functions and several classes for encapsulating authentication information (passwords and keys). Let's first create authentication classes, as they will be used by other classes.
(The multiple PHP class codes provided in the article are omitted here because the article is too long, but its core logic has been reflected in the above description)
Summary
When the SSH2 PHP extension is installed, it allows your scripts to connect to the SSH2 server. You can take advantage of convenient classes that simplify the code that executes SFTP or SCP calls, or if the library does not provide a specific function, you can use most core file system operations by leveraging the SSH2 wrapper functionality.
(The FAQ part provided in the article is omitted here because the article is too long, but its core logic has been reflected in the above description)
The above is the detailed content of PHP Master | Using SSH and SFTP with PHP. For more information, please follow other related articles on the PHP Chinese website!

Long URLs, often cluttered with keywords and tracking parameters, can deter visitors. A URL shortening script offers a solution, creating concise links ideal for social media and other platforms. These scripts are valuable for individual websites a

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

This is the second and final part of the series on building a React application with a Laravel back-end. In the first part of the series, we created a RESTful API using Laravel for a basic product-listing application. In this tutorial, we will be dev

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

The 2025 PHP Landscape Survey investigates current PHP development trends. It explores framework usage, deployment methods, and challenges, aiming to provide insights for developers and businesses. The survey anticipates growth in modern PHP versio

In this article, we're going to explore the notification system in the Laravel web framework. The notification system in Laravel allows you to send notifications to users over different channels. Today, we'll discuss how you can send notifications ov


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Chinese version
Chinese version, very easy to use
