聊天对于大家都不陌生,但是如何做一个自己的聊天功能呢
首先介绍一下何为websocket,帮助大家更好的认识一下websocket
在浏览器中通过http仅能实现单向的通信,comet可以一定程度上模拟双向通信,但效率较低,并需要服务器有较好的支持; flash中的socket和xmlsocket可以实现真正的双向通信,通过 flex ajax bridge,可以在javascript中使用这两项功能. 可以预见,如果websocket一旦在浏览器中得到实现,将会替代上面两项技术,得到广泛的使用.面对这种状况,HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽并达到实时通讯。
可见为何利用websocket来写聊天功能了,这样可以省去很多的麻烦!
因为我是用go写的首先你得了解go语言吧,不必精通但是不许知道如何运用go语言,否则我也爱莫能助啊
好了!进入正题吧
首先是客户的代码
<script type="text/javascript" src="jquery-1.11.0.js" ></script>
<script type="text/javascript">
var sock = null;
var wsuri = "ws://localhost:9999";
window.onload = function() {
console.log("onload");
sock = new WebSocket(wsuri);
sock.onopen = function() {
console.log("connected to " + wsuri);
}
sock.onclose = function(e) {
console.log("connection closed (" + e.code + ")");
}
sock.onmessage = function(e) {
$('.ps').append(e.data+"</br>");
console.log("message received: " + e.data);
}
};
function send() {
var msg = document.getElementById('message').value;
sock.send(msg);
};
</script>
<h1>WebSocket Echo Test</h1>
<form>
<p>
Message: <input id="message" type="text" value="Hello, world!">
</p>
</form>
<div style='width:100px,height:200px,border:1px solid red'>
<p class="ps"></p>
</div>
<button onclick="send();">Send Message</button>
服务端的代码
package main
import (
"golang.org/x/net/websocket"
"fmt"
"log"
"net/http"
)
func Echo(ws *websocket.Conn) {
var err error
for {
var reply string
if err = websocket.Message.Receive(ws, &reply); err != nil {
fmt.Println("Can't receive")
break
}
fmt.Println("Received back from client: " + reply)
msg := reply
fmt.Println("Sending to client: " + msg)
if err = websocket.Message.Send(ws, msg); err != nil {
fmt.Println("Can't send")
break
}
}
}
func main() {
http.Handle("/", websocket.Handler(Echo))
if err := http.ListenAndServe(":9999", nil); err != nil {
log.Fatal("ListenAndServe:", err)
}
}
*其中需要注意的是:需下载go的websocket库,因为我本人是用windows系统写的,所以库稍微做了修改
这是windows下的websocket库的下载地址:http://download.csdn.net/detail/qq_35730500/9736074
这是linux下的websocket库的下载地址:http://download.csdn.net/detail/qq_35730500/9736079*
由于官方的库需要在code.google的地址下下载,所以就把他上传
要说的也就这些了!