当客户端通过websocket来访问服务端的时候,需要进行三次握手。那是怎么进行的呢?
说白了,就是,websocket来访问服务端的时候会发送一些消息,这些消息里有一个Sec-WebSocket-Key的数据。得到这个数据值,并进行编码一下返回给websocket就可以啦。这就握手成功了。是不是很简单。
PHP代码:
//这里只贴握手的代码。 完整的代码去看我聊天室的代码。 //先获取客户端连接过来的时候发送的数据 $request = socket_read($sock,1024); //然后正则匹配,匹配到的数据放入$match,这里的$match是引用传值。 //Sec-WebSocket-Key: 后面是有一个空格的。切记。。。 preg_match('/Sec-WebSocket-Key: (.*)\r\n/',$request,$match); //这里进行编码先进行 sha1 加上一串字符长,这个字符串是固定的不可改变。记得设置true,这样得到的是20 字符长度的原始格式 //在进行base64_encode 编码 $accept = base64_encode(sha1($match[1].'258EAFA5-E914-47DA-95CA-C5AB0DC85B11',true)); //这里就是拼接报文头信息了。 $buffer = "HTTP/1.1 101 Switching Protocols\r\n"; $buffer .= "Connection: Upgrade \r\n"; //在这里拼接我们编码后的数据 $buffer .= "Sec-WebSocket-Accept: $accept\r\n"; $buffer .= "Sec-WebSocket-Version: 13 \r\n"; //一定要切记 最后一行需要两个换行符 \r\n\r\n $buffer .= "Upgrade: websocket \r\n\r\n"; //吧这个字符串写入套接字, socket_write($sock , $buffer, strlen($buffer));
JS:
var so = new WebSocket('ws://*.*.*.48:8888'); //这里是你请求的地址,ip+端口 记住协议是 ws开头的不是http console.log(so) so.onopen = function(){ //这是链接成功后的回调函数。 console.log('链接成功'); }
这里看效果图
这是 客户端 websocket 发送给我们的数据。
我们拼接好返回个客户端数据后:我们写字回调函数的数据页打印出来了。