现在的PYTHON很火,但是我们的PHP也不错!主要是看有没有去挖掘它,去在phper中开更多的脑洞,有时学习框架学累的时候,不妨写写脚本。或许能帮助自己更好的了解PHP。
本博文出自51CTO博客且行且欣赏博主,有任何问题请进入博主页面互动讨论! 博文地址: http://skytina.blog.51cto.com/6834539/1615463 |
这里我们就不阐述Socket(套接字)是什么了,这里我们使用常见的C(client)/S(server)模式。作为服务器端,它的操作socket流程如下:
下面是Server.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的流程。
下面是代码:
- 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,那我们便会发现返回这样的错误!
#p#
错误一:服务端没有在监听返回错误:由于目标计算机积极拒绝,无法连接
错误二:端口已经被绑定了使用了,也就是你第二次运行了server.php返回错误:通常每个套接字地址(协议/网络地址/端口)只允许一次
所以在我们测试前,最好先查看一下,端口是否被占用!netstat -an | find "端口号"正确的运行次序以及结果如下,先运行server.php只需要php server.php即可!
可以看到没运行server.php前,本地127.0.0.1没有监听1993端口,但是一运行之后,服务端便在1993端口进行监听。之后运行client.php
客户端接收到来自服务端的信息,而服务端则进行计数,记录自己发送的次数!这个简单的例子可以为之后的socket应用打下一些基础,最常见的如聊天工具,然后到游戏之类的!