phpsocket客户端以及服务器例子

一个菜鸟朋友,突然问了我这个问题...现在稍稍有点时间,就写了一个简单的例子给他,顺便贴上来

服务器端:

<?php
/**
 * @author 邹颢	[email protected]
 */
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();//开始监听

客户端:

<?php
/**
 * @author 邹颢	[email protected]
 */
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模式,简单的说就是用命令行去执行,而不要用游览器打开,否则会超时的

phpsocket客户端以及服务器例子

时间: 2024-10-11 04:35:17

phpsocket客户端以及服务器例子的相关文章

Android客户端与服务器交互方式-小结

最近的Android项目开发过程中一个问题困扰自己很长时间,Android客户端与服务器交互有几种方式,最常见的就是webservices和json.要在Android手机客户端与pc服务器交互,需要满足下面几种条件:跨平台.传输数据格式标准.交互方便. 为了与服务器通讯其实无非就两种协议HTTP和TCP,TCP的学习Socket,HTTP的话熟悉一下HTTP协议和相关Java API.而下面的几种方式就是从这两种协议扩展出来的:webservices soap.SSH的JSON(可参考:该链接

MYSQL 客户端与服务器关系

数据库概念   如果想要知道mysql数据库客户端与服务器之间的关系.首先要明白什么是"数据库". 从字面意思理解,所谓"数据库",就是存放数据的库.现实中,大家都知道仓库,粮食库,车库,快递库,它们是放各种实体东西的库.而数据库,放的只有数据. 它是一个软件,它是一个能帮我们管理数据的地方.什么样的东西算数据?一篇文章,一个人的年龄,名字,一件商品的名称,数量,价格等等...把它们放在数据库中稳妥的管理起来,且效率挺高,这就是数据库. 数据库与PHP配合的重要性

ICE学习第四步-----客户端请求服务器返回数据

这次我们来做一个例子,流程很简单:客户端向服务器发送一条指令,服务端接收到这条指令之后,向客户端发送数据库中查询到的数据,最终显示在DataGridView上. 根据上一篇文章介绍的Slice语法,我们先来定义ICE文件.我定义两个ICE文件,一个用来描述测试数据库表中属性相关信息,另一个则是请求数据的方法. 结构如下:    定义结构体,和数据库中表的列对应,添加序列(相当于数组类型). 在获取表的方法中注意要记得#include带有结构的ice文件,并把接口函数的返回值类型写成之前定义的数组

分布式数据库数据从属与客户端与服务器的数据同步

老实说,目前市面上许多产品,的确是不成熟的产品. 用过一些,给人蛋痛的感觉. 导言 分布还是集总 今天我们来探讨一个很重要的问题. 每个程序员都有其思想,我的思想之一,就是分布式. 分布式,面对的一个问题,就数据的同步. 比如说,我们人类是分布式的,我们每个细胞都在无时无刻与其它细脑交换数据. 而现实世界,我们的设计是什么样子?一般都是集总式. 首先来说,这种方式,与现实世界并不一致.所以,带来的最严重的一个影响就是效率的问题. 自己这些年,一直在无线通信领域. 无线通信,有两个重要的特点: 1

SignalR一个集成的客户端与服务器库。内部的两个对象类:PersistentConnection和Hub

SignalR 将整个交换信息的行为封装得非常漂亮,客户端和服务器全部都使用 JSON 来沟通,在服务器端声明的所有 hub 的信息,都会一般生成 JavaScript 输出到客户端. 它是基于浏览器的客户端和基于ASP.NET 的服务器组件 可以借助SignalR来进行双向多步对话.就是说 该对话可不受限制的进行 单个无状态请求/响应 数据交换:它将继续,直到明确关闭.  对话通过永久连接进行,允许客户端向服务器发送多个消息,并允许服务器做出相应答复.  它还允许服务器向客户端发送异步消息.

OPC协议解析-OPC客户端与服务器通讯解析

1      OPC服务器 OPC服务器, 是指按照OPC基金组织规定的OPC规范群开发的软件驱动.OPC服务器作为中间媒介负责从数据源读取数据再跟另外一端的客户端通信.在 OPC客户端/服务器 的结构图中, 通信的发起端是, 也只能是OPC客户端.客户端和服务器的对话是双向的, 也就是说, 客户端既可以从服务器读出也可以向服务器写入. TOPC基金会定义了四种不同类型的OPC服务器.他们分别是: OPC数据访问服务器(OPC DA) – 它基于 OPC数据访问规范, 是一种为实时数据通讯特别定

用java语言构建一个网络服务器,实现客户端和服务器之间通信,实现客户端拥有独立线程,互不干扰

服务器: 1.与客户端的交流手段多是I/O流的方式 2.对接的方式是Socket套接字,套接字通过IP地址和端口号来建立连接 3.(曾经十分影响理解的点)服务器发出的输出流的所有信息都会成为客户端的输入流,同时所有客户端的所有输出流都会包含在服务器的输入流中. (即套接字即使建立连接,输入输出流都是相对自己的而言的,向外发送自己的内部的信息都用输出流,接受外部的数据都使用输入流!) 简单服务器的代码实现: public static void main(String [] args){ try

介绍一款chrom浏览器插件 DHC是一款使用chrome模拟REST客户端向服务器发送测试数据的谷歌浏览器插件

先打个小广告哈 公司招java架构师,月薪25K以上,负责电商平台架构工作,工作地点在北京 1号线永安里站 附近,如有意向 请把简历发我邮箱[email protected] 可以内部推荐. DHC是一款使用chrome模拟REST客户端向服务器发送测试数据的谷歌浏览器插件. DHC的开发背景 在web开发中,服务器端和客户端的开发和测试必不可少,但是测试的工作往往需要服务器端完成之后,客户端才能进行测试,这无疑延后了测试流程,导致服务器端开发完成后,无法进行充分的数据测试,很容易造成服务器端和

java实现客户端向服务器发送文件的操作

服务器源代码: import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.net.ServerSocket;