亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

微信小程序 websocket 實現SpringMVC+Spring+Mybatis

2019-11-19 15:54:19
字體:
來源:轉載
供稿:網友

微信小程序實現websocket步驟:

后臺:

 1. 添加maven依賴 2. 創建握手 3. 創建處理器 4. spring配置(xml配置或javabean方式配置任選一種)

微信小程序:

 1. 書寫連接

java后臺

1.添加maven依賴

 <!-- websocket -->  <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-websocket</artifactId>    <version>${spring.version}</version>  </dependency>  <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-messaging</artifactId>    <version>${spring.version}</version>  </dependency>  <!-- 其中spring版本 -->  <!-- 注意spring版本一定要為4以上版本 -->  <spring.version>4.3.7.RELEASE</spring.version>

2.創建握手

package com.ahutshop.websocket;import java.util.Map;import javax.servlet.http.HttpServletRequest;import org.springframework.http.server.ServerHttpRequest;import org.springframework.http.server.ServerHttpResponse;import org.springframework.http.server.ServletServerHttpRequest;import org.springframework.web.socket.WebSocketHandler;import org.springframework.web.socket.server.HandshakeInterceptor;/** * 此類用來獲取登錄用戶信息并交由websocket管理 */public class MyWebSocketInterceptor implements HandshakeInterceptor {  @Override  public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse arg1, WebSocketHandler arg2,      Map<String, Object> arg3) throws Exception {    // 將ServerHttpRequest轉換成request請求相關的類,用來獲取request域中的用戶信息    if (request instanceof ServletServerHttpRequest) {      ServletServerHttpRequest servletRequest = (ServletServerHttpRequest) request;      HttpServletRequest httpRequest = servletRequest.getServletRequest();    }    System.out.println("連接到我了");    return true;  }  @Override  public void afterHandshake(ServerHttpRequest arg0, ServerHttpResponse arg1, WebSocketHandler arg2, Exception arg3) {    // TODO Auto-generated method stub  }}

3.創建處理器

package com.ahutshop.websocket;import java.io.IOException;import java.util.ArrayList;import java.util.List;import org.springframework.web.socket.CloseStatus;import org.springframework.web.socket.TextMessage;import org.springframework.web.socket.WebSocketHandler;import org.springframework.web.socket.WebSocketMessage;import org.springframework.web.socket.WebSocketSession;public class WebSocketPushHandler implements WebSocketHandler {  private static final List<WebSocketSession> users = new ArrayList<>();  // 用戶進入系統監聽  @Override  public void afterConnectionEstablished(WebSocketSession session) throws Exception {    System.out.println("成功進入了系統。。。");    users.add(session);    sendMessagesToUsers(new TextMessage("今天晚上服務器維護,請注意"));  }  //  @Override  public void handleMessage(WebSocketSession session, WebSocketMessage<?> message) throws Exception {    // 將消息進行轉化,因為是消息是json數據,可能里面包含了發送給某個人的信息,所以需要用json相關的工具類處理之后再封裝成TextMessage,    // 我這兒并沒有做處理,消息的封裝格式一般有{from:xxxx,to:xxxxx,msg:xxxxx},來自哪里,發送給誰,什么消息等等    // TextMessage msg = (TextMessage)message.getPayload();    // 給所有用戶群發消息    //sendMessagesToUsers(msg);    // 給指定用戶群發消息    //sendMessageToUser(userId, msg);  }  // 后臺錯誤信息處理方法  @Override  public void handleTransportError(WebSocketSession session, Throwable exception) throws Exception {  }  // 用戶退出后的處理,不如退出之后,要將用戶信息從websocket的session中remove掉,這樣用戶就處于離線狀態了,也不會占用系統資源  @Override  public void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus) throws Exception {    if (session.isOpen()) {      session.close();    }    users.remove(session);    System.out.println("安全退出了系統");  }  @Override  public boolean supportsPartialMessages() {    return false;  }  /**   * 給所有的用戶發送消息   */  public void sendMessagesToUsers(TextMessage message) {    for (WebSocketSession user : users) {      try {        // isOpen()在線就發送        if (user.isOpen()) {          user.sendMessage(message);        }      } catch (IOException e) {        e.printStackTrace();      }    }  }  /**   * 發送消息給指定的用戶   */  public void sendMessageToUser(String userId, TextMessage message) {    for (WebSocketSession user : users) {      if (user.getAttributes().get("").equals(userId)) {        try {          // isOpen()在線就發送          if (user.isOpen()) {            user.sendMessage(message);          }        } catch (IOException e) {          e.printStackTrace();        }      }    }  }}

4.spring配置

javabean方式配置(推薦)package com.ahutshop.websocket;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;import org.springframework.web.socket.WebSocketHandler;import org.springframework.web.socket.config.annotation.EnableWebSocket;import org.springframework.web.socket.config.annotation.WebSocketConfigurer;import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;@Configuration@EnableWebSocketpublic class WebSocketConfig extends WebMvcConfigurerAdapter implements WebSocketConfigurer {  @Override  public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {    registry.addHandler(WebSocketPushHandler(), "/webSocketServer.action").addInterceptors(new MyWebSocketInterceptor()).setAllowedOrigins("*");    registry.addHandler(WebSocketPushHandler(), "/sockjs/webSocketServer.action")        .addInterceptors(new MyWebSocketInterceptor()).withSockJS();  }  @Bean  public WebSocketHandler WebSocketPushHandler() {    return new WebSocketPushHandler();  }}spring.xml中配置掃描包<!-- 掃描包 --><context:component-scan base-package="com.ahutshop.websocket" />

注意:

1. /webSocketServer.action之所以要加上.action的后綴,是因為web.xmlk中配置了攔截的后綴名為.action

<!-- springmvc模塊 --><servlet>  <servlet-name>DispatcherServlet</servlet-name>  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  <init-param>    <param-name>contextConfigLocation</param-name>    <param-value>classpath:springmvc.xml</param-value>  </init-param>  <load-on-startup>1</load-on-startup>  <!-- 支持異步 -->  <async-supported>true</async-supported></servlet><servlet-mapping>  <servlet-name>DispatcherServlet</servlet-name>  <url-pattern>*.action</url-pattern> </servlet-mapping>

2 .setAllowedOrigins(“*”)中的*代表合法的請求域名,該方法接受一個可變數組作為參數,一定要配置,不然會請求時會出現403

xml方式配置(省略)

微信小程序

1.websocket.wxml

<!--pages/websocket/websocket.wxml--><view class="page"> <view class="page__hd"> </view> <view class="page__bd"> <button bindtap="connectWebsocket" type="primary">連接websocket</button> </view></view>

2.websocket.js

// pages/websocket/websocket.jsPage({ /**  * 頁面的初始數據  */ data: { }, connectWebsocket: function () {  wx.connectSocket({   url: 'ws://localhost:8080/AhutShop/webSocketServer.action',   data: {   },   header: {    'content-type': 'application/json'   },   method: "GET"  })  wx.onSocketOpen(function (res) {   console.log('WebSocket連接已打開!')  })  wx.onSocketError(function (res) {   console.log('WebSocket連接打開失敗,請檢查!')  })  wx.onSocketMessage(function (res) {   console.log('收到服務器內容:' + res.data)  }) }})

運行效果

以上就是微信小程序 后臺的建立,如有疑問請留言或者到本站社區交流討論,本站關于微信小程序的文章還有很多,希望大家多多搜索查閱,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕日韩在线视频| 精品国产自在精品国产浪潮| 伊人激情综合网| 欧美资源在线观看| 亚洲在线免费看| 亚洲成人黄色在线| 在线观看精品国产视频| 亚洲亚裔videos黑人hd| 亚洲va欧美va国产综合久久| 欧美亚洲午夜视频在线观看| 成人免费网站在线看| 久久99亚洲热视| 国产精品视频网站| 国内精品久久久久影院 日本资源| 亚洲激情电影中文字幕| 91沈先生在线观看| 日韩中文字幕视频在线观看| 亚洲色图校园春色| 国产欧美精品一区二区三区介绍| 日韩欧美在线中文字幕| 久久影院免费观看| 久久久久久12| 日韩电影在线观看免费| 国产小视频91| 亚洲国产日韩欧美综合久久| 日韩av综合中文字幕| 国产日韩欧美另类| 欧美日韩在线观看视频| 亚洲成人国产精品| 91高清视频在线免费观看| 亚洲片国产一区一级在线观看| 91国产美女视频| 欧美疯狂做受xxxx高潮| 欧美成人性生活| 国产精品美乳一区二区免费| 欧美另类高清videos| 成人激情综合网| 中文字幕自拍vr一区二区三区| 国产亚洲精品美女久久久| 影音先锋日韩有码| 亚洲成年网站在线观看| 久久久国产91| 清纯唯美日韩制服另类| 欧美日韩色婷婷| 国产精品va在线播放我和闺蜜| 国产精品久久久久久五月尺| 欧美一区二三区| 日日摸夜夜添一区| 亚洲片国产一区一级在线观看| 欧美成人免费网| 亚洲精品综合精品自拍| 91精品久久久久久久| 日韩欧美综合在线视频| 久久久视频精品| 亚洲欧美在线第一页| 日韩成人激情在线| 久久九九精品99国产精品| 亚洲精品视频免费在线观看| 成人免费网站在线| 日韩国产在线看| 日韩免费在线观看视频| 欧美精品www| 亚洲欧美日韩久久久久久| 国产成人jvid在线播放| xvideos成人免费中文版| 中文字幕日韩免费视频| 91中文字幕在线| 日韩成人在线视频| 久久综合电影一区| 国产suv精品一区二区| 欧美精品成人在线| 中文字幕国产亚洲2019| 在线精品播放av| 在线观看国产精品91| 日韩视频在线免费| 美女扒开尿口让男人操亚洲视频网站| 97色在线视频观看| 日韩欧美一区二区三区| 美女av一区二区三区| 欧美激情日韩图片| 精品久久久久久中文字幕大豆网| 久久久久久久久久国产精品| 精品国产999| 少妇精69xxtheporn| 国产精品中文字幕在线观看| 这里只有精品在线播放| 亚洲自拍偷拍色图| 亚洲精品国产suv| 精品国产一区二区三区在线观看| 亚洲999一在线观看www| 在线观看日韩专区| 欧美精品www在线观看| 欧美日韩中文字幕| 黑人巨大精品欧美一区二区一视频| 日韩欧美亚洲一二三区| 国产亚洲精品91在线| 一区二区三区四区在线观看视频| 视频在线观看一区二区| 国产精品久久久久久五月尺| 欧美天堂在线观看| 久久久久久久国产精品视频| 高清一区二区三区日本久| 日韩电影免费在线观看中文字幕| 热99精品里视频精品| 欧美性xxxx18| 一区二区国产精品视频| 久久国产精品久久久久久久久久| 欧美在线免费看| 成人午夜激情免费视频| 国产在线精品播放| 欧美日韩国产在线看| 日韩在线观看精品| 久久久国产精品免费| 成人情趣片在线观看免费| 欧美日韩一区二区三区在线免费观看| 成人欧美一区二区三区黑人孕妇| 日韩精品极品在线观看| 日韩精品在线视频| 欧美中文在线字幕| 91免费电影网站| 国内外成人免费激情在线视频网站| 国产ts一区二区| 亚洲国产精品推荐| 深夜福利一区二区| 欧美午夜精品在线| 欧美亚洲国产精品| 国产精品福利片| 丁香五六月婷婷久久激情| 欧美精品videosex性欧美| 欧美激情精品久久久久久久变态| 国内精品一区二区三区四区| 精品视频在线播放| 日本国产欧美一区二区三区| 色综合91久久精品中文字幕| 欧美性理论片在线观看片免费| 国产成人精品一区二区| 久久久亚洲影院你懂的| 久久久精品国产| 日本精品久久久久影院| 青青久久av北条麻妃海外网| 日韩av中文字幕在线免费观看| 92看片淫黄大片欧美看国产片| 国产精品视频成人| 欧美野外猛男的大粗鳮| 精品国内自产拍在线观看| 一个色综合导航| 国产精品青青在线观看爽香蕉| 国产精品日日摸夜夜添夜夜av| 亚洲伊人成综合成人网| 精品成人69xx.xyz| 91在线精品视频| 欧美日本啪啪无遮挡网站| 日韩中文在线中文网三级| 国产精品91在线| 亚洲国产成人精品电影| 国产精品视频一| 欧美激情乱人伦一区| 国产欧美久久久久久| 久久夜精品va视频免费观看| 国产999精品久久久影片官网| 欧美激情一级欧美精品| 91社区国产高清| 精品国偷自产在线| 国产亚洲视频中文字幕视频|