swoole学习手记(三)建立服务器(下)

目录javascript

持续更新中。。。php

1.建立HttpServer服务器

HttpServer是基于swoole_server,因此swoole_server下的方法HttpServer均可以使用
httpsevrer它只能被客户端唤起html

clipboard.png

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执行一下,打开浏览器
clipboard.pngweb

服务器
clipboard.pngsegmentfault

这里咱们发现了一个怪象
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

clipboard.png

有了!!
通常来讲设置了document_root的http_server流程是这样的:
1.先会去根据url去访问document_root相对的路径下的文件,跟配置域名访问文件的原理差很少
2.若是这个文件没有,那么咱们http_server才会顺着执行 $http->on('request'function($request, $response));作出相应的相应swoole


2.建立WebSocket服务器

1.特性:
(1)HTTP 协议有一个缺陷:通讯只能由客户端发起,作不到服务器主动向客户端推送信息。
而WebSocket它的最大特色就是,服务器能够主动向客户端推送信息,客户端也能够主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。
(2)Web_Socket继承http_server
clipboard.png

因为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>

clipboard.png

你能够根据这个来写一个基于web_socket的聊天室,十分有趣

学习了tcp,udp,websocket,http的服务,咱们能够作一波总结:

clipboard.png

若是这篇文章对你有用,能够点个赞或者是收藏,算是对做者的鼓励~

文档地址传送门:https://wiki.swoole.com/wiki/...
推荐singwa老师的视频教程:https://coding.imooc.com/clas...

另附上小弟网站。。。www.entercode.cn 推广一波...

相关文章
相关标签/搜索