spring+websocket整合

时间:2022-09-13 11:41:18

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包有以下几个:
  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的版本,
  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)
  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处理类
  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)接口
  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文件)
  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 客户端页面
  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包有以下几个:
    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的版本,
    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)
    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处理类
    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)接口
    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文件)
    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 客户端页面
    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

spring+websocket整合的更多相关文章

  1. spring&plus;websocket综合(springMVC&plus;spring&plus;MyBatis这是SSM框架和websocket集成技术)

    java-websocket该建筑是easy.儿童无用的框架可以在这里下载主线和个人教学好java-websocket计划: Apach Tomcat 8.0.3+MyEclipse+maven+JD ...

  2. 【Java Web开发学习】Spring MVC整合WebSocket通信

    Spring MVC整合WebSocket通信 目录 ========================================================================= ...

  3. spring&plus;websocket的整合实例--可使用

    spring+websocket的整合实例----借鉴如下链接--此贴用于笔记 https://blog.csdn.net/qq_35515521/article/details/78610847

  4. spring&plus;hibernate整合:报错org&period;hibernate&period;HibernateException&colon; No Session found for current thread

    spring+hibernate整合:报错信息如下 org.hibernate.HibernateException: No Session found for current thread at o ...

  5. struts2 spring mybatis 整合(test)

    这几天搭了个spring+struts2+mybatis的架子,练练手,顺便熟悉熟悉struts2. 环境:myEclipse10+tomcat7+jdk1.6(1.8的jre报错,所以换成了1.6) ...

  6. 【Java EE 学习 79 下】【动态SQL】【mybatis和spring的整合】

    一.动态SQL 什么是动态SQL,就是在不同的条件下,sql语句不相同的意思,曾经在“酒店会员管理系统”中写过大量的多条件查询,那是在SSH的环境中,所以只能在代码中进行判断,以下是其中一个多条件查询 ...

  7. spring websocket源码分析续Handler的使用

    1. handler的定义 spring websocket支持的消息有以下几种: 对消息的处理就使用了Handler模式,抽象handler类AbstractWebSocketHandler.jav ...

  8. 3&period;springMVC&plus;spring&plus;Mybatis整合Demo(单表的增删该查,这里主要是贴代码,不多解释了)

    前面给大家讲了整合的思路和整合的过程,在这里就不在提了,直接把springMVC+spring+Mybatis整合的实例代码(单表的增删改查)贴给大家: 首先是目录结构: 仔细看看这个目录结构:我不详 ...

  9. spring WebSocket详解

    场景 websocket是Html5新增加特性之一,目的是浏览器与服务端建立全双工的通信方式,解决http请求-响应带来过多的资源消耗,同时对特殊场景应用提供了全新的实现方式,比如聊天.股票交易.游戏 ...

随机推荐

  1. 文件和目录之link、unlink、remove和rename函数

    任何一个文件可以有多个目录项指向其i节点.创建一个指向现有文件的链接的方法是使用link函数. #include <unistd.h> int link( const char *exis ...

  2. 二次战CPP链表

    Felling By Ruiy: Pre-learnning link list knowloages 熟悉 指针相关操作应用+结构体数据类型应用,且能简单融合使用,堆内存(内存泄露)->类似于 ...

  3. iOS界面调试工具 Reveal-备用

    Reveal是一个iOS程序界面调试工具.使用Reveal,我们可以在iOS开发时动态地查看和修改应用程序的界面. 对于动态或复杂的交互界面,手写UI是不可避免的.通过Reveal,我们可以方便地调试 ...

  4. 重磅!!!微软发布&period;NET Core 2&period;2

    我们很高兴地宣布发布.NET Core 2.2.它包括对运行时的诊断改进,对ARM32 for Windows和Azure Active Directory for SQL Client的支持.此版本 ...

  5. Ontology理论研究和应用建模

    转自:https://www.cnblogs.com/yes-V-can/p/8151275.html 目录 1 关于Ontology 1.1 Ontology的定义 1.2 Ontology的建模元 ...

  6. PHP常用180函数总结【初学者必看】

    数学函数 1.abs(): 求绝对值 <span style="font-size: 14px;">$abs = abs(-4.2); //4.2<br>& ...

  7. IOS6&period;0调用通讯录和之前的差别

    6.通讯录列表获取差异 自iOS6.0后获取通讯录列表需要询问用户,经过用户同意后才可以获取通讯录用户列表.而且ABAddressBookRef的初始化工作也由ABAddressBookCreate函 ...

  8. python &lbrack;&colon;-1&rsqb; 与 &lbrack;&colon;&colon;-1&rsqb;

    line = "abcde"line[:-1]结果为:'abcd' line = "abcde"line[::-1]结果为:'edcba' [:-1] b = ...

  9. HDOJ&lpar;HDU&rpar;&period;1025 Constructing Roads In JGShining's Kingdom &lpar;DP&rpar;

    HDOJ(HDU).1025 Constructing Roads In JGShining's Kingdom (DP) 点我挑战题目 题目分析 题目大意就是给出两两配对的poor city和ric ...

  10. PHP使用curl请求https站点的常见错误及解决方案

    使用curl请求http站点和https站点最大的不同就是https站点有证书验证这一环节,如果证书验证不通过则无法发起请求,不管是请求什么类型的站点遇到问题时先把错误码打印出来看一下,打印错误码的代 ...