spring+websocket整合

java-websocket的搭建非常之容易,没用框架的童鞋可以在这里下载撸主亲自调教好的java-websocket程序:

Apach Tomcat 8.0.3+MyEclipse+maven+JDK1.7

http://download.csdn.net/detail/up19910522/7719087

spring4.0以后加入了对websocket技术的支持,撸主目前的项目用的是SSM(springMVC+spring+MyBatis)框

架,所以肯定要首选spring自带的websocket了,好,现在问题来了,撸主在网上各种狂搜猛找,拼凑了几个自称是

spring websocket的东东,下来一看,废物,其中包括从github上down下来的。举个例子,在搭建过程中有个问题,

撸主上谷歌搜索,总共搜出来三页结果共30条左右,前15条是纯英文的  后15条是韩语和日语,而这30条结果都不能

解决撸主的问题,无奈,只好上官网看全英帮助,在撸主惊人的毅力和不懈奋斗下,纠结了两天的spring+websocket

整合今天算是彻底搭建成功,摸索透彻了。

websocket是目前唯一真正实现全双工通信的服务器向客户端推的互联网技术,与长连接和轮询技术相比,

websocket的优越性不言自明,长连接的连接资源(线程资源)随着连接数量的增多,必会耗尽,客户端轮询会给服

务器造成很大的压力,而websocket是在物理层非网络层建立一条客户端至服务器的长连接,以此来保证服务器向客

户端的即时推送,既不耗费线程资源,又不会不断向服务器轮询请求。

下面言归正传,讲一讲撸主在SSM(springMVC+spring+MyBatis)框架中集成websocket技术的曲折蛋疼直至成功喜悦之路。

  • 1 在maven的pom.xml中加入websocket所依赖的jar包,什么,你不知道maven,快去度之或者查看撸主关于maven的博文恶补一下,spring-websocket所依赖的jar包有以下几个:

[html] view plaincopy

  1. <dependency>
  2. <groupId>javax.servlet</groupId>
  3. <artifactId>javax.servlet-api</artifactId>
  4. <version>3.1.0</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.fasterxml.jackson.core</groupId>
  8. <artifactId>jackson-core</artifactId>
  9. <version>2.3.0</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>com.fasterxml.jackson.core</groupId>
  13. <artifactId>jackson-databind</artifactId>
  14. <version>2.3.0</version>
  15. </dependency>
  16. <dependency>
  17. <groupId>org.springframework</groupId>
  18. <artifactId>spring-websocket</artifactId>
  19. <version>4.0.1.RELEASE</version>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework</groupId>
  23. <artifactId>spring-messaging</artifactId>
  24. <version>4.0.1.RELEASE</version>
  25. </dependency>
  • 2 更新web.xml中namespace.xsd的版本,

[html] view plaincopy

  1. <beans xmlns="http://www.springframework.org/schema/beans"
  2. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns:websocket="http://www.springframework.org/schema/websocket"
  4. xsi:schemaLocation="
  5. http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
  6. http://www.springframework.org/schema/websocket http://www.springframework.org/schema/websocket/spring-websocket.xsd">
  • 3 更新spring框架的jar包至4.0以上(spring-core, spring-context, spring-web and spring-webmvc)

[html] view plaincopy

  1. <dependency>
  2. <span style="white-space:pre">    </span><groupId>org.springframework</groupId>
  3. <artifactId>spring-core</artifactId>
  4. <version>${spring.version}</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework</groupId>
  8. <artifactId>spring-web</artifactId>
  9. <version>${spring.version}</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>org.springframework</groupId>
  13. <artifactId>spring-webmvc</artifactId>
  14. <version>${spring.version}</version>
  15. </dependency>
  16. <dependency>
  17. <groupId>org.springframework</groupId>
  18. <artifactId>spring-context-support</artifactId>
  19. <version>${spring.version}</version>
  20. </dependency>
  • 4  4.1创建websocket处理类

[html] view plaincopy

  1. package com.up.websocket.handler;
  2. import org.springframework.web.socket.TextMessage;
  3. import org.springframework.web.socket.WebSocketSession;
  4. import org.springframework.web.socket.handler.TextWebSocketHandler;
  5. public class WebsocketEndPoint extends TextWebSocketHandler {
  6. @Override
  7. protected void handleTextMessage(WebSocketSession session,
  8. TextMessage message) throws Exception {
  9. super.handleTextMessage(session, message);
  10. TextMessage returnMessage = new TextMessage(message.getPayload()+" received at server");
  11. session.sendMessage(returnMessage);
  12. }
  13. }
  • 4.2创建握手(handshake)接口

[html] view plaincopy

  1. package com.up.websocket;
  2. import java.util.Map;
  3. import org.springframework.http.server.ServerHttpRequest;
  4. import org.springframework.http.server.ServerHttpResponse;
  5. import org.springframework.web.socket.WebSocketHandler;
  6. import org.springframework.web.socket.server.support.HttpSessionHandshakeInterceptor;
  7. public class HandshakeInterceptor extends HttpSessionHandshakeInterceptor{
  8. @Override
  9. public boolean beforeHandshake(ServerHttpRequest request,
  10. ServerHttpResponse response, WebSocketHandler wsHandler,
  11. Map<String, Object> attributes) throws Exception {
  12. System.out.println("Before Handshake");
  13. return super.beforeHandshake(request, response, wsHandler, attributes);
  14. }
  15. @Override
  16. public void afterHandshake(ServerHttpRequest request,
  17. ServerHttpResponse response, WebSocketHandler wsHandler,
  18. Exception ex) {
  19. System.out.println("After Handshake");
  20. super.afterHandshake(request, response, wsHandler, ex);
  21. }
  22. }
  • 5 处理类和握手协议的spring配置(applicationContext.xml文件)

[html] view plaincopy

  1. <bean id="websocket" class="com.up.websocket.handler.WebsocketEndPoint"/>
  2. <websocket:handlers>
  3. <websocket:mapping path="/websocket" handler="websocket"/>
  4. <websocket:handshake-interceptors>
  5. <bean class="com.up.websocket.HandshakeInterceptor"/>
  6. </websocket:handshake-interceptors>
  7. </websocket:handlers>
  • 6 客户端页面

[html] view plaincopy

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>WebSocket/SockJS Echo Sample (Adapted from Tomcat‘s echo sample)</title>
  5. <style type="text/css">
  6. #connect-container {
  7. float: left;
  8. width: 400px
  9. }
  10. #connect-container div {
  11. padding: 5px;
  12. }
  13. #console-container {
  14. float: left;
  15. margin-left: 15px;
  16. width: 400px;
  17. }
  18. #console {
  19. border: 1px solid #CCCCCC;
  20. border-right-color: #999999;
  21. border-bottom-color: #999999;
  22. height: 170px;
  23. overflow-y: scroll;
  24. padding: 5px;
  25. width: 100%;
  26. }
  27. #console p {
  28. padding: 0;
  29. margin: 0;
  30. }
  31. </style>
  32. <script src="http://cdn.sockjs.org/sockjs-0.3.min.js"></script>
  33. <script type="text/javascript">
  34. var ws = null;
  35. var url = null;
  36. var transports = [];
  37. function setConnected(connected) {
  38. document.getElementById(‘connect‘).disabled = connected;
  39. document.getElementById(‘disconnect‘).disabled = !connected;
  40. document.getElementById(‘echo‘).disabled = !connected;
  41. }
  42. function connect() {
  43. alert("url:"+url);
  44. if (!url) {
  45. alert(‘Select whether to use W3C WebSocket or SockJS‘);
  46. return;
  47. }
  48. ws = (url.indexOf(‘sockjs‘) != -1) ?
  49. new SockJS(url, undefined, {protocols_whitelist: transports}) : new WebSocket(url);
  50. ws.onopen = function () {
  51. setConnected(true);
  52. log(‘Info: connection opened.‘);
  53. };
  54. ws.onmessage = function (event) {
  55. log(‘Received: ‘ + event.data);
  56. };
  57. ws.onclose = function (event) {
  58. setConnected(false);
  59. log(‘Info: connection closed.‘);
  60. log(event);
  61. };
  62. }
  63. function disconnect() {
  64. if (ws != null) {
  65. ws.close();
  66. ws = null;
  67. }
  68. setConnected(false);
  69. }
  70. function echo() {
  71. if (ws != null) {
  72. var message = document.getElementById(‘message‘).value;
  73. log(‘Sent: ‘ + message);
  74. ws.send(message);
  75. } else {
  76. alert(‘connection not established, please connect.‘);
  77. }
  78. }
  79. function updateUrl(urlPath) {
  80. if (urlPath.indexOf(‘sockjs‘) != -1) {
  81. url = urlPath;
  82. document.getElementById(‘sockJsTransportSelect‘).style.visibility = ‘visible‘;
  83. }
  84. else {
  85. if (window.location.protocol == ‘http:‘) {
  86. url = ‘ws://‘ + window.location.host + urlPath;
  87. } else {
  88. url = ‘wss://‘ + window.location.host + urlPath;
  89. }
  90. document.getElementById(‘sockJsTransportSelect‘).style.visibility = ‘hidden‘;
  91. }
  92. }
  93. function updateTransport(transport) {
  94. alert(transport);
  95. transports = (transport == ‘all‘) ?  [] : [transport];
  96. }
  97. function log(message) {
  98. var console = document.getElementById(‘console‘);
  99. var p = document.createElement(‘p‘);
  100. p.style.wordWrap = ‘break-word‘;
  101. p.appendChild(document.createTextNode(message));
  102. console.appendChild(p);
  103. while (console.childNodes.length > 25) {
  104. console.removeChild(console.firstChild);
  105. }
  106. console.scrollTop = console.scrollHeight;
  107. }
  108. </script>
  109. </head>
  110. <body>
  111. <noscript><h2 style="color: #ff0000">Seems your browser doesn‘t support Javascript! Websockets
  112. rely on Javascript being enabled. Please enable
  113. Javascript and reload this page!</h2></noscript>
  114. <div>
  115. <div id="connect-container">
  116. <input id="radio1" type="radio" name="group1" onclick="updateUrl(‘‘/spring-websocket-uptest/websocket‘);">
  117. <label for="radio1">W3C WebSocket</label>
  118. <br>
  119. <input id="radio2" type="radio" name="group1" onclick="updateUrl(‘/spring-websocket-uptest/websocket‘);">
  120. <label for="radio2">SockJS</label>
  121. <div id="sockJsTransportSelect" style="visibility:hidden;">
  122. <span>SockJS transport:</span>
  123. <select onchange="updateTransport(this.value)">
  124. <option value="all">all</option>
  125. <option value="websocket">websocket</option>
  126. <option value="xhr-polling">xhr-polling</option>
  127. <option value="jsonp-polling">jsonp-polling</option>
  128. <option value="xhr-streaming">xhr-streaming</option>
  129. <option value="iframe-eventsource">iframe-eventsource</option>
  130. <option value="iframe-htmlfile">iframe-htmlfile</option>
  131. </select>
  132. </div>
  133. <div>
  134. <button id="connect" onclick="connect();">Connect</button>
  135. <button i

    java-websocket的搭建非常之容易,没用框架的童鞋可以在这里下载撸主亲自调教好的java-websocket程序:

    Apach Tomcat 8.0.3+MyEclipse+maven+JDK1.7

    http://download.csdn.net/detail/up19910522/7719087

    spring4.0以后加入了对websocket技术的支持,撸主目前的项目用的是SSM(springMVC+spring+MyBatis)框

    架,所以肯定要首选spring自带的websocket了,好,现在问题来了,撸主在网上各种狂搜猛找,拼凑了几个自称是

    spring websocket的东东,下来一看,废物,其中包括从github上down下来的。举个例子,在搭建过程中有个问题,

    撸主上谷歌搜索,总共搜出来三页结果共30条左右,前15条是纯英文的  后15条是韩语和日语,而这30条结果都不能

    解决撸主的问题,无奈,只好上官网看全英帮助,在撸主惊人的毅力和不懈奋斗下,纠结了两天的spring+websocket

    整合今天算是彻底搭建成功,摸索透彻了。

    websocket是目前唯一真正实现全双工通信的服务器向客户端推的互联网技术,与长连接和轮询技术相比,

    websocket的优越性不言自明,长连接的连接资源(线程资源)随着连接数量的增多,必会耗尽,客户端轮询会给服

    务器造成很大的压力,而websocket是在物理层非网络层建立一条客户端至服务器的长连接,以此来保证服务器向客

    户端的即时推送,既不耗费线程资源,又不会不断向服务器轮询请求。

    下面言归正传,讲一讲撸主在SSM(springMVC+spring+MyBatis)框架中集成websocket技术的曲折蛋疼直至成功喜悦之路。

    • 1 在maven的pom.xml中加入websocket所依赖的jar包,什么,你不知道maven,快去度之或者查看撸主关于maven的博文恶补一下,spring-websocket所依赖的jar包有以下几个:

    [html] view plaincopy

    1. <dependency>
    2. <groupId>javax.servlet</groupId>
    3. <artifactId>javax.servlet-api</artifactId>
    4. <version>3.1.0</version>
    5. </dependency>
    6. <dependency>
    7. <groupId>com.fasterxml.jackson.core</groupId>
    8. <artifactId>jackson-core</artifactId>
    9. <version>2.3.0</version>
    10. </dependency>
    11. <dependency>
    12. <groupId>com.fasterxml.jackson.core</groupId>
    13. <artifactId>jackson-databind</artifactId>
    14. <version>2.3.0</version>
    15. </dependency>
    16. <dependency>
    17. <groupId>org.springframework</groupId>
    18. <artifactId>spring-websocket</artifactId>
    19. <version>4.0.1.RELEASE</version>
    20. </dependency>
    21. <dependency>
    22. <groupId>org.springframework</groupId>
    23. <artifactId>spring-messaging</artifactId>
    24. <version>4.0.1.RELEASE</version>
    25. </dependency>
    • 2 更新web.xml中namespace.xsd的版本,

    [html] view plaincopy

    1. <beans xmlns="http://www.springframework.org/schema/beans"
    2. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    3. xmlns:websocket="http://www.springframework.org/schema/websocket"
    4. xsi:schemaLocation="
    5. http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    6. http://www.springframework.org/schema/websocket http://www.springframework.org/schema/websocket/spring-websocket.xsd">
    • 3 更新spring框架的jar包至4.0以上(spring-core, spring-context, spring-web and spring-webmvc)

    [html] view plaincopy

    1. <dependency>
    2. <span style="white-space:pre">    </span><groupId>org.springframework</groupId>
    3. <artifactId>spring-core</artifactId>
    4. <version>${spring.version}</version>
    5. </dependency>
    6. <dependency>
    7. <groupId>org.springframework</groupId>
    8. <artifactId>spring-web</artifactId>
    9. <version>${spring.version}</version>
    10. </dependency>
    11. <dependency>
    12. <groupId>org.springframework</groupId>
    13. <artifactId>spring-webmvc</artifactId>
    14. <version>${spring.version}</version>
    15. </dependency>
    16. <dependency>
    17. <groupId>org.springframework</groupId>
    18. <artifactId>spring-context-support</artifactId>
    19. <version>${spring.version}</version>
    20. </dependency>
    • 4  4.1创建websocket处理类

    [html] view plaincopy

    1. package com.up.websocket.handler;
    2. import org.springframework.web.socket.TextMessage;
    3. import org.springframework.web.socket.WebSocketSession;
    4. import org.springframework.web.socket.handler.TextWebSocketHandler;
    5. public class WebsocketEndPoint extends TextWebSocketHandler {
    6. @Override
    7. protected void handleTextMessage(WebSocketSession session,
    8. TextMessage message) throws Exception {
    9. super.handleTextMessage(session, message);
    10. TextMessage returnMessage = new TextMessage(message.getPayload()+" received at server");
    11. session.sendMessage(returnMessage);
    12. }
    13. }
    • 4.2创建握手(handshake)接口

    [html] view plaincopy

    1. package com.up.websocket;
    2. import java.util.Map;
    3. import org.springframework.http.server.ServerHttpRequest;
    4. import org.springframework.http.server.ServerHttpResponse;
    5. import org.springframework.web.socket.WebSocketHandler;
    6. import org.springframework.web.socket.server.support.HttpSessionHandshakeInterceptor;
    7. public class HandshakeInterceptor extends HttpSessionHandshakeInterceptor{
    8. @Override
    9. public boolean beforeHandshake(ServerHttpRequest request,
    10. ServerHttpResponse response, WebSocketHandler wsHandler,
    11. Map<String, Object> attributes) throws Exception {
    12. System.out.println("Before Handshake");
    13. return super.beforeHandshake(request, response, wsHandler, attributes);
    14. }
    15. @Override
    16. public void afterHandshake(ServerHttpRequest request,
    17. ServerHttpResponse response, WebSocketHandler wsHandler,
    18. Exception ex) {
    19. System.out.println("After Handshake");
    20. super.afterHandshake(request, response, wsHandler, ex);
    21. }
    22. }
    • 5 处理类和握手协议的spring配置(applicationContext.xml文件)

    [html] view plaincopy

    1. <bean id="websocket" class="com.up.websocket.handler.WebsocketEndPoint"/>
    2. <websocket:handlers>
    3. <websocket:mapping path="/websocket" handler="websocket"/>
    4. <websocket:handshake-interceptors>
    5. <bean class="com.up.websocket.HandshakeInterceptor"/>
    6. </websocket:handshake-interceptors>
    7. </websocket:handlers>
    • 6 客户端页面

    [html] view plaincopy

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <title>WebSocket/SockJS Echo Sample (Adapted from Tomcat‘s echo sample)</title>
    5. <style type="text/css">
    6. #connect-container {
    7. float: left;
    8. width: 400px
    9. }
    10. #connect-container div {
    11. padding: 5px;
    12. }
    13. #console-container {
    14. float: left;
    15. margin-left: 15px;
    16. width: 400px;
    17. }
    18. #console {
    19. border: 1px solid #CCCCCC;
    20. border-right-color: #999999;
    21. border-bottom-color: #999999;
    22. height: 170px;
    23. overflow-y: scroll;
    24. padding: 5px;
    25. width: 100%;
    26. }
    27. #console p {
    28. padding: 0;
    29. margin: 0;
    30. }
    31. </style>
    32. <script src="http://cdn.sockjs.org/sockjs-0.3.min.js"></script>
    33. <script type="text/javascript">
    34. var ws = null;
    35. var url = null;
    36. var transports = [];
    37. function setConnected(connected) {
    38. document.getElementById(‘connect‘).disabled = connected;
    39. document.getElementById(‘disconnect‘).disabled = !connected;
    40. document.getElementById(‘echo‘).disabled = !connected;
    41. }
    42. function connect() {
    43. alert("url:"+url);
    44. if (!url) {
    45. alert(‘Select whether to use W3C WebSocket or SockJS‘);
    46. return;
    47. }
    48. ws = (url.indexOf(‘sockjs‘) != -1) ?
    49. new SockJS(url, undefined, {protocols_whitelist: transports}) : new WebSocket(url);
    50. ws.onopen = function () {
    51. setConnected(true);
    52. log(‘Info: connection opened.‘);
    53. };
    54. ws.onmessage = function (event) {
    55. log(‘Received: ‘ + event.data);
    56. };
    57. ws.onclose = function (event) {
    58. setConnected(false);
    59. log(‘Info: connection closed.‘);
    60. log(event);
    61. };
    62. }
    63. function disconnect() {
    64. if (ws != null) {
    65. ws.close();
    66. ws = null;
    67. }
    68. setConnected(false);
    69. }
    70. function echo() {
    71. if (ws != null) {
    72. var message = document.getElementById(‘message‘).value;
    73. log(‘Sent: ‘ + message);
    74. ws.send(message);
    75. } else {
    76. alert(‘connection not established, please connect.‘);
    77. }
    78. }
    79. function updateUrl(urlPath) {
    80. if (urlPath.indexOf(‘sockjs‘) != -1) {
    81. url = urlPath;
    82. document.getElementById(‘sockJsTransportSelect‘).style.visibility = ‘visible‘;
    83. }
    84. else {
    85. if (window.location.protocol == ‘http:‘) {
    86. url = ‘ws://‘ + window.location.host + urlPath;
    87. } else {
    88. url = ‘wss://‘ + window.location.host + urlPath;
    89. }
    90. document.getElementById(‘sockJsTransportSelect‘).style.visibility = ‘hidden‘;
    91. }
    92. }
    93. function updateTransport(transport) {
    94. alert(transport);
    95. transports = (transport == ‘all‘) ?  [] : [transport];
    96. }
    97. function log(message) {
    98. var console = document.getElementById(‘console‘);
    99. var p = document.createElement(‘p‘);
    100. p.style.wordWrap = ‘break-word‘;
    101. p.appendChild(document.createTextNode(message));
    102. console.appendChild(p);
    103. while (console.childNodes.length > 25) {
    104. console.removeChild(console.firstChild);
    105. }
    106. console.scrollTop = console.scrollHeight;
    107. }
    108. </script>
    109. </head>
    110. <body>
    111. <noscript><h2 style="color: #ff0000">Seems your browser doesn‘t support Javascript! Websockets
    112. rely on Javascript being enabled. Please enable
    113. Javascript and reload this page!</h2></noscript>
    114. <div>
    115. <div id="connect-container">
    116. <input id="radio1" type="radio" name="group1" onclick="updateUrl(‘‘/spring-websocket-uptest/websocket‘);">
    117. <label for="radio1">W3C WebSocket</label>
    118. <br>
    119. <input id="radio2" type="radio" name="group1" onclick="updateUrl(‘/spring-websocket-uptest/websocket‘);">
    120. <label for="radio2">SockJS</label>
    121. <div id="sockJsTransportSelect" style="visibility:hidden;">
    122. <span>SockJS transport:</span>
    123. <select onchange="updateTransport(this.value)">
    124. <option value="all">all</option>
    125. <option value="websocket">websocket</option>
    126. <option value="xhr-polling">xhr-polling</option>
    127. <option value="jsonp-polling">jsonp-polling</option>
    128. <option value="xhr-streaming">xhr-streaming</option>
    129. <option value="iframe-eventsource">iframe-eventsource</option>
    130. <option value="iframe-htmlfile">iframe-htmlfile</option>
    131. </select>
    132. </div>
    133. <div>
    134. <button id="connect" onclick="connect();">Connect</button>
    135. <button id="disconnect" disabled="disabled" onclick="disconnect();">Disconnect</button>
    136. </div>
    137. <div>
    138. <textarea id="message" style="width: 350px">Here is a message!</textarea>
    139. </div>
    140. <div>
    141. <button id="echo" onclick="echo();" disabled="disabled">Echo message</button>
    142. </div>
    143. </div>
    144. <div id="console-container">
    145. <div id="console"></div>
    146. </div>
    147. </div>
    148. </body>
    149. </html>
      • 7  按照以上步骤搭建,根据个人开发环境不同,可能会出现各种问题,下面将在整个搭建过程中遇到的问题总结一下,详见博文:http://blog.csdn.net/gisredevelopment/article/details/38397569

    d="disconnect" disabled="disabled" onclick="disconnect();">Disconnect</button>

  136. </div>
  137. <div>
  138. <textarea id="message" style="width: 350px">Here is a message!</textarea>
  139. </div>
  140. <div>
  141. <button id="echo" onclick="echo();" disabled="disabled">Echo message</button>
  142. </div>
  143. </div>
  144. <div id="console-container">
  145. <div id="console"></div>
  146. </div>
  147. </div>
  148. </body>
  149. </html>
    • 7  按照以上步骤搭建,根据个人开发环境不同,可能会出现各种问题,下面将在整个搭建过程中遇到的问题总结一下,详见博文:http://blog.csdn.net/gisredevelopment/article/details/38397569
时间: 2024-10-08 09:28:09

spring+websocket整合的相关文章

spring+websocket整合(springMVC+spring+MyBatis即SSM框架)

spring4.0以后加入了对websocket技术的支持,撸主目前的项目用的是SSM(springMVC+spring+MyBatis)框 架,所以肯定要首选spring自带的websocket了,好,现在问题来了,撸主在网上各种狂搜猛找,拼凑了几个自称是 spring websocket的东东,下来一看,废物,其中包括从github上down下来的.举个例子,在搭建过程中有个问题, 撸主上谷歌搜索,总共搜出来三页结果共30条左右,前15条是纯英文的  后15条是韩语和日语,而这30条结果都不

spring+websocket整合(springMVC+spring+MyBatis即SSM框架和websocket技术的整合)

java-websocket的搭建非常之容易,没用框架的童鞋可以在这里下载撸主亲自调教好的java-websocket程序: Apach Tomcat 8.0.3+MyEclipse+maven+JDK1.7 spring4.0以后加入了对websocket技术的支持,撸主目前的项目用的是SSM(springMVC+spring+MyBatis)框架,所 以肯定要首选spring自带的websocket了,好,现在问题来了,撸主在网上各种狂搜猛找,拼凑了几个自称是spring websocket

spring+websocket综合(springMVC+spring+MyBatis这是SSM框架和websocket集成技术)

java-websocket该建筑是easy.儿童无用的框架可以在这里下载主线和个人教学好java-websocket计划: Apach Tomcat 8.0.3+MyEclipse+maven+JDK1.7: http://download.csdn.net/detail/up19910522/7719087 spring4.0以后增加了对websocket技术的支持,撸主眼下的项目用的是SSM(springMVC+spring+MyBatis)框 架,所以肯定要首选spring自带的webs

spring+hibernate整合:报错org.hibernate.HibernateException: No Session found for current thread

spring+hibernate整合:报错信息如下 org.hibernate.HibernateException: No Session found for current thread at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:106) at org.hibernate.internal.SessionFactoryImpl.getC

Spring Boot 整合JSP之Hello World

Spring Boot 整合JSP之Hello World 前半部分译自https://hellokoding.com/spring-boot-hello-world-example-with-jsp/ 其实原文已经相当简单了. 本教程手把手教你如何使用SpringBoot 和 JSP来创建一个Hello World的web app样例程序. 你想要的 你所需要的 JDK 8+ or OpenJDK 8+ Maven 3+ 初始化项目结构和依赖 项目结构 ├── src │ └── main │

spring boot 整合 quartz 集群环境 实现 动态定时任务配置【原】

最近做了一个spring boot 整合 quartz  实现 动态定时任务配置,在集群环境下运行的 任务.能够对定时任务,动态的进行增删改查,界面效果图如下: 1. 在项目中引入jar 2. 将需要的表导入数据库 官网上有不同数据库的脚本,找到对应的,导入即可 3. java 代码 将quartz 的相关配置文件,配置为暴露bean,方便后期引用. 有一处关键的地方,就是注入spring 上下文,也可以算是一个坑.如果,不注入spring 上下文,那么新添加的定时任务job,是新new 的一个

Spring与Struts2整合VS Spring与Spring MVC整合

Spring与Struts2整合,struts.xml在src目录下 1.在web.xml配置监听器 web.xml <!-- 配置Spring的用于初始化ApplicationContext的监听器 --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <contex

Spring Websocket配置

实现的版本jdk1.7.0_25, tomcat7.0.47.0, Tengine/2.1.1 (nginx/1.6.2), servlet3.0, spring4.2.2 使用maven导入版本3.0+的servlet包: <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>3.0-alpha-1<

struts2+hibernate-jpa+Spring+maven 整合(2)

之前的一篇已经讲到了 spring 与struts2 的整合, 其实对于struts2+hibernate-jpa+Spring 之间的整合的文章已经相当多了, 也相当成熟了,只要不是各自的版本不兼容之外,其他的几乎没啥问题, 不行mybatis那样是不是的冒点让人头疼的事情来 下面修改pom.xml ,把hibernate 的jar 关联进来; <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="