search
HomeBackend DevelopmentPHP TutorialPHP Master | Using SSH and SFTP with PHP

PHP Master | Using SSH and SFTP with PHP

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() and ssh2_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!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
11 Best PHP URL Shortener Scripts (Free and Premium)11 Best PHP URL Shortener Scripts (Free and Premium)Mar 03, 2025 am 10:49 AM

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

Working with Flash Session Data in LaravelWorking with Flash Session Data in LaravelMar 12, 2025 pm 05:08 PM

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-

Build a React App With a Laravel Back End: Part 2, ReactBuild a React App With a Laravel Back End: Part 2, ReactMar 04, 2025 am 09:33 AM

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

Simplified HTTP Response Mocking in Laravel TestsSimplified HTTP Response Mocking in Laravel TestsMar 12, 2025 pm 05:09 PM

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' =>

cURL in PHP: How to Use the PHP cURL Extension in REST APIscURL in PHP: How to Use the PHP cURL Extension in REST APIsMar 14, 2025 am 11:42 AM

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.

12 Best PHP Chat Scripts on CodeCanyon12 Best PHP Chat Scripts on CodeCanyonMar 13, 2025 pm 12:08 PM

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

Announcement of 2025 PHP Situation SurveyAnnouncement of 2025 PHP Situation SurveyMar 03, 2025 pm 04:20 PM

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

Notifications in LaravelNotifications in LaravelMar 04, 2025 am 09:22 AM

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

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use