im
This commit is contained in:
@@ -3,7 +3,6 @@ package im
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"git.rosy.net.cn/baseapi/utils"
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
@@ -33,40 +32,19 @@ func Init() {
|
|||||||
fmt.Printf("服务器启动成功,端口号:%s\n", CommonSetting.HttpPort)
|
fmt.Printf("服务器启动成功,端口号:%s\n", CommonSetting.HttpPort)
|
||||||
}
|
}
|
||||||
|
|
||||||
func StartWebSocket(w http.ResponseWriter, r *http.Request) {
|
var upgrader = websocket.Upgrader{}
|
||||||
|
|
||||||
conn, err := (&websocket.Upgrader{
|
func StartWebSocket(conn *websocket.Conn, clientID string, err error) {
|
||||||
ReadBufferSize: 8182,
|
|
||||||
WriteBufferSize: 8182,
|
|
||||||
// 允许所有CORS跨域请求
|
|
||||||
CheckOrigin: func(r *http.Request) bool {
|
|
||||||
return true
|
|
||||||
},
|
|
||||||
}).Upgrade(w, r, nil)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
globals.SugarLogger.Errorf("upgrade error: %v", err)
|
|
||||||
http.NotFound(w, r)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
//设置读取消息大小上线
|
//设置读取消息大小上线
|
||||||
conn.SetReadLimit(maxMessageSize)
|
conn.SetReadLimit(maxMessageSize)
|
||||||
|
|
||||||
clientId := ""
|
clientSocket := NewClient(clientID, conn)
|
||||||
temp := r.Header["Clientid"]
|
|
||||||
if temp[0] != "" {
|
|
||||||
clientId = temp[0]
|
|
||||||
} else {
|
|
||||||
clientId = "defaultClientIDJXCS"
|
|
||||||
}
|
|
||||||
|
|
||||||
clientSocket := NewClient(clientId, conn)
|
|
||||||
|
|
||||||
//读取客户端消息
|
//读取客户端消息
|
||||||
clientSocket.Read()
|
clientSocket.Read()
|
||||||
|
|
||||||
if err = ConnRender(conn, renderData{ClientId: clientId}); err != nil {
|
if err = ConnRender(conn, renderData{ClientId: clientID}); err != nil {
|
||||||
_ = conn.Close()
|
_ = conn.Close()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,10 @@ package controllers
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"git.rosy.net.cn/jx-callback/globals"
|
||||||
|
|
||||||
"git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
"git.rosy.net.cn/jx-callback/business/partner/purchase/im"
|
||||||
"github.com/astaxie/beego/server/web"
|
"github.com/astaxie/beego/server/web"
|
||||||
)
|
)
|
||||||
@@ -16,7 +20,17 @@ type IMController struct {
|
|||||||
// @Failure 200 {object} controllers.CallResult
|
// @Failure 200 {object} controllers.CallResult
|
||||||
// @router /StartWebSocket [get]
|
// @router /StartWebSocket [get]
|
||||||
func (c *IMController) StartWebSocket() {
|
func (c *IMController) StartWebSocket() {
|
||||||
im.StartWebSocket(c.Ctx.ResponseWriter, c.Ctx.Request)
|
upgrader.CheckOrigin = func(r *http.Request) bool {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
ws, err := upgrader.Upgrade(c.Ctx.ResponseWriter, c.Ctx.Request, nil)
|
||||||
|
if err != nil {
|
||||||
|
globals.SugarLogger.Errorf("upgrade error: %v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
clientID := c.GetString("clientID")
|
||||||
|
globals.SugarLogger.Debugf("clientID=%s", clientID)
|
||||||
|
im.StartWebSocket(ws, clientID, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Title IM获取门店用户聊天列表
|
// @Title IM获取门店用户聊天列表
|
||||||
|
|||||||
Reference in New Issue
Block a user