目录javascript
持续更新中。。。php
HttpServer是基于swoole_server,因此swoole_server下的方法HttpServer均可以使用
httpsevrer它只能被客户端唤起html
1.测试java
<?php $http = new swoole_http_server("0.0.0.0", 8811); $http->on('request', function($request, $response) { echo 'nihao'; $response->end('hello swoole'); }); $http->start();
php执行一下,打开浏览器web
服务器segmentfault
这里咱们发现了一个怪象
1.echo(var_dump,print_rd)的内容在服务器现实
2.而浏览器的内容只能经过end(内容)的方式
end只能调用一次,若是须要分屡次向客户端发送数据,请使用write方法浏览器
扩展:咦这个,很像咱们平时访问的 XXX.com:80 若是咱们想要访问下面的文件那怎么办?
是否是想起咱们以前tcp和udp都有用到的一个函数 set,这个函数我把它理解为配置,那么咱们就怼着它进行配置服务器
$http->set([ 'enable_static_handler' => true, 'document_root' => "/www/wwwroot/server",//设置根目录这里根据你本身的路径来写 ]);
是否是很像配置虚拟地址?咱们试着访问server目录下的test.htmlwebsocket
有了!!
通常来讲设置了document_root的http_server流程是这样的:
1.先会去根据url去访问document_root相对的路径下的文件,跟配置域名访问文件的原理差很少
2.若是这个文件没有,那么咱们http_server才会顺着执行 $http->on('request'function($request, $response));作出相应的相应swoole
1.特性:
(1)HTTP 协议有一个缺陷:通讯只能由客户端发起,作不到服务器主动向客户端推送信息。
而WebSocket它的最大特色就是,服务器能够主动向客户端推送信息,客户端也能够主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。
(2)Web_Socket继承http_server
因为web_server全双工这个特性因此很适合作聊天室
2.说到这咱们就来作一个简单的测试!
(1)咱们先写一个web_server.php的文件
$server = new swoole_websocket_server("0.0.0.0", 8811); //Web_Socket继承http_server,因此它也能够拥有一样的set方法 //包括 $server->on('request', function($request, $response) {}也是能够有的 $server->set( [ 'enable_static_handler' => true, 'document_root' => "/www/wwwroot/server", ] ); //监听websocket链接打开事件 $server->on('open', 'onOpen'); function onOpen($server, $request) { echo "fd为:".$request->fd."已经上线\n"; } // 监听ws消息事件 $server->on('message', function ( $server, $frame) { var_dump($frame); $msg='fd为'.$frame->fd.'说:'.$frame->data;//$frame->data为客户端传递过来的信息 $server->push($frame->fd, $msg); }); $server->on('close', function ($server, $fd) { echo "client {$fd} closed\n"; }); $server->start();
(2)而后再写一个客户端文件
<script type="text/javascript"> var url='ws://你的ip地址:8811'; var ws =new WebSocket(url); ws.onopen=function (evt) { ws.send('客户端:创建连接成功'); console.log(evt); } ws.onmessage=function(evt){ console.log(evt); console.log('服务器回复:'+evt.data); } ws.onclose=function(evt){ console.log(evt); } ws.onerror=function(evt){ console.log(evt); } </script>
你能够根据这个来写一个基于web_socket的聊天室,十分有趣
学习了tcp,udp,websocket,http的服务,咱们能够作一波总结:
若是这篇文章对你有用,能够点个赞或者是收藏,算是对做者的鼓励~
文档地址传送门:https://wiki.swoole.com/wiki/...
推荐singwa老师的视频教程:https://coding.imooc.com/clas...
另附上小弟网站。。。www.entercode.cn 推广一波...