RestWebSocket增加anyuser功能

This commit is contained in:
Redkale
2017-12-06 10:20:13 +08:00
parent 1da73429f7
commit 2d4b865432
4 changed files with 20 additions and 2 deletions

View File

@@ -328,6 +328,10 @@ public final class Rest {
mv.visitInsn(rws.single() ? ICONST_1 : ICONST_0);
mv.visitFieldInsn(PUTFIELD, newDynName, "single", "Z");
mv.visitVarInsn(ALOAD, 0);
mv.visitInsn(rws.anyuser() ? ICONST_1 : ICONST_0);
mv.visitFieldInsn(PUTFIELD, newDynName, "anyuser", "Z");
mv.visitInsn(RETURN);
mv.visitMaxs(3, 1);
mv.visitEnd();

View File

@@ -52,6 +52,13 @@ public @interface RestWebSocket {
*/
boolean single() default true;
/**
* WebSocket.createUserid返回的值是否不能表示户登录态
*
* @return 默认false
*/
boolean anyuser() default false;
/**
* WebScoket服务器给客户端进行ping操作的间隔时间, 单位: 秒, 默认值15秒
*

View File

@@ -62,14 +62,21 @@ public abstract class WebSocketServlet extends HttpServlet implements Resourcabl
protected Type messageTextType; //RestWebSocket时会被修改
//同RestWebSocket.single
protected boolean single = true; //是否单用户单连接
//同RestWebSocket.liveinterval
protected int liveinterval = DEFAILT_LIVEINTERVAL;
//同RestWebSocket.wsmaxconns
protected int wsmaxconns = 0;
//同RestWebSocket.wsmaxbody
protected int wsmaxbody = 16 * 1024;
//同RestWebSocket.anyuser
protected boolean anyuser = false;
@Resource(name = "jsonconvert")
protected Convert jsonConvert;
@@ -203,7 +210,7 @@ public abstract class WebSocketServlet extends HttpServlet implements Resourcabl
return;
}
webSocket._userid = userid;
if (single) {
if (single && !anyuser) {
WebSocketServlet.this.node.existsWebSocket(userid).whenComplete((rs, ex) -> {
if (rs) webSocket.onSingleRepeatConnect();
WebSocketServlet.this.node.localEngine.add(webSocket);