经常有朋友会对php的socket应用充满疑惑,本文就以实例代码作一讲解,希望能对初学php的朋友起到一点帮助作用
具体代码如下:
1.服务器端代码:
<?php class SocketServer{ private $_port='9000'; private $_address='127.0.0.1'; private $_client_socket_list=array(); public function __set($name,$val){ $this--->$name=$val; } private function _showError($error){ exit($error); } /** * 开始进行socket服务器端监听端口 */ public function start(){ // 创建端口 if (($sock = socket_create ( AF_INET, SOCK_STREAM, SOL_TCP )) === false) { $this->_showError("socket_create() failed :reason:" . socket_strerror ( socket_last_error () )); } // 绑定 if (socket_bind ( $sock, $this->_address, $this->_port ) === false) { $this->_showError("socket_bind() failed :reason:" . socket_strerror ( socket_last_error ( $sock ) )); } // 监听 if (socket_listen ( $sock, 5 ) === false) { $this->_showError("socket_bind() failed :reason:" . socket_strerror ( socket_last_error ( $sock ) ) ); } do { //当有一个客户端连接的时候 if ($client_socket=socket_accept ( $sock )) { $count = count ( $this->_client_socket_list ) + 1; //把新来的用户加入 客户端数组里 $this->_client_socket_list[]=$client_socket; echo "new connection:\r\n";//服务器端输出当前正在连接的客户端数量 echo "current connection:{$count}\r\n"; //接受客户端传过来的字符串 $msg=$this->read($client_socket); echo "client:{$msg}\r\n"; //服务器向客户端传值 $my_msg="I am fine,think you\r\n"; $this->send($client_socket,$my_msg); } /** * 这段代码给你参考,用来判断是否有客户端主动失去连接 else{ foreach ( $this->_client_socket_list as $socket ) { $len = socket_recv ($socket, $buffer, 2048, 0 ); // 接受一下客户端信息,如果为0代表断开连接 if ($len < 7) { //这里写是去连接的客户端业务 } } } */ }while(true); } /** * 发送数据给客户端 */ public function send($client_socket,$str){ return socket_write ( $client_socket,$str, strlen ( $str ) ); } /** * 从客户端接受数据 */ public function read($client_socket){ return socket_read ( $client_socket, 8192 );//8192实际代表的接受长度,我用819292表示长一点,这样长一点的字符串也可以接受到,不到8192也没关系,会自动识别 } } $socket_server =new SocketServer(); $socket_server->start();//开始监听
2.客户端代码:
<?php class SocketServer{ private $_port='9000'; private $_address='127.0.0.1'; private $_client_socket_list=array(); public function __set($name,$val){ $this--->$name=$val; } private function _showError($error){ exit($error); } /** * 开始进行socket服务器端监听端口 */ public function start(){ // 创建端口 if (($sock = socket_create ( AF_INET, SOCK_STREAM, SOL_TCP )) === false) { $this->_showError("socket_create() failed :reason:" . socket_strerror ( socket_last_error () )); } // 绑定 if (socket_bind ( $sock, $this->_address, $this->_port ) === false) { $this->_showError("socket_bind() failed :reason:" . socket_strerror ( socket_last_error ( $sock ) )); } // 监听 if (socket_listen ( $sock, 5 ) === false) { $this->_showError("socket_bind() failed :reason:" . socket_strerror ( socket_last_error ( $sock ) ) ); } do { //当有一个客户端连接的时候 if ($client_socket=socket_accept ( $sock )) { $count = count ( $this->_client_socket_list ) + 1; //把新来的用户加入 客户端数组里 $this->_client_socket_list[]=$client_socket; echo "new connection:\r\n";//服务器端输出当前正在连接的客户端数量 echo "current connection:{$count}\r\n"; //接受客户端传过来的字符串 $msg=$this->read($client_socket); echo "client:{$msg}\r\n"; //服务器向客户端传值 $my_msg="I am fine,think you\r\n"; $this->send($client_socket,$my_msg); } /** * 这段代码给你参考,用来判断是否有客户端主动失去连接 else{ foreach ( $this->_client_socket_list as $socket ) { $len = socket_recv ($socket, $buffer, 2048, 0 ); // 接受一下客户端信息,如果为0代表断开连接 if ($len < 7) { //这里写是去连接的客户端业务 } } } */ }while(true); } /** * 发送数据给客户端 */ public function send($client_socket,$str){ return socket_write ( $client_socket,$str, strlen ( $str ) ); } /** * 从客户端接受数据 */ public function read($client_socket){ return socket_read ( $client_socket, 8192 );//8192实际代表的接受长度,我用819292表示长一点,这样长一点的字符串也可以接受到,不到8192也没关系,会自动识别 } } $socket_server =new SocketServer(); $socket_server->start();//开始监听
注意事项:服务器端请用CLI模式运行,cgi模式会超时,这是新手常喜欢犯的错误。那么什么是CLI模式呢?简单的说就是用命令行去执行,而不要用游览器打开,否则会超时的!
我想在一些计算机之间建立点对点连接,这样用户就可以在没有外部服务器的情况下聊天和交换文件。我最初的想法如下: 我在服务器上制作了一个中央服务器插座,所有应用程序都可以连接到该插座。此ServerSocket跟踪已连接的套接字(客户端),并将新连接的客户端的IP和端口提供给所有其他客户端。每个客户端都会创建一个新的ServerSocket,所有客户端都可以连接到它。 换句话说:每个客户端都有一个Se
前面的章节介绍了所有 Redis 的重要功能组件: 数据结构、数据类型、事务、Lua 环境、事件处理、数据库、持久化, 等等, 但是我们还没有对 Redis 服务器本身做任何介绍。 不过, 服务器本身并没有多少需要介绍的新东西, 因为服务器除了维持服务器状态之外, 最重要的就是将前面介绍过的各个功能模块组合起来, 而这些功能模块在前面的章节里已经介绍过了, 所以本章将焦点放在服务器的初始化过程,
本文向大家介绍Python XML RPC服务器端和客户端实例,包括了Python XML RPC服务器端和客户端实例的使用技巧和注意事项,需要的朋友参考一下 一、远程过程调用RPC XML-RPC is a Remote Procedure Call method that uses XML passed via HTTP as a transport. With it, a client ca
[服务器]:
正在编写一个服务器,使用Java套接字的客户端聊天程序。这是我的服务器套接字类的代码。 客户端能够建立连接并向服务器发送消息。服务器也可以接收客户端发送的消息。问题是当消息从服务器发送时,客户端没有收到消息。这是我的客户端套接字代码。
问题内容: 我正在尝试以客户端/服务器方式制作Java应用程序。客户端是SWT中的GUI,它显示来自服务器的数据。服务器已连接到数据库。 好的,对此感到抱歉,我确定这是一个经典问题,但我不知道如何开始。 在我为他们工作的一个项目中,他们实施了很多魔术来透明地调用Glassfish服务器。 我不想使用Glassfish服务器。我只想要简单的Java语言。但是代理的概念似乎很酷。 你有这种想法或例子吗