您好,登錄后才能下訂單哦!
現在的PYTHON很火,但是我們的PHP也不錯!主要是看有沒有去挖掘它,去在phper中開更多的腦洞,有時學習框架學累的時候,不妨寫寫腳本。或許能幫助自己更好的了解PHP。
這里我們就不闡述Socket(套接字)是什么了,這里我們使用常見的C(client)/S(server)模式。
作為服務器端,它的操作socket流程如下:
下面是Server.php的代碼
<?php #The script is used to listen the requests from client error_reporting(E_ALL & ~E_NOTICE); $ip = '127.0.0.1'; $port = 1993; $sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP); if(!$sock){ echo 'In create process'.socket_strerror(socket_last_error()); } $bind_ornot = socket_bind($sock,$ip,$port); if(!$bind_ornot) { echo 'In bind process:'.socket_strerror(socket_last_error($sock)); return 0; } if(socket_listen($sock,10)){ $flag = 1; do{ $conn_socket = socket_accept($sock); $msg = "Send Message:Hello,World"; if(socket_write($conn_socket,$msg,strlen($msg))) { echo "第{$flag}次:發送成功\n"; }; if($flag == 5) { echo "停止監聽,發送完成"; break; } $flag++; socket_close($conn_socket); }while(True); } ?>
socket_create()函數是用來創建一個socket資源,它有三個參數,第一個參數指的是協議族,其中AF_INET指的是使用ipv4的協議族,第二個參數是指使用的通信類型,SOCK_STREAM指的是流模式。流模式對應的是可靠連接,也就是tcp連接方式。第三個指的是選用哪一種連接方式,要是tcp就是用SOL_TCP.要是udp就使用SOL_UDP。
對于socket_listen,第一個參數是要監聽的套接字,第二個是可允許的隊列數目,即允許有多少個人連接。但在使用前得先綁定一個ip地址和端口
上面的php代碼,監聽本地環路地址‘127.0.0.1’的1993端口,只要有連接請求發送到1993端口,便與客戶端建立tcp連接,之后便是發送信息到客戶端,發送完消息之后便關閉連接。里面的flag為計數標志變量,當$flag為5的時候,停止建立連接。
PS:socket_strerror(socket_last_error($sock))返回的是對應套接字產生錯誤的原因,編碼是根據操作系統所使用的語言,我這里是windows的中文系統,所以返回的是gbk編碼!
接下來是client.php操作socket的流程。
下面是代碼:
<?php error_reporting(E_ALL & ~E_NOTICE); $sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP); if($sock){ if(socket_connect($sock,'127.0.0.1',1993)) { while(($content = socket_read($sock,256))) { echo $content."\n"; } } else { echo 'In connect process'.socket_strerror(socket_last_error()); } } else { echo 'In create process'.socket_strerror(socket_last_error($sock)); } ?>
上面的代碼使用socket_connect()連接到正在監聽的服務器端口1993,連接后,通過socket_read()從連接后的套接字讀取內容!返回的由于是字符串類型,可以直接打印!
之后我們先運行server.php,因為其負責監聽指定端口和發送信息。
倘若我們先運行client.php,那我們便會發現返回這樣的錯誤!
錯誤一:服務端沒有在監聽
返回錯誤:由于目標計算機積極拒絕,無法連接
錯誤二:端口已經被綁定了使用了,也就是你第二次運行了server.php
返回錯誤:通常每個套接字地址(協議/網絡地址/端口)只允許一次
所以在我們測試前,最好先查看一下,端口是否被占用!
netstat -an | find "端口號"
正確的運行次序以及結果如下,先運行server.php
只需要php server.php即可!
可以看到沒運行server.php前,本地127.0.0.1沒有監聽1993端口,但是一運行之后,服務端便在1993端口進行監聽。
之后運行client.php
客戶端接收到來自服務端的信息,而服務端則進行計數,記錄自己發送的次數!
這個簡單的例子可以為之后的socket應用打下一些基礎,最常見的如聊天工具,然后到游戲之類的!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。