溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用webSocket需要注意什么

發(fā)布時間:2021-09-13 18:19:14 來源:億速云 閱讀:261 作者:小新 欄目:大數(shù)據(jù)

這篇文章將為大家詳細(xì)講解有關(guān)使用webSocket需要注意什么,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1. 什么是webSocket

一種網(wǎng)絡(luò)通信協(xié)議,是 HTML5 開始提供的一種在單個 TCP 連接上進(jìn)行全雙工通訊的協(xié)議。

  • HTTP 協(xié)議的缺陷:通信只能由客戶端發(fā)起,且服務(wù)端不能主動向客戶端發(fā)送資源。

  • 如果想要知道服務(wù)端是否準(zhǔn)備好資源,只有采用輪詢方式請求,浪費(fèi)資源(因?yàn)楸仨毑煌_B接,或者 HTTP 連接始終打開), websocket正是解決了這一問題,可以實(shí)現(xiàn)雙向通信。

  • WebSocket目前支持兩種統(tǒng)一資源標(biāo)志符wswss,類似于HTTP和HTTPS,主要是加密與非加密的兩種協(xié)議。

  • 一圖看懂HTTP與webSocket的原理區(qū)別:

使用webSocket需要注意什么

2. webSocket的注解及使用

  • 常用注解:

@ServerEndpoint(value = "/webSocketProxy/{nickName}")

表示一個URI映射的路徑,標(biāo)準(zhǔn)的restfulAPI,{nickName}為路徑參數(shù)。用于注解于類上。

@OnOpen     @OnMessage     @OnClose      @OnError

以上四個注解用于方法上,分別對應(yīng)不同的事件:打開連接、收到消息、連接關(guān)閉、發(fā)生錯誤。當(dāng)發(fā)生對應(yīng)事件時,該方法將會被觸發(fā)。通常開發(fā)中主要在@OnMessage方法內(nèi)進(jìn)行業(yè)務(wù)開發(fā)。

@PathParam("nickName")

此注解用于獲取路徑參數(shù){nickName}。

  • 五種連接狀態(tài):

NOT_YET_CONNECTED, CONNECTING, OPEN, CLOSING, CLOSED;
  • 服務(wù)端的簡單實(shí)例

@ServerEndpoint(value = "/customWebSocket/{nickName}")
@Component
@Slf4j
public class CustomWebSocket {

	// 用來存放每個客戶端對應(yīng)的MyWebSocket對象 全局對象
	private static CopyOnWriteArraySet<CustomWebSocket> user = new CopyOnWriteArraySet<CustomWebSocket>();
	// 與某個客戶端的連接會話,需要通過它來給客戶端發(fā)送數(shù)據(jù)
	private Session session;

	@OnMessage
	public void onMessage(String message, Session session, @PathParam("nickName") String nickName) throws IOException {
		// 群發(fā)消息
		for (CustomWebSocket myWebSocket : user) {
			log.info("請求url:" + session.getRequestURI());
			myWebSocket.session.getBasicRemote().sendText(nickName + " :" + message);
			log.info("custom 收到消息:" + nickName + " :" + message);
		}
	}

	@OnOpen
	public void onOpen(Session session) {
		log.info("custom " + session.getId() + " open...");
		this.session = session;
		user.add(this);
	}

	@OnClose
	public void onClose() {
		System.out.println("custom " + this.session.getId() + " close...");
		session=null;
		user.remove(this);
	}

	@OnError
	public void onError(Session session, Throwable error) {
		session=null;
		log.warn("custom " + this.session.getId() + " error...",error);
	}

3. WebSocket的注意事項

  • WebSocket服務(wù)端 由spring管理后,默認(rèn)是單例,但是對于WebSocket對象,每個連接會新建一個對象,
    因此需要注意static關(guān)鍵字的優(yōu)雅使用。一個session對應(yīng)一個會話。


  • 特別注意這段代碼,使用了static 修飾是類屬性,用來存儲所有連接的客戶端信息。
     static CopyOnWriteArraySet<CustomWebSocket> user = new CopyOnWriteArraySet<CustomWebSocket>();


  • 如果報錯:The remote endpoint was in state [TEXT_FULL_WRITING] which is an invalid state for called method,則是存在多線程并發(fā)發(fā)送消息的情況。采用同步機(jī)制即可。

synchronized (session){
    session.getBasicRemote().sendText(JSON.toJSONString(message));
}

關(guān)于“使用webSocket需要注意什么”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI