核心要點
- PHP 的 SSH2 擴展(libssh2 的包裝器)提供多個函數,用於使用 SCP 和 SFTP 等協議安全地傳輸文件。需要安裝 SSH2 包才能使用這些函數。
- 身份驗證可以使用用戶名/密碼或公鑰/私鑰身份驗證來實現。函數
ssh2_auth_password()
和ssh2_auth_pubkey_file()
返回一個布爾值,指示身份驗證是否成功。 - 成功進行身份驗證後,可以使用 SCP 函數執行文件傳輸操作。 SFTP 函數提供了更多功能,包括更改文件或目錄權限、獲取有關文件的信息、創建目錄、重命名項目和刪除項目。
- 本文提供了代碼片段,用於創建輔助類來簡化執行這些命令的過程,包括用於執行SCP 調用和SFTP 調用的類、用於常見功能的父類以及用於封裝身份驗證信息(密碼和密鑰)的類。
在當今世界,第三方集成和內容共享非常普遍,因此了解並使用 SCP 和 SFTP 等協議至關重要。 PHP 的 SSH2 擴展(libssh2 的包裝器,實現了 SSH2 協議)提供了多個函數,可用於安全地傳輸文件。要開始使用這些函數,顯然需要安裝 SSH2 包。由於它是一個 PECL 擴展,因此安裝過程將取決於您選擇的操作系統。請遵循 php.net 上的指南。
建立連接
讓我們從連接到 SSH 服務開始。建立連接非常簡單:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_password($conn, 'username', 'password'); ?>
一些管理員更喜歡使用公鑰和私鑰來驗證登錄。如果服務已配置並且您想以此方式連接,則應改用以下方法:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_pubkey_file( $conn, 'username', '/home/username/.ssh/id_rsa.pub', '/home/username/.ssh/id_rsa' ); ?>
無論您使用用戶名/密碼還是公鑰/私鑰身份驗證,ssh2_auth_password()
和 ssh2_auth_pubkey_file()
都返回一個布爾值,指示身份驗證是否成功。
執行基本命令
成功驗證服務器身份後,您可以執行文件傳輸操作。 SCP 函數允許您像這樣發送或接收文件:
<?php // 发送文件 ssh2_scp_send($conn, '/local/filename', '/remote/filename', 0644); // 获取文件 ssh2_scp_recv($conn, '/remote/filename', '/local/filename'); ?>
ssh2_scp_send()
還有一個附加參數,您可以指定文件複製到遠程服務器時的文件權限。 SFTP 函數提供了更多功能;您可以更改文件或目錄權限、獲取有關文件的信息、創建目錄、重命名項目、刪除項目等。它們的工作方式與上面的 SCP 函數非常相似,但在使用這些函數之前,必須通過 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()
接受連接資源並返回一個 SFTP 資源,該資源用於將來的 ssh2_sftp_*
調用。然後,這些調用返回一個布爾值,允許您確定操作是否成功。
使用包裝函數
當 SFTP 或 SCP 不存在特定文件管理函數時,通常可以使用流包裝器使用核心文件系統函數。以下是一些示例:
<?php $conn = ssh2_connect('example.com', 22); ssh2_auth_password($conn, 'username', 'password'); ?>
在執行任何這些調用之前,必須連接到 SSH 和 SFTP 服務器,因為它使用先前創建的 $sftp
變量。
整合所有內容
既然您能夠連接、驗證身份並在SSH 服務器上運行命令,我們可以創建一些輔助類來簡化執行這些命令的過程:一個用於執行SCP 調用的類和一個用於SFTP 調用的類、一個用於常見功能的父類以及幾個用於封裝身份驗證信息(密碼和密鑰)的類。讓我們首先創建身份驗證類,因為它們將被其他類使用。
(此處省略了文章中提供的多個PHP類代碼,因為篇幅過長,但其核心邏輯已在上述描述中體現)
總結
安裝 SSH2 PHP 擴展後,它可以讓您的腳本連接到 SSH2 服務器。您可以利用簡化執行 SFTP 或 SCP 調用的代碼的便捷類,或者如果庫未提供特定函數,則可以通過利用 SSH2 包裝器功能來使用大多數核心文件系統操作。
(此處省略了文章中提供的FAQ部分,因為篇幅過長,但其核心邏輯已在上述描述中體現)
以上是PHP主|將SSH和SFTP與PHP一起使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

ToretrievedatafromaPHPsession,startthesessionwithsession_start()andaccessvariablesinthe$_SESSIONarray.Forexample:1)Startthesession:session_start().2)Retrievedata:$username=$_SESSION['username'];echo"Welcome,".$username;.Sessionsareserver-si

利用會話構建高效購物車系統的步驟包括:1)理解會話的定義與作用,會話是服務器端的存儲機制,用於跨請求維護用戶狀態;2)實現基本的會話管理,如添加商品到購物車;3)擴展到高級用法,支持商品數量管理和刪除;4)優化性能和安全性,通過持久化會話數據和使用安全的會話標識符。

本文討論了PHP中的crypt()和password_hash()的差異,以進行密碼哈希,重點介紹其實施,安全性和對現代Web應用程序的適用性。

文章討論了通過輸入驗證,輸出編碼以及使用OWASP ESAPI和HTML淨化器之類的工具來防止PHP中的跨站點腳本(XSS)。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

WebStorm Mac版
好用的JavaScript開發工具

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

禪工作室 13.0.1
強大的PHP整合開發環境