?介紹
Socket用于進程間通信。進程間通信通常基于客戶端—服務端模型。此時,客戶端—服務端是可以彼此交互的應用程序。客戶端和服務端之間的交互需要連接。Socket編程負責的就是為應用程序之間建立可進行交互的連接。
在本文中,我們將學習如何用PHP創建一個簡單的客戶端—服務端。我們還將學習如何客戶端應用程序如何發送消息到服務端,以及如何從服務端接受消息。
使用代碼
目的:開發一個客戶端用于發送string消息到服務端,服務端將相同的信息反轉后返回給客戶端。
PHP服務器
第1步:設置變量,如“主機”和“端口”
$host = "127.0.0.1";
$port = 5353;
// No Timeout
set_time_limit(0);
端口號可以是1024 -65535之間的任何正整數。
第2步:創建socket
$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create socket\n");
第3步:綁定socket到端口和主機
創建的socket資源綁定到IP地址和端口號。
$result = socket_bind($socket, $host, $port) or die("Could not bind to socket\n");
第4步:啟動socket監聽
在綁定到IP和端口后,服務端開始等待客戶端的連接。在沒有連接之前它就一直等下去。
$result = socket_listen($socket, 3) or die("Could not set up socket listener\n");
第5步:接受連接
這個函數會接受所建的socket傳入的連接請求。在接受來自客戶端socket的連接后,該函數返回另一個socket資源,實際上就是負責與相應的客戶端socket通信。這里的“$spawn”就是負責與客戶端socket通信的socket資源。
$spawn = socket_accept($socket) or die("Could not accept incoming connection\n");
到現在為止,我們已經準備好了服務端socket ,但實際上這個腳本并沒有做任何事情。所以為了繼續完成上述目標,我們將讀取客戶端socket消息,然后將接收到的消息反轉后發回給客戶端socket。
第6步:從客戶端socket讀取消息
$input = socket_read($spawn, 1024) or die("Could not read input\n");
第7步:反轉消息
$output = strrev($input) . "\n";
第8步:發送消息給客戶端socket
socket_write($spawn, $output, strlen ($output)) or die("Could not write output\n");
關閉socket
socket_close($spawn);
socket_close($socket);
這就完成了服務端。現在,我們學習如何創建PHP客戶端。
PHP客戶端
前兩個步驟與服務端相同。
第1步:設置變量,如“主機”和“端口”
$host = "127.0.0.1";
$port = 5353;
// No Timeout
set_time_limit(0);
注:這里的端口和主機應該和服務端中的定義是相同的。
第2步:創建socket
$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create socket\n");
第3步:連接到服務端
$result = socket_connect($socket, $host, $port) or die("Could not connect toserver\n");
此時和服務端不同,客戶端socket不綁定端口和主機。相反,它連接到服務端socket,等待接受來自客戶端socket的連接。這一步建立了客戶端socket到服務端socket的連接。
第4步:寫入服務端socket
socket_write($socket, $message, strlen($message)) or die("Could not send data to server\n");
在此步驟中,客戶端socket的數據被發送到服務端socket。
第5步:閱讀來自服務端的響應
$result = socket_read ($socket, 1024) or die("Could not read server response\n");
echo "Reply From Server :".$result;
第6步:關閉socket
socket_close($socket);
完整的代碼
服務端(server.php)
// set some variables
$host = "127.0.0.1";
$port = 25003;
// don't timeout!
set_time_limit(0);
// create socket
$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create socket\n");
// bind socket to port
$result = socket_bind($socket, $host, $port) or die("Could not bind to socket\n");
// start listening for connections
$result = socket_listen($socket, 3) or die("Could not set up socket listener\n");
// accept incoming connections
// spawn another socket to handle communication
$spawn = socket_accept($socket) or die("Could not accept incoming connection\n");
// read client input
$input = socket_read($spawn, 1024) or die("Could not read input\n");
// clean up input string
$input = trim($input);
echo "Client Message : ".$input;
// reverse client input and send back
$output = strrev($input) . "\n";
socket_write($spawn, $output, strlen ($output)) or die("Could not write output\n");
// close sockets
socket_close($spawn);
socket_close($socket);
客戶端(client.php)
$host = "127.0.0.1";
$port = 25003;
$message = "Hello Server";
echo "Message To server :".$message;
// create socket
$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create socket\n");
// connect to server
$result = socket_connect($socket, $host, $port) or die("Could not connect to server\n");
// send string to server
socket_write($socket, $message, strlen($message)) or die("Could not send data to server\n");
// get server response
$result = socket_read ($socket, 1024) or die("Could not read server response\n");
echo "Reply From Server :".$result;
// close socket
socket_close($socket);
建立上述文件(server.php和client.php)后,執行如下操作:
復制www目錄中的這些文件(假設WAMP),安置于C:\wamp。
打開Web瀏覽器,在地址欄中鍵入localhost 。
先瀏覽server.php然后client.php。
> 許可證
> 這篇文章,以及任何相關的源代碼和文件,是經過The Code Project Open License (CPOL)許可的。
> 譯文鏈接:http://www.codeceo.com/article/php-socket-programming.html
> 英文原文:Socket Programming in PHP
> 翻譯作者:碼農網 – 小峰
- PHP技術文章
- PHP中session和cookie的區別
- php設計模式(一):簡介及創建型模式
- php設計模式結構型模式
- Php設計模式(三):行為型模式
- 十款最出色的 PHP 安全開發庫中文詳細介紹
- 12個提問頻率最高的PHP面試題
- PHP 語言需要避免的 10 大誤區
- PHP 死鎖問題分析
- 致PHP路上的“年輕人”
- PHP網站常見安全漏洞,及相應防范措施總結
- 各開源框架使用與設計總結(一)
- 數據庫的本質、概念及其應用實踐(二)
- PHP導出MySQL數據到Excel文件(fputcsv)
- PHP中14種排序算法評測
- 深入理解PHP原理之--echo的實現
- PHP性能分析相關的函數
- PHP 性能分析10則
- 10 位頂級 PHP 大師的開發原則
- 30條爆笑的程序員梗 PHP是最好的語言
- PHP底層的運行機制與原理
- PHP 性能分析與實驗——性能的宏觀分析
- PHP7 性能翻倍關鍵大揭露
- 鳥哥:寫在PHP7發布之際一些話
- PHP與MySQL通訊那點事
- Php session內部執行流程的再次剖析
- 關于 PHP 中的 Class 的幾點個人看法
- PHP Socket 編程過程詳解
- PHP過往及現在及變革
- PHP吉祥物大象的由來
- PHP生成靜態頁面的方法
- 吊炸天的 PHP 7 ,你值得擁有!
- PHP開發中文件操作疑難問答
- MongoDB PHP Driver的連接處理解析
- PHP 雜談《重構-改善既有代碼的設計》之二 對象
- 在php中判斷一個請求是ajax請求還是普通請求的方法
- 使用HAProxy、PHP、Redis和MySQL支撐10億請求每周架構細節
- HTML、HTML5、XHTML、CSS、SQL、JavaScript、PHP、Web Services 是什么?
- 重構-改善既有代碼的設計
- PHP場景中getshell防御思路分享
- 移動互聯時代,你看看除了PHP你還會些什么
- 安卓系統上搭建本地php服務器環境
- PHP中常見的緩存技術!
- PHP里10個鮮為人知但卻非常有用的函數
- 成為一名PHP專家其實并不難
- PHP 命令行?是的,您可以!
- PHP開發提高效率技巧
- PHP八大安全函數解析
- PHP實現四種基本排序算法
- PHP開發中的中文編碼問題
- php.get.post
- php發送get、post請求的6種方法簡明總結
- 中高級PHP開發者應該掌握哪些技術?
- 前端開發
- web前端知識體系大全
- 前端工程與性能優化(下)
- 前端工程與性能優化(上)
- 2016 年技術發展方向
- Web應用檢查清單
- 如何成為一名優秀的web前端工程師
- 前端組件化開發實踐
- 移動端H5頁面高清多屏適配方案
- 2015前端框架何去何從
- 從前端看“百度遷徙”的技術實現(一)
- 從前端看“百度遷徙”的技術實現(二)
- 前端路上的旅行
- 大公司里怎樣開發和部署前端代碼?
- 5個經典的前端面試問題
- 前端工程師新手必讀
- 手機淘寶前端的圖片相關工作流程梳理
- 一個自動化的前端項目實現(附源碼)
- 前端代碼異常日志收集與監控
- 15年雙11手淘前端技術總結 - H5性能最佳實踐
- 深入理解javascript原型和閉包系列
- 一切都是對象
- 函數和對象的關系
- prototype原型
- 隱式原型
- instanceof
- 繼承
- 原型的靈活性
- 簡述【執行上下文】上
- 簡述【執行上下文】下
- this
- 執行上下文棧
- 簡介【作用域】
- 【作用域】和【上下文環境】
- 從【自由變量】到【作用域鏈】
- 閉包
- 完結
- 補充:上下文環境和作用域的關系
- Linux私房菜