添加代码示例springboot-websocket
This commit is contained in:
parent
7db9f11a9c
commit
41927e2762
@ -24,7 +24,7 @@ springboot-mongodb | [集成MongoDB](https://www.xncoding.com/2017/07/0
|
|||||||
springboot-restful | [实现RESTful接口](https://www.xncoding.com/2017/07/05/spring/sb-restful.html)
|
springboot-restful | [实现RESTful接口](https://www.xncoding.com/2017/07/05/spring/sb-restful.html)
|
||||||
springboot-resttemplate | [使用RestTemplate](https://www.xncoding.com/2017/07/06/spring/sb-restclient.html)
|
springboot-resttemplate | [使用RestTemplate](https://www.xncoding.com/2017/07/06/spring/sb-restclient.html)
|
||||||
springboot-shiro | [集成Shiro权限管理](https://www.xncoding.com/2017/07/07/spring/sb-shiro.html)
|
springboot-shiro | [集成Shiro权限管理](https://www.xncoding.com/2017/07/07/spring/sb-shiro.html)
|
||||||
springboot-swagger2 | [集成Swagger2](https://www.xncoding.com/2017/07/08/spring/sb-swagger2.html)
|
springboot-swagger2 | [集成Swagger2自动生成API文档](https://www.xncoding.com/2017/07/08/spring/sb-swagger2.html)
|
||||||
springboot-jwt | [集成JWT实现接口权限认证](https://www.xncoding.com/2017/07/09/spring/sb-jwt.html)
|
springboot-jwt | [集成JWT实现接口权限认证](https://www.xncoding.com/2017/07/09/spring/sb-jwt.html)
|
||||||
springboot-multisource | [多数据源配置](https://www.xncoding.com/2017/07/10/spring/sb-multisource.html)
|
springboot-multisource | [多数据源配置](https://www.xncoding.com/2017/07/10/spring/sb-multisource.html)
|
||||||
springboot-schedule | [定时任务](https://www.xncoding.com/2017/07/12/spring/sb-schedule.html)
|
springboot-schedule | [定时任务](https://www.xncoding.com/2017/07/12/spring/sb-schedule.html)
|
||||||
|
17
springboot-websocket/.gitignore
vendored
Normal file
17
springboot-websocket/.gitignore
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
# 此为注释– 将被Git 忽略
|
||||||
|
# /结尾表示是目录,忽略目录和目录下的所有件
|
||||||
|
# /开头表示根目录,否则是.gitignore的相对目录
|
||||||
|
# !开头表示反选
|
||||||
|
.idea/
|
||||||
|
target/
|
||||||
|
*.iml
|
||||||
|
*.ipr
|
||||||
|
*.iws
|
||||||
|
*.log
|
||||||
|
.svn/
|
||||||
|
.project
|
||||||
|
rebel.xml
|
||||||
|
.rebel-remote.xml.*
|
||||||
|
swagger.json
|
||||||
|
swagger.adoc
|
||||||
|
|
20
springboot-websocket/LICENSE
Normal file
20
springboot-websocket/LICENSE
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2018 Xiong Neng
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
26
springboot-websocket/README.md
Normal file
26
springboot-websocket/README.md
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
|
||||||
|
## 简介
|
||||||
|
|
||||||
|
在SpringBoot中有两种实现WebSocket实时通信的方式:
|
||||||
|
|
||||||
|
1. 一个是使用WebSocket的一个子协议stomp
|
||||||
|
2. 另外一个是使用Socket.IO协议实现。
|
||||||
|
|
||||||
|
本项目演示如何通过stomp协议实现
|
||||||
|
|
||||||
|
### WebSocket js客户端测试
|
||||||
|
|
||||||
|
```
|
||||||
|
/client/html/index.html
|
||||||
|
```
|
||||||
|
|
||||||
|
### WebSocket Java客户端测试
|
||||||
|
|
||||||
|
参考github地址:<https://github.com/NaikSoftware/StompProtocolAndroid>
|
||||||
|
|
||||||
|
## 许可证
|
||||||
|
|
||||||
|
Copyright (c) 2018 Xiong Neng
|
||||||
|
|
||||||
|
基于 MIT 协议发布: <http://www.opensource.org/licenses/MIT>
|
||||||
|
|
91
springboot-websocket/pom.xml
Normal file
91
springboot-websocket/pom.xml
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
<groupId>com.xncoding</groupId>
|
||||||
|
<artifactId>springboot-websocket</artifactId>
|
||||||
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
|
<name>springboot-websocket</name>
|
||||||
|
<description>使用WebScoket实时通信</description>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-parent</artifactId>
|
||||||
|
<version>1.5.9.RELEASE</version>
|
||||||
|
<relativePath/>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
|
<java.version>1.8</java.version>
|
||||||
|
<netty.version>4.1.19.Final</netty.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-websocket</artifactId>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-tomcat</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-jetty</artifactId>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>3.6.1</version>
|
||||||
|
<configuration>
|
||||||
|
<!--<proc>none</proc>-->
|
||||||
|
<source>1.8</source>
|
||||||
|
<target>1.8</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<version>2.20</version>
|
||||||
|
<configuration>
|
||||||
|
<systemPropertyVariables>
|
||||||
|
<swaggerOutputDir>${project.basedir}/src/main/resources/swagger</swaggerOutputDir>
|
||||||
|
<asciiDocOutputDir>${project.basedir}/src/main/resources/swagger/swagger</asciiDocOutputDir>
|
||||||
|
</systemPropertyVariables>
|
||||||
|
<skip>true</skip>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
|
||||||
|
<resources>
|
||||||
|
<resource>
|
||||||
|
<directory>src/main/resources</directory>
|
||||||
|
</resource>
|
||||||
|
<resource>
|
||||||
|
<directory>src/main/java</directory>
|
||||||
|
<includes>
|
||||||
|
<include>**/*.xml</include>
|
||||||
|
</includes>
|
||||||
|
</resource>
|
||||||
|
</resources>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
</project>
|
72
springboot-websocket/run.sh
Normal file
72
springboot-websocket/run.sh
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# 项目自动更新脚本
|
||||||
|
# 先clone相应的分支下来:
|
||||||
|
# git clone ssh://git@120.24.173.142:7999/xxx.git
|
||||||
|
# 远程调试启动:
|
||||||
|
# nohup java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -Xms512m -Xmx1024m -jar -Dspring.profiles.active=${profile} ${jarfile} >/dev/null 2>&1 &
|
||||||
|
|
||||||
|
function start {
|
||||||
|
profile="$1"
|
||||||
|
echo "启动环境profile=${profile}"
|
||||||
|
jarfile=$(ls target/*.jar)
|
||||||
|
if [[ "$?" == "0" ]]; then
|
||||||
|
stop $profile $jarfile
|
||||||
|
fi
|
||||||
|
branch=$(git branch |awk '{print $2}')
|
||||||
|
git pull origin ${branch}
|
||||||
|
echo "更新完代码开始重新打包"
|
||||||
|
mvn clean && mvn clean && mvn package -DskipTests=true
|
||||||
|
if [[ "$?" != "0" ]]; then
|
||||||
|
echo "编译出错,退出!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "nohup java -Xms512m -Xmx1024m -jar -Dspring.profiles.active=${profile} ${jarfile} >/dev/null 2>&1 &"
|
||||||
|
nohup java -Xms512m -Xmx1024m -jar -Dspring.profiles.active=${profile} ${jarfile} >/dev/null 2>&1 &
|
||||||
|
echo "启动应用中,请查看日志文件..."
|
||||||
|
}
|
||||||
|
|
||||||
|
function stop {
|
||||||
|
profile="$1"
|
||||||
|
jarfile="$2"
|
||||||
|
ps aux | grep "${jarfile}" | grep "spring.profiles.active=${profile}" | grep -v grep > /dev/null
|
||||||
|
if [[ "$?" == "0" ]]; then
|
||||||
|
echo "该应用还在跑,我先停了它"
|
||||||
|
pid=$(ps aux | grep "${jarfile}" | grep "spring.profiles.active=${profile}" | grep -v grep |awk '{print $2}')
|
||||||
|
if [[ "$pid" != "" ]]; then
|
||||||
|
kill -9 $pid
|
||||||
|
fi
|
||||||
|
echo "停止应用成功..."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ "$1" == "start" ]]; then
|
||||||
|
if [[ "$#" < 2 ]]; then
|
||||||
|
echo "请输入正确参数:./epay.sh start {profile}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
profile="$2"
|
||||||
|
if [[ "$profile" != "dev" && "$profile" != "test" && "$profile" != "show" && "$profile" != "production" ]]; then
|
||||||
|
echo "参数错误,请输入正确的profile参数,使用方法:"
|
||||||
|
echo "./epay.sh start {profile} ==> 启动应用,{profile}取值:dev|test|show|production"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
start "${profile}"
|
||||||
|
elif [[ "$1" == "stop" ]]; then
|
||||||
|
if [[ "$#" < 2 ]]; then
|
||||||
|
echo "请输入正确参数:./epay.sh stop {profile}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
profile="$2"
|
||||||
|
if [[ "$profile" != "dev" && "$profile" != "test" && "$profile" != "show" && "$profile" != "production" ]]; then
|
||||||
|
echo "参数错误,请输入正确的profile参数,使用方法:"
|
||||||
|
echo "./epay.sh stop {profile} ==> 停止应用,{profile}取值:dev|test|show|production"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
jarfile=$(ls target/*.jar)
|
||||||
|
stop $profile $jarfile
|
||||||
|
else
|
||||||
|
echo "参数错误,使用方法:{}参数是必填的,[]参数可选"
|
||||||
|
echo "./epay.sh start {profile} ==> 启动应用,{profile}取值:dev|test|show|production"
|
||||||
|
echo "./epay.sh stop {profile} ==> 停止应用,{profile}取值:dev|test|show|production"
|
||||||
|
exit 1
|
||||||
|
fi
|
@ -0,0 +1,14 @@
|
|||||||
|
package com.xncoding.jwt;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.scheduling.annotation.EnableScheduling;
|
||||||
|
|
||||||
|
@EnableScheduling
|
||||||
|
@SpringBootApplication
|
||||||
|
public class Application {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(Application.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
package com.xncoding.jwt.config;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
|
||||||
|
import org.springframework.web.socket.config.annotation.AbstractWebSocketMessageBrokerConfigurer;
|
||||||
|
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
|
||||||
|
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WebSocketConfig
|
||||||
|
*
|
||||||
|
* @author XiongNeng
|
||||||
|
* @version 1.0
|
||||||
|
* @since 2018/2/28
|
||||||
|
*/
|
||||||
|
@Configuration
|
||||||
|
@EnableWebSocketMessageBroker
|
||||||
|
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry) {
|
||||||
|
stompEndpointRegistry.addEndpoint("/simple")
|
||||||
|
.setAllowedOrigins("*") //解决跨域问题
|
||||||
|
.withSockJS();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void configureMessageBroker(MessageBrokerRegistry registry) {
|
||||||
|
registry.enableSimpleBroker("/topic");
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,49 @@
|
|||||||
|
package com.xncoding.jwt.controller;
|
||||||
|
|
||||||
|
import com.xncoding.jwt.model.RequestMessage;
|
||||||
|
import com.xncoding.jwt.model.ResponseMessage;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.messaging.handler.annotation.MessageMapping;
|
||||||
|
import org.springframework.messaging.handler.annotation.SendTo;
|
||||||
|
import org.springframework.messaging.simp.SimpMessagingTemplate;
|
||||||
|
import org.springframework.scheduling.annotation.Scheduled;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
|
||||||
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WsController
|
||||||
|
*
|
||||||
|
* @author XiongNeng
|
||||||
|
* @version 1.0
|
||||||
|
* @since 2018/2/28
|
||||||
|
*/
|
||||||
|
@Controller
|
||||||
|
public class WsController {
|
||||||
|
|
||||||
|
private final SimpMessagingTemplate messagingTemplate;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public WsController(SimpMessagingTemplate messagingTemplate) {
|
||||||
|
this.messagingTemplate = messagingTemplate;
|
||||||
|
}
|
||||||
|
|
||||||
|
@MessageMapping("/welcome")
|
||||||
|
@SendTo("/topic/say")
|
||||||
|
public ResponseMessage say(RequestMessage message) {
|
||||||
|
System.out.println(message.getName());
|
||||||
|
return new ResponseMessage("welcome," + message.getName() + " !");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定时推送消息
|
||||||
|
*/
|
||||||
|
@Scheduled(fixedRate = 1000)
|
||||||
|
public void callback() {
|
||||||
|
// 发现消息
|
||||||
|
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
||||||
|
messagingTemplate.convertAndSend("/topic/callback", "定时推送消息时间: " + df.format(new Date()));
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,16 @@
|
|||||||
|
package com.xncoding.jwt.model;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* RequestMessage
|
||||||
|
*
|
||||||
|
* @author XiongNeng
|
||||||
|
* @version 1.0
|
||||||
|
* @since 2018/2/28
|
||||||
|
*/
|
||||||
|
public class RequestMessage {
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
package com.xncoding.jwt.model;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ResponseMessage
|
||||||
|
*
|
||||||
|
* @author XiongNeng
|
||||||
|
* @version 1.0
|
||||||
|
* @since 2018/2/28
|
||||||
|
*/
|
||||||
|
public class ResponseMessage {
|
||||||
|
private String responseMessage;
|
||||||
|
|
||||||
|
public ResponseMessage(String responseMessage) {
|
||||||
|
this.responseMessage = responseMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getResponseMessage() {
|
||||||
|
return responseMessage;
|
||||||
|
}
|
||||||
|
}
|
43
springboot-websocket/src/main/resources/application.yml
Normal file
43
springboot-websocket/src/main/resources/application.yml
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
##########################################################
|
||||||
|
################## 所有profile共有的配置 #################
|
||||||
|
##########################################################
|
||||||
|
|
||||||
|
|
||||||
|
################### spring配置 ###################
|
||||||
|
spring:
|
||||||
|
profiles:
|
||||||
|
active: dev
|
||||||
|
|
||||||
|
server:
|
||||||
|
port: 8092
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
######################## 开发环境profile ##########################
|
||||||
|
#####################################################################
|
||||||
|
spring:
|
||||||
|
profiles: dev
|
||||||
|
|
||||||
|
logging:
|
||||||
|
level:
|
||||||
|
ROOT: INFO
|
||||||
|
com:
|
||||||
|
xncoding: DEBUG
|
||||||
|
file: E:/logs/app.log
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
######################## 测试环境profile ##########################
|
||||||
|
#####################################################################
|
||||||
|
|
||||||
|
spring:
|
||||||
|
profiles: test
|
||||||
|
|
||||||
|
logging:
|
||||||
|
level:
|
||||||
|
ROOT: INFO
|
||||||
|
com:
|
||||||
|
xncoding: DEBUG
|
||||||
|
file: /var/logs/app.log
|
4983
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/bootstrap.css
vendored
Normal file
4983
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/bootstrap.css
vendored
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,73 @@
|
|||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8"/>
|
||||||
|
<title>广播式WebSocket</title>
|
||||||
|
<script src="js/sockjs.min.js"></script>
|
||||||
|
<script src="js/stomp.js"></script>
|
||||||
|
<script src="js/jquery-3.1.1.js"></script>
|
||||||
|
</head>
|
||||||
|
<body onload="disconnect()">
|
||||||
|
<noscript><h2 style="color: #e80b0a;">Sorry,浏览器不支持WebSocket</h2></noscript>
|
||||||
|
<div>
|
||||||
|
<div>
|
||||||
|
<button id="connect" onclick="connect();">连接</button>
|
||||||
|
<button id="disconnect" disabled="disabled" onclick="disconnect();">断开连接</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="conversationDiv">
|
||||||
|
<label>输入你的名字</label><input type="text" id="name"/>
|
||||||
|
<button id="sendName" onclick="sendName();">发送</button>
|
||||||
|
<p id="response"></p>
|
||||||
|
<p id="callback"></p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
var stompClient = null;
|
||||||
|
|
||||||
|
function setConnected(connected) {
|
||||||
|
document.getElementById("connect").disabled = connected;
|
||||||
|
document.getElementById("disconnect").disabled = !connected;
|
||||||
|
document.getElementById("conversationDiv").style.visibility = connected ? 'visible' : 'hidden';
|
||||||
|
$("#response").html();
|
||||||
|
$("#callback").html();
|
||||||
|
}
|
||||||
|
|
||||||
|
function connect() {
|
||||||
|
var socket = new SockJS('http://localhost:8092/simple');
|
||||||
|
stompClient = Stomp.over(socket);
|
||||||
|
stompClient.connect({}, function (frame) {
|
||||||
|
setConnected(true);
|
||||||
|
console.log('Connected:' + frame);
|
||||||
|
stompClient.subscribe('/topic/say', function (response) {
|
||||||
|
showResponse(JSON.parse(response.body).responseMessage);
|
||||||
|
});
|
||||||
|
// 另外再注册一下定时任务接受
|
||||||
|
stompClient.subscribe('/topic/callback', function (response) {
|
||||||
|
showCallback(response.body);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function disconnect() {
|
||||||
|
if (stompClient != null) {
|
||||||
|
stompClient.disconnect();
|
||||||
|
}
|
||||||
|
setConnected(false);
|
||||||
|
console.log('Disconnected');
|
||||||
|
}
|
||||||
|
|
||||||
|
function sendName() {
|
||||||
|
var name = $('#name').val();
|
||||||
|
console.log('name:' + name);
|
||||||
|
stompClient.send("/welcome", {}, JSON.stringify({'name': name}));
|
||||||
|
}
|
||||||
|
|
||||||
|
function showResponse(message) {
|
||||||
|
$("#response").html(message);
|
||||||
|
}
|
||||||
|
function showCallback(message) {
|
||||||
|
$("#callback").html(message);
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
10220
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/js/jquery-3.1.1.js
vendored
Normal file
10220
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/js/jquery-3.1.1.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
27
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/js/sockjs.min.js
vendored
Normal file
27
springboot-websocket/src/test/java/com/xncoding/jwt/socket/client/html/js/sockjs.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -0,0 +1,501 @@
|
|||||||
|
// Generated by CoffeeScript 1.7.1
|
||||||
|
|
||||||
|
/*
|
||||||
|
Stomp Over WebSocket http://www.jmesnil.net/stomp-websocket/doc/ | Apache License V2.0
|
||||||
|
|
||||||
|
Copyright (C) 2010-2013 [Jeff Mesnil](http://jmesnil.net/)
|
||||||
|
Copyright (C) 2012 [FuseSource, Inc.](http://fusesource.com)
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function() {
|
||||||
|
var Byte, Client, Frame, Stomp,
|
||||||
|
__hasProp = {}.hasOwnProperty,
|
||||||
|
__slice = [].slice;
|
||||||
|
|
||||||
|
Byte = {
|
||||||
|
LF: '\x0A',
|
||||||
|
NULL: '\x00'
|
||||||
|
};
|
||||||
|
|
||||||
|
Frame = (function() {
|
||||||
|
var unmarshallSingle;
|
||||||
|
|
||||||
|
function Frame(command, headers, body) {
|
||||||
|
this.command = command;
|
||||||
|
this.headers = headers != null ? headers : {};
|
||||||
|
this.body = body != null ? body : '';
|
||||||
|
}
|
||||||
|
|
||||||
|
Frame.prototype.toString = function() {
|
||||||
|
var lines, name, skipContentLength, value, _ref;
|
||||||
|
lines = [this.command];
|
||||||
|
skipContentLength = this.headers['content-length'] === false ? true : false;
|
||||||
|
if (skipContentLength) {
|
||||||
|
delete this.headers['content-length'];
|
||||||
|
}
|
||||||
|
_ref = this.headers;
|
||||||
|
for (name in _ref) {
|
||||||
|
if (!__hasProp.call(_ref, name)) continue;
|
||||||
|
value = _ref[name];
|
||||||
|
lines.push("" + name + ":" + value);
|
||||||
|
}
|
||||||
|
if (this.body && !skipContentLength) {
|
||||||
|
lines.push("content-length:" + (Frame.sizeOfUTF8(this.body)));
|
||||||
|
}
|
||||||
|
lines.push(Byte.LF + this.body);
|
||||||
|
return lines.join(Byte.LF);
|
||||||
|
};
|
||||||
|
|
||||||
|
Frame.sizeOfUTF8 = function(s) {
|
||||||
|
if (s) {
|
||||||
|
return encodeURI(s).match(/%..|./g).length;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
unmarshallSingle = function(data) {
|
||||||
|
var body, chr, command, divider, headerLines, headers, i, idx, len, line, start, trim, _i, _j, _len, _ref, _ref1;
|
||||||
|
divider = data.search(RegExp("" + Byte.LF + Byte.LF));
|
||||||
|
headerLines = data.substring(0, divider).split(Byte.LF);
|
||||||
|
command = headerLines.shift();
|
||||||
|
headers = {};
|
||||||
|
trim = function(str) {
|
||||||
|
return str.replace(/^\s+|\s+$/g, '');
|
||||||
|
};
|
||||||
|
_ref = headerLines.reverse();
|
||||||
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
||||||
|
line = _ref[_i];
|
||||||
|
idx = line.indexOf(':');
|
||||||
|
headers[trim(line.substring(0, idx))] = trim(line.substring(idx + 1));
|
||||||
|
}
|
||||||
|
body = '';
|
||||||
|
start = divider + 2;
|
||||||
|
if (headers['content-length']) {
|
||||||
|
len = parseInt(headers['content-length']);
|
||||||
|
body = ('' + data).substring(start, start + len);
|
||||||
|
} else {
|
||||||
|
chr = null;
|
||||||
|
for (i = _j = start, _ref1 = data.length; start <= _ref1 ? _j < _ref1 : _j > _ref1; i = start <= _ref1 ? ++_j : --_j) {
|
||||||
|
chr = data.charAt(i);
|
||||||
|
if (chr === Byte.NULL) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
body += chr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new Frame(command, headers, body);
|
||||||
|
};
|
||||||
|
|
||||||
|
Frame.unmarshall = function(datas) {
|
||||||
|
var frame, frames, last_frame, r;
|
||||||
|
frames = datas.split(RegExp("" + Byte.NULL + Byte.LF + "*"));
|
||||||
|
r = {
|
||||||
|
frames: [],
|
||||||
|
partial: ''
|
||||||
|
};
|
||||||
|
r.frames = (function() {
|
||||||
|
var _i, _len, _ref, _results;
|
||||||
|
_ref = frames.slice(0, -1);
|
||||||
|
_results = [];
|
||||||
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
||||||
|
frame = _ref[_i];
|
||||||
|
_results.push(unmarshallSingle(frame));
|
||||||
|
}
|
||||||
|
return _results;
|
||||||
|
})();
|
||||||
|
last_frame = frames.slice(-1)[0];
|
||||||
|
if (last_frame === Byte.LF || (last_frame.search(RegExp("" + Byte.NULL + Byte.LF + "*$"))) !== -1) {
|
||||||
|
r.frames.push(unmarshallSingle(last_frame));
|
||||||
|
} else {
|
||||||
|
r.partial = last_frame;
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
|
||||||
|
Frame.marshall = function(command, headers, body) {
|
||||||
|
var frame;
|
||||||
|
frame = new Frame(command, headers, body);
|
||||||
|
return frame.toString() + Byte.NULL;
|
||||||
|
};
|
||||||
|
|
||||||
|
return Frame;
|
||||||
|
|
||||||
|
})();
|
||||||
|
|
||||||
|
Client = (function() {
|
||||||
|
var now;
|
||||||
|
|
||||||
|
function Client(ws) {
|
||||||
|
this.ws = ws;
|
||||||
|
this.ws.binaryType = "arraybuffer";
|
||||||
|
this.counter = 0;
|
||||||
|
this.connected = false;
|
||||||
|
this.heartbeat = {
|
||||||
|
outgoing: 10000,
|
||||||
|
incoming: 10000
|
||||||
|
};
|
||||||
|
this.maxWebSocketFrameSize = 16 * 1024;
|
||||||
|
this.subscriptions = {};
|
||||||
|
this.partialData = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
Client.prototype.debug = function(message) {
|
||||||
|
var _ref;
|
||||||
|
return typeof window !== "undefined" && window !== null ? (_ref = window.console) != null ? _ref.log(message) : void 0 : void 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
now = function() {
|
||||||
|
if (Date.now) {
|
||||||
|
return Date.now();
|
||||||
|
} else {
|
||||||
|
return new Date().valueOf;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype._transmit = function(command, headers, body) {
|
||||||
|
var out;
|
||||||
|
out = Frame.marshall(command, headers, body);
|
||||||
|
if (typeof this.debug === "function") {
|
||||||
|
this.debug(">>> " + out);
|
||||||
|
}
|
||||||
|
while (true) {
|
||||||
|
if (out.length > this.maxWebSocketFrameSize) {
|
||||||
|
this.ws.send(out.substring(0, this.maxWebSocketFrameSize));
|
||||||
|
out = out.substring(this.maxWebSocketFrameSize);
|
||||||
|
if (typeof this.debug === "function") {
|
||||||
|
this.debug("remaining = " + out.length);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return this.ws.send(out);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype._setupHeartbeat = function(headers) {
|
||||||
|
var serverIncoming, serverOutgoing, ttl, v, _ref, _ref1;
|
||||||
|
if ((_ref = headers.version) !== Stomp.VERSIONS.V1_1 && _ref !== Stomp.VERSIONS.V1_2) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_ref1 = (function() {
|
||||||
|
var _i, _len, _ref1, _results;
|
||||||
|
_ref1 = headers['heart-beat'].split(",");
|
||||||
|
_results = [];
|
||||||
|
for (_i = 0, _len = _ref1.length; _i < _len; _i++) {
|
||||||
|
v = _ref1[_i];
|
||||||
|
_results.push(parseInt(v));
|
||||||
|
}
|
||||||
|
return _results;
|
||||||
|
})(), serverOutgoing = _ref1[0], serverIncoming = _ref1[1];
|
||||||
|
if (!(this.heartbeat.outgoing === 0 || serverIncoming === 0)) {
|
||||||
|
ttl = Math.max(this.heartbeat.outgoing, serverIncoming);
|
||||||
|
if (typeof this.debug === "function") {
|
||||||
|
this.debug("send PING every " + ttl + "ms");
|
||||||
|
}
|
||||||
|
this.pinger = Stomp.setInterval(ttl, (function(_this) {
|
||||||
|
return function() {
|
||||||
|
_this.ws.send(Byte.LF);
|
||||||
|
return typeof _this.debug === "function" ? _this.debug(">>> PING") : void 0;
|
||||||
|
};
|
||||||
|
})(this));
|
||||||
|
}
|
||||||
|
if (!(this.heartbeat.incoming === 0 || serverOutgoing === 0)) {
|
||||||
|
ttl = Math.max(this.heartbeat.incoming, serverOutgoing);
|
||||||
|
if (typeof this.debug === "function") {
|
||||||
|
this.debug("check PONG every " + ttl + "ms");
|
||||||
|
}
|
||||||
|
return this.ponger = Stomp.setInterval(ttl, (function(_this) {
|
||||||
|
return function() {
|
||||||
|
var delta;
|
||||||
|
delta = now() - _this.serverActivity;
|
||||||
|
if (delta > ttl * 2) {
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug("did not receive server activity for the last " + delta + "ms");
|
||||||
|
}
|
||||||
|
return _this.ws.close();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
})(this));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype._parseConnect = function() {
|
||||||
|
var args, connectCallback, errorCallback, headers;
|
||||||
|
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
|
||||||
|
headers = {};
|
||||||
|
switch (args.length) {
|
||||||
|
case 2:
|
||||||
|
headers = args[0], connectCallback = args[1];
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
if (args[1] instanceof Function) {
|
||||||
|
headers = args[0], connectCallback = args[1], errorCallback = args[2];
|
||||||
|
} else {
|
||||||
|
headers.login = args[0], headers.passcode = args[1], connectCallback = args[2];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
headers.login = args[0], headers.passcode = args[1], connectCallback = args[2], errorCallback = args[3];
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
headers.login = args[0], headers.passcode = args[1], connectCallback = args[2], errorCallback = args[3], headers.host = args[4];
|
||||||
|
}
|
||||||
|
return [headers, connectCallback, errorCallback];
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.connect = function() {
|
||||||
|
var args, errorCallback, headers, out;
|
||||||
|
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
|
||||||
|
out = this._parseConnect.apply(this, args);
|
||||||
|
headers = out[0], this.connectCallback = out[1], errorCallback = out[2];
|
||||||
|
if (typeof this.debug === "function") {
|
||||||
|
this.debug("Opening Web Socket...");
|
||||||
|
}
|
||||||
|
this.ws.onmessage = (function(_this) {
|
||||||
|
return function(evt) {
|
||||||
|
var arr, c, client, data, frame, messageID, onreceive, subscription, unmarshalledData, _i, _len, _ref, _results;
|
||||||
|
data = typeof ArrayBuffer !== 'undefined' && evt.data instanceof ArrayBuffer ? (arr = new Uint8Array(evt.data), typeof _this.debug === "function" ? _this.debug("--- got data length: " + arr.length) : void 0, ((function() {
|
||||||
|
var _i, _len, _results;
|
||||||
|
_results = [];
|
||||||
|
for (_i = 0, _len = arr.length; _i < _len; _i++) {
|
||||||
|
c = arr[_i];
|
||||||
|
_results.push(String.fromCharCode(c));
|
||||||
|
}
|
||||||
|
return _results;
|
||||||
|
})()).join('')) : evt.data;
|
||||||
|
_this.serverActivity = now();
|
||||||
|
if (data === Byte.LF) {
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug("<<< PONG");
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug("<<< " + data);
|
||||||
|
}
|
||||||
|
unmarshalledData = Frame.unmarshall(_this.partialData + data);
|
||||||
|
_this.partialData = unmarshalledData.partial;
|
||||||
|
_ref = unmarshalledData.frames;
|
||||||
|
_results = [];
|
||||||
|
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
||||||
|
frame = _ref[_i];
|
||||||
|
switch (frame.command) {
|
||||||
|
case "CONNECTED":
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug("connected to server " + frame.headers.server);
|
||||||
|
}
|
||||||
|
_this.connected = true;
|
||||||
|
_this._setupHeartbeat(frame.headers);
|
||||||
|
_results.push(typeof _this.connectCallback === "function" ? _this.connectCallback(frame) : void 0);
|
||||||
|
break;
|
||||||
|
case "MESSAGE":
|
||||||
|
subscription = frame.headers.subscription;
|
||||||
|
onreceive = _this.subscriptions[subscription] || _this.onreceive;
|
||||||
|
if (onreceive) {
|
||||||
|
client = _this;
|
||||||
|
messageID = frame.headers["message-id"];
|
||||||
|
frame.ack = function(headers) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
return client.ack(messageID, subscription, headers);
|
||||||
|
};
|
||||||
|
frame.nack = function(headers) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
return client.nack(messageID, subscription, headers);
|
||||||
|
};
|
||||||
|
_results.push(onreceive(frame));
|
||||||
|
} else {
|
||||||
|
_results.push(typeof _this.debug === "function" ? _this.debug("Unhandled received MESSAGE: " + frame) : void 0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "RECEIPT":
|
||||||
|
_results.push(typeof _this.onreceipt === "function" ? _this.onreceipt(frame) : void 0);
|
||||||
|
break;
|
||||||
|
case "ERROR":
|
||||||
|
_results.push(typeof errorCallback === "function" ? errorCallback(frame) : void 0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
_results.push(typeof _this.debug === "function" ? _this.debug("Unhandled frame: " + frame) : void 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return _results;
|
||||||
|
};
|
||||||
|
})(this);
|
||||||
|
this.ws.onclose = (function(_this) {
|
||||||
|
return function() {
|
||||||
|
var msg;
|
||||||
|
msg = "Whoops! Lost connection to " + _this.ws.url;
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug(msg);
|
||||||
|
}
|
||||||
|
_this._cleanUp();
|
||||||
|
return typeof errorCallback === "function" ? errorCallback(msg) : void 0;
|
||||||
|
};
|
||||||
|
})(this);
|
||||||
|
return this.ws.onopen = (function(_this) {
|
||||||
|
return function() {
|
||||||
|
if (typeof _this.debug === "function") {
|
||||||
|
_this.debug('Web Socket Opened...');
|
||||||
|
}
|
||||||
|
headers["accept-version"] = Stomp.VERSIONS.supportedVersions();
|
||||||
|
headers["heart-beat"] = [_this.heartbeat.outgoing, _this.heartbeat.incoming].join(',');
|
||||||
|
return _this._transmit("CONNECT", headers);
|
||||||
|
};
|
||||||
|
})(this);
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.disconnect = function(disconnectCallback, headers) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
this._transmit("DISCONNECT", headers);
|
||||||
|
this.ws.onclose = null;
|
||||||
|
this.ws.close();
|
||||||
|
this._cleanUp();
|
||||||
|
return typeof disconnectCallback === "function" ? disconnectCallback() : void 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype._cleanUp = function() {
|
||||||
|
this.connected = false;
|
||||||
|
if (this.pinger) {
|
||||||
|
Stomp.clearInterval(this.pinger);
|
||||||
|
}
|
||||||
|
if (this.ponger) {
|
||||||
|
return Stomp.clearInterval(this.ponger);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.send = function(destination, headers, body) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
if (body == null) {
|
||||||
|
body = '';
|
||||||
|
}
|
||||||
|
headers.destination = destination;
|
||||||
|
return this._transmit("SEND", headers, body);
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.subscribe = function(destination, callback, headers) {
|
||||||
|
var client;
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
if (!headers.id) {
|
||||||
|
headers.id = "sub-" + this.counter++;
|
||||||
|
}
|
||||||
|
headers.destination = destination;
|
||||||
|
this.subscriptions[headers.id] = callback;
|
||||||
|
this._transmit("SUBSCRIBE", headers);
|
||||||
|
client = this;
|
||||||
|
return {
|
||||||
|
id: headers.id,
|
||||||
|
unsubscribe: function() {
|
||||||
|
return client.unsubscribe(headers.id);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.unsubscribe = function(id) {
|
||||||
|
delete this.subscriptions[id];
|
||||||
|
return this._transmit("UNSUBSCRIBE", {
|
||||||
|
id: id
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.begin = function(transaction) {
|
||||||
|
var client, txid;
|
||||||
|
txid = transaction || "tx-" + this.counter++;
|
||||||
|
this._transmit("BEGIN", {
|
||||||
|
transaction: txid
|
||||||
|
});
|
||||||
|
client = this;
|
||||||
|
return {
|
||||||
|
id: txid,
|
||||||
|
commit: function() {
|
||||||
|
return client.commit(txid);
|
||||||
|
},
|
||||||
|
abort: function() {
|
||||||
|
return client.abort(txid);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.commit = function(transaction) {
|
||||||
|
return this._transmit("COMMIT", {
|
||||||
|
transaction: transaction
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.abort = function(transaction) {
|
||||||
|
return this._transmit("ABORT", {
|
||||||
|
transaction: transaction
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.ack = function(messageID, subscription, headers) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
headers["message-id"] = messageID;
|
||||||
|
headers.subscription = subscription;
|
||||||
|
return this._transmit("ACK", headers);
|
||||||
|
};
|
||||||
|
|
||||||
|
Client.prototype.nack = function(messageID, subscription, headers) {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = {};
|
||||||
|
}
|
||||||
|
headers["message-id"] = messageID;
|
||||||
|
headers.subscription = subscription;
|
||||||
|
return this._transmit("NACK", headers);
|
||||||
|
};
|
||||||
|
|
||||||
|
return Client;
|
||||||
|
|
||||||
|
})();
|
||||||
|
|
||||||
|
Stomp = {
|
||||||
|
VERSIONS: {
|
||||||
|
V1_0: '1.0',
|
||||||
|
V1_1: '1.1',
|
||||||
|
V1_2: '1.2',
|
||||||
|
supportedVersions: function() {
|
||||||
|
return '1.1,1.0';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
client: function(url, protocols) {
|
||||||
|
var klass, ws;
|
||||||
|
if (protocols == null) {
|
||||||
|
protocols = ['v10.stomp', 'v11.stomp'];
|
||||||
|
}
|
||||||
|
klass = Stomp.WebSocketClass || WebSocket;
|
||||||
|
ws = new klass(url, protocols);
|
||||||
|
return new Client(ws);
|
||||||
|
},
|
||||||
|
over: function(ws) {
|
||||||
|
return new Client(ws);
|
||||||
|
},
|
||||||
|
Frame: Frame
|
||||||
|
};
|
||||||
|
|
||||||
|
if (typeof exports !== "undefined" && exports !== null) {
|
||||||
|
exports.Stomp = Stomp;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof window !== "undefined" && window !== null) {
|
||||||
|
Stomp.setInterval = function(interval, f) {
|
||||||
|
return window.setInterval(f, interval);
|
||||||
|
};
|
||||||
|
Stomp.clearInterval = function(id) {
|
||||||
|
return window.clearInterval(id);
|
||||||
|
};
|
||||||
|
window.Stomp = Stomp;
|
||||||
|
} else if (!exports) {
|
||||||
|
self.Stomp = Stomp;
|
||||||
|
}
|
||||||
|
|
||||||
|
}).call(this);
|
Loading…
Reference in New Issue
Block a user