0

0

深入浅出php socket编程_PHP教程

php中文网

php中文网

发布时间:2016-07-13 09:53:46

|

1013人浏览过

|

来源于php中文网

原创

深入浅出php socket编程

   这篇文章主要介绍了深入浅出php socket编程,本文详细的讲解了socket的相关知识、php socket的编程实例行装内容,需要的朋友可以参考下

  对TCP/IP、UDP、Socket编程这些词你不会很陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵。那么我想问:

  1.什么是TCP/IP、UDP?

  2.Socket在哪里呢?

  3.Socket是什么呢?

立即学习PHP免费学习笔记(深入)”;

  4.你会使用它们吗?

  什么是TCP/IP、UDP?

  TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协议,是一个工业标准的协议集,它是为广域网(WANs)设计的。

  UDP(User Data Protocol,用户数据报协议)是与TCP相对应的协议。它是属于TCP/IP协议族中的一种。

  这里有一张图,表明了这些协议的关系。

  TCP/IP协议族包括运输层、网络层、链路层。现在你知道TCP/IP与UDP的关系了吧。

  Socket在哪里呢?

  在图1中,我们没有看到Socket的影子,那么它到底在哪里呢?还是用图来说话,一目了然。

  原来Socket在这里。

  Socket是什么呢?

  Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。

  你会使用它们吗?

  前人已经给我们做了好多的事了,网络间的通信也就简单了许多,但毕竟还是有挺多工作要做的。以前听到Socket编程,觉得它是比较高深的编程知识,但是只要弄清Socket编程的工作原理,神秘的面纱也就揭开了。

  一个生活中的场景。你要打电话给一个朋友,先拨号,朋友听到电话铃声后提起电话,这时你和你的朋友就建立起了连接,就可以讲话了。等交流结束,挂断电话结束此次交谈。 生活中的场景就解释了这工作原理,也许TCP/IP协议族就是诞生于生活中,这也不一定。

  先从服务器端说起。服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接。在这时如果有个客户端初始化一个Socket,然后连接服务器(connect),如果连接成功,这时客户端与服务器端的连接就建立了。客户端发送数据请求,服务器端接收请求并处理请求,然后把回应数据发送给客户端,客户端读取数据,最后关闭连接,一次交互结束。

  socket相关函数:

  ----------------------------------------------------------------------------------------------

  socket_accept() 接受一个Socket连接

  socket_bind() 把socket绑定在一个IP地址和端口上

  socket_clear_error() 清除socket的错误或者最后的错误代码

  socket_close() 关闭一个socket资源

  socket_connect() 开始一个socket连接

  socket_create_listen() 在指定端口打开一个socket监听

  socket_create_pair() 产生一对没有区别的socket到一个数组里

  socket_create() 产生一个socket,相当于产生一个socket的数据结构

  socket_get_option() 获取socket选项

  socket_getpeername() 获取远程类似主机的ip地址

  socket_getsockname() 获取本地socket的ip地址

  socket_iovec_add() 添加一个新的向量到一个分散/聚合的数组

  socket_iovec_alloc() 这个函数创建一个能够发送接收读写的iovec数据结构

  socket_iovec_delete() 删除一个已经分配的iovec

  socket_iovec_fetch() 返回指定的iovec资源的数据

  socket_iovec_free() 释放一个iovec资源

  socket_iovec_set() 设置iovec的数据新值

  socket_last_error() 获取当前socket的最后错误代码

  socket_listen() 监听由指定socket的所有连接

  socket_read() 读取指定长度的数据

  socket_readv() 读取从分散/聚合数组过来的数据

  socket_recv() 从socket里结束数据到缓存

  socket_recvfrom() 接受数据从指定的socket,如果没有指定则默认当前socket

  socket_recvmsg() 从iovec里接受消息

  socket_select() 多路选择

  socket_send() 这个函数发送数据到已连接的socket

  socket_sendmsg() 发送消息到socket

  socket_sendto() 发送消息到指定地址的socket

  socket_set_block() 在socket里设置为块模式

  socket_set_nonblock() socket里设置为非块模式

  socket_set_option() 设置socket选项

  socket_shutdown() 这个函数允许你关闭读、写、或者指定的socket

  socket_strerror() 返回指定错误号的详细错误

  socket_write() 写数据到socket缓存

  socket_writev() 写数据到分散/聚合数组

  案例一:socket通信演示

  服务器端:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

MusicAI
MusicAI

AI音乐生成工具

下载

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

//确保在连接客户端时不会超时

set_time_limit(0);

 

$ip = '127.0.0.1';

$port = 1935;

 

/*

+-------------------------------

* @socket通信整个过程

+-------------------------------

* @socket_create

* @socket_bind

* @socket_listen

* @socket_accept

* @socket_read

* @socket_write

* @socket_close

+--------------------------------

*/

 

/*---------------- 以下操作都是手册上的 -------------------*/

if(($sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP))

echo "socket_create() 失败的原因是:".socket_strerror($sock)."\n";

}

 

if(($ret = socket_bind($sock,$ip,$port))

echo "socket_bind() 失败的原因是:".socket_strerror($ret)."\n";

}

 

if(($ret = socket_listen($sock,4))

echo "socket_listen() 失败的原因是:".socket_strerror($ret)."\n";

}

 

$count = 0;

 

do {

if (($msgsock = socket_accept($sock))

echo "socket_accept() failed: reason: " . socket_strerror($msgsock) . "\n";

break;

} else {

 

//发到客户端

$msg ="测试成功!\n";

socket_write($msgsock, $msg, strlen($msg));

 

echo "测试成功了啊\n";

$buf = socket_read($msgsock,8192);

 

 

$talkback = "收到的信息:$buf\n";

echo $talkback;

 

if(++$count >= 5){

break;

};

 

 

}

//echo $buf;

socket_close($msgsock);

 

} while (true);

 

socket_close($sock);

?>

  这是socket的服务端代码。然后运行cmd,注意是自己的程序存放路径啊。

  没有反映,对现在服务端的程序已经开始运行,端口已经开始监听了。运行netstat -ano可以查看端口情况,我的是1935端口

  看,端口已经处于LISTENING状态了。接下来我们只要运行客户端程序即可连接上。上代码

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

error_reporting(E_ALL);

set_time_limit(0);

echo "

TCP/IP Connection

\n";

 

$port = 1935;

$ip = "127.0.0.1";

 

/*

+-------------------------------

* @socket连接整个过程

+-------------------------------

* @socket_create

* @socket_connect

* @socket_write

* @socket_read

* @socket_close

+--------------------------------

*/

 

$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);

if ($socket

echo "socket_create() failed: reason: " . socket_strerror($socket) . "\n";

}else {

echo "OK.\n";

}

 

echo "试图连接 '$ip' 端口 '$port'...\n";

$result = socket_connect($socket, $ip, $port);

if ($result

echo "socket_connect() failed.\nReason: ($result) " . socket_strerror($result) . "\n";

}else {

echo "连接OK\n";

}

 

$in = "Ho\r\n";

$in .= "first blood\r\n";

$out = '';

 

if(!socket_write($socket, $in, strlen($in))) {

echo "socket_write() failed: reason: " . socket_strerror($socket) . "\n";

}else {

echo "发送到服务器信息成功!\n";

echo "发送的内容为:$in
";

}

 

while($out = socket_read($socket, 8192)) {

echo "接收服务器回传信息成功!\n";

echo "接受的内容为:",$out;

}

 

 

echo "关闭SOCKET...\n";

socket_close($socket);

echo "关闭OK\n";

?>

  至此客户端已经连接上服务端了。

  案例二:代码详解

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

// 设置一些基本的变量

$host = "192.168.1.99";

$port = 1234;

// 设置超时时间

set_time_limit(0);

// 创建一个Socket

$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not createsocket\n");

//绑定Socket到端口

$result = socket_bind($socket, $host, $port) or die("Could not bind tosocket\n");

// 开始监听链接

$result = socket_listen($socket, 3) or die("Could not set up socketlistener\n");

// accept incoming connections

// 另一个Socket来处理通信

$spawn = socket_accept($socket) or die("Could not accept incomingconnection\n");

// 获得客户端的输入

$input = socket_read($spawn, 1024) or die("Could not read input\n");

// 清空输入字符串

$input = trim($input);

//处理客户端输入并返回结果

$output = strrev($input) . "\n";

socket_write($spawn, $output, strlen ($output)) or die("Could not write

output\n");

// 关闭sockets

socket_close($spawn);

socket_close($socket);

  下面是其每一步骤的详细说明:

  1.第一步是建立两个变量来保存Socket运行的服务器的IP地址和端口.你可以设置为你自己的服务器和端口(这个端口可以是1到65535之间的数字),前提是这个端口未被使用.

   代码如下:

  // 设置两个变量

  $host = "192.168.1.99";

  $port = 1234;

  2.在服务器端可以使用set_time_out()函数来确保PHP在等待客户端连接时不会超时.

  代码如下:

  // 超时时间

  set_time_limit(0);

  3.在前面的基础上,现在该使用socket_creat()函数创建一个Socket了—这个函数返回一个Socket句柄,这个句柄将用在以后所有的函数中.

   代码如下:

  // 创建Socket

  $socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create

  socket\n");

  第一个参数”AF_INET”用来指定域名;

  第二个参数”SOCK_STREM”告诉函数将创建一个什么类型的Socket(在这个例子中是TCP类型)

  因此,如果你想创建一个UDP Socket的话,你可以使用如下的代码:

  代码如下:

  // 创建 socket

  $socket = socket_create(AF_INET, SOCK_DGRAM, 0) or die("Could not create

  socket\n");

  4.一旦创建了一个Socket句柄,下一步就是指定或者绑定它到指定的地址和端口.这可以通过socket_bind()函数来完成.

   代码如下:

  // 绑定 socket to 指定地址和端口

  $result = socket_bind($socket, $host, $port) or die("Could not bind to

  socket\n");

  5.当Socket被创建好并绑定到一个端口后,就可以开始监听外部的连接了.PHP允许你由socket_listen()函数来开始一个监听,同时你可以指定一个数字(在这个例子中就是第二个参数:3)

   代码如下:

  // 开始监听连接

  $result = socket_listen($socket, 3) or die("Could not set up socket

  listener\n");

  6.到现在,你的服务器除了等待来自客户端的连接请求外基本上什么也没有做.一旦一个客户端的连接被收到,socket_accept()函数便开始起作用了,它接收连接请求并调用另一个子Socket来处理客户端–服务器间的信息.

   代码如下:

  //接受请求链接

  // 调用子socket 处理信息

  $spawn = socket_accept($socket) or die("Could not accept incoming

  connection\n");

  这个子socket现在就可以被随后的客户端–服务器通信所用了.

  7.当一个连接被建立后,服务器就会等待客户端发送一些输入信息,这写信息可以由socket_read()函数来获得,并把它赋值给PHP的$input变量.

   代码如下:

  // 读取客户端输入

  $input = socket_read($spawn, 1024) or die("Could not read input\n");

  ?>

  socker_read的第而个参数用以指定读入的字节数,你可以通过它来限制从客户端获取数据的大小.

  注意:socket_read函数会一直读取壳户端数据,直到遇见\n,\t或者\0字符.PHP脚本把这写字符看做是输入的结束符.

  8.现在服务器必须处理这些由客户端发来是数据(在这个例子中的处理仅仅包含数据的输入和回传到客户端).这部分可以由socket_write()函数来完成(使得由通信socket发回一个数据流到客户端成为可能)

  代码如下:

  // 处理客户端输入并返回数据

  $output = strrev($input) . "\n";

  socket_write($spawn, $output, strlen ($output)) or die("Could not write

  output\n");

  9.一旦输出被返回到客户端,父/子socket都应通过socket_close()函数来终止

  代码如下:

  // 关闭 sockets

  socket_close($spawn);

  socket_close($socket);

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1000097.htmlTechArticle深入浅出php socket编程 这篇文章主要介绍了深入浅出php socket编程,本文详细的讲解了socket的相关知识、PHP socket的编程实例行装内容,需要的朋...

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

89

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

276

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

59

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

99

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

105

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

230

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

619

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

173

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号