公司新项目需要用websockt做及时通讯,golang语言,看了下websocket的库,选用使用人数比较多的gorilla/websocket
Gin框架是一个用Go语言编写的轻量级Web框架,而gorilla/websocket是Go语言中用于处理WebSocket的库。结合这两者可以实现在Gin应用中添加WebSocket功能。以下是一个简单的例子,演示了如何在Gin应用中使用gorilla/websocket。
go get -u github.com/gin-gonic/gin
go get -u github.com/gorilla/websocket
package main
import (
"log"
"net/http"
"github.com/gin-gonic/gin"
"github.com/gorilla/websocket"
)
var upgrader = websocket.Upgrader{
CheckOrigin: func(r *http.Request) bool {
// 在这里进行权限验证,返回true表示验证通过,允许连接
// 你可以根据需要实现自己的验证逻辑
return true
},
}
func main() {
r := gin.Default()
// 提供一个HTTP端点用于升级连接为WebSocket
r.GET("/ws", func(c *gin.Context) {
serveWebSocket(c.Writer, c.Request)
})
r.Run(":8080")
}
func serveWebSocket(w http.ResponseWriter, r *http.Request) {
conn, err := upgrader.Upgrade(w, r, nil)
if err != nil {
log.Println(err)
return
}
defer conn.Close()
for {
// 读取客户端发送的消息
messageType, p, err := conn.ReadMessage()
if err != nil {
log.Println(err)
return
}
// 将消息原样发送回客户端
err = conn.WriteMessage(messageType, p)
if err != nil {
log.Println(err)
return
}
}
}
Ctool 程序开发常用工具
4. 后续根据需要调整业务代码就可以了,如果需要wss,可以结合nginx ssl证书进行升级
···
server {
listen 443 ssl;
server_name your_domain.com;
ssl_certificate /path/to/your_cert.crt;
ssl_certificate_key /path/to/your_private_key.key;
location / {
proxy_pass http://127.0.0.1:8080; # 这里是你的Gin应用的地址和端口
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
}
}
···
在上述Nginx配置中,已经包含了HTTPS的设置。确保使用正确的证书和私钥文件路径,并将域名和端口替换为你的实际值。
部署Gin应用和Nginx配置。
测试WebSocket连接是否正常,确保Nginx能够正确地将WebSocket握手流量传递到Gin应用。
测试HTTPS连接,确保Nginx能够正确地处理HTTPS请求并将流量传递给Gin应用。
请注意:在生产环境中,确保证书的安全性,使用由受信任的证书颁发机构签发的证书,并定期更新证书。对于WebSocket权限验证,根据实际需求修改Gin应用中的验证逻辑。