因为做通信项目的时候,需要实时获取每个分机的当前状态,发现websocket还不错,只是对浏览器的要求比较高,

针对特定用户推送消息,网上有一些

public class GetHttpSessionConfigurator  extends ServerEndpointConfig.Configurator{

@Override
 public void modifyHandshake(ServerEndpointConfig config,HandshakeRequest request,HandshakeResponse response){
  HttpSession httpSession = (HttpSession)request.getHttpSession();
  config.getUserProperties().put(HttpSession.class.getName(),httpSession);
  }
 
}

//@ServerEndpoint(value="/websocket",configurator=GetHttpSessionConfigurator.class)

在open方法加入参数,进行实现,最后发现获取不到session,为null。 然后通过他们说的在监听器内,把session也加入,最后可以获取session,却发现用户的session会改变

两个httpSession 不是一个值。实在没办法用啦下面的法子。。。。。。。。

实际点,代码奉上:

jsp:

<script type="text/javascript">
var BASE_PATH="${pageContext.request.contextPath}";//项目名称
var iphost="${iphost}";//服务器ip+端口
var session="${session}";//针对特定用户推送时,实在找不到方法只能笨点,把每个用户放去缓存,通过后台闯入页面
var ws;
$(function(){
    ws = new WebSocket("ws://"+iphost+"/${pageContext.request.contextPath }/websocket?"+session);
    ws.onopen = function(evn){
        //console.log(evn);
    };
    ws.onmessage = function(evn){              
        var data = evn.data+'';
        //console.log(data);
        if(data.indexOf("挂机原因")>-1){
         UIkit.modal.alert(evn.data);
        }else if(data.indexOf("来电弹屏")>-1){
         var tpphone=data.replace("来电弹屏", "");
         var rw=document.body.clientWidth-800;
      var rh=document.body.clientHeight-600;
      window.open(BASE_PATH+'/main/asterisktest/bomb?phone='+tpphone,"","toolbar=yes, location=yes, directories=no, status=no, menubar=yes, scrollbars=yes, resizable=no, copyhistory=yes, width=800, height=600,top="+rh+", left="+rw);

}else{
        var json=eval('('+data+')');      
        var div = $("#"+json["id"]);
        div.html(json["statusname"]);
        }
    };
    ws.onclose = function(evn){
        //console.log("关闭");
    };
    ws.onError=function(evn){
     // console.log('Error occured: ' + evt.data);
      };
});
</script>

java:

//@ServerEndpoint(value="/websocket",configurator=GetHttpSessionConfigurator.class)
@ServerEndpoint(value="/websocket")
public class WebSocket  {
  public WebSocket(){
        
     }
  //给所有的用户推送消息
  public static void broadcastAll(JSONObject jsono){ 
 
   ListIterator it=WEBApp.AppSession.listIterator();
            while(it.hasNext()){
               try { 
                ((Session)it.next()).getBasicRemote().sendText(jsono.toString()); 
                   
                } catch (Exception e) {

e.printStackTrace();

}

}

}
     //给指定用户发送消息
   public static void broadcast(String key,String value){
    MapCacheUtil mapc=MapCacheUtil.getInstance();
    try {
     if(mapc.getWebsession(key)!=null){
    mapc.getWebsession(key).getBasicRemote().sendText(value);
     }
   } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   }
 
 
     @OnOpen//,EndpointConfig config
     public void onopen(Session session){
         System.out.println("连接成功");
         MapCacheUtil mapc=MapCacheUtil.getInstance();
         mapc.putWebsession(session.getQueryString(), session);
         try {
          WEBApp.AppSession.add(session);                    
             session.getBasicRemote().sendText("hello client...");
         } catch (IOException e) {
             e.printStackTrace();
         }
     }
     @OnClose
     public void onclose(Session session){
      WEBApp.AppSession.remove(session);
         System.out.println(session.getId()+"close....");
        
     }
      @OnMessage     
     public void onsend(Session session,String msg){
         try {      
     session.getBasicRemote().sendText(msg);
    
         } catch (IOException e) {
             e.printStackTrace();
         }
     }

//保存所有Websocket Session 的值

public class WEBApp {

public static Vector<javax.websocket.Session>
AppSession=new Vector<javax.websocket.Session>();

}

也没什么经验,不足的大家提出建议,起码功能实现啦。。

WebSocket 的一些简单页面推送使用的更多相关文章

  1. 基于page的简单页面推送技术

    我们可以先看下简单效果,打开2个页面可以看到推送效果 服务端我们只需要下面一个方法 using System; using System.Collections.Generic; using Syst ...

  2. 结合实际需求,在webapi内利用WebSocket建立单向的消息推送平台,让A页面和服务端建立WebSocket连接,让其他页面可以及时给A页面推送消息

    1.需求示意图 2.需求描述 原本是为了给做unity3d客户端开发的同事提供不定时的消息推送,比如商城购买道具后服务端将道具信息推送给客户端. 本篇文章简化理解,用“相关部门开展活动,向全市人民征集 ...

  3. Spring之WebSocket网页聊天以及服务器推送

    Spring之WebSocket网页聊天以及服务器推送 转自:http://www.xdemo.org/spring-websocket-comet/ /Springframework /Spring ...

  4. 最简单的推送--uexGetui

    个推插件使用指南 配置方法这里不再复述,详情请参见插件接入指引 怎样创建一个最简单的推送? //只需要两个方法 uexGetui.initialize(data); uexGetui.onInitia ...

  5. H5 EventSource 实现web页面推送功能demo

    /** * H5 EventSource 实现web页面推送功能demo */ var serverData,statusDiv; var SERVER_URL = "index.php&q ...

  6. 在Openfire上弄一个简单的推送系统

    推送系统 说是推送系统有点大,其实就是一个消息广播功能吧.作用其实也就是由服务端接收到消息然后推送到订阅的客户端. 思路 对于推送最关键的是服务端向客户端发送数据,客户端向服务端订阅自己想要的消息.这 ...

  7. Android中脱离WebView使用WebSocket实现群聊和推送功能

    WebSocket是Web2.0时代的新产物,用于弥补HTTP协议的某些不足,不过他们之间真实的关系是兄弟关系,都是对socket的进一步封装,其目前最直观的表现就是服务器推送和聊天功能.更多知识参考 ...

  8. v-charts 和 websocket实现数据展示动态推送

    v-charts https://v-charts.js.org/#/ ELEMENT力作: 在使用 echarts 生成图表时,经常需要做繁琐的数据类型转化.修改复杂的配置项,v-charts 的出 ...

  9. Django2.0.4 + websocket 实现实时通信,主动推送,聊天室及客服系统

    webSocket是一种在单个TCP连接上进行全双工通信的协议. webSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据.在WebSocket API中,浏览器 ...

随机推荐

  1. SSH三大框架整合配置详细步骤(3)

    5 配置Spring2.5 5.1 基础配置 1)        导入spring包.下载spring-framework-2.5.6并解压后,在spring-framework-2.5.6" ...

  2. jQuery 1.x and 2.x , which is better?

    1. jQuery 1.x和2.x的区别 或者可以说是jQuery 2.x有什么新特征? jQuery官方发布2.x原话 不再支持IE6/7/8,如果在IE9/10里只用“兼容性视图”模式也将会受到影 ...

  3. linux多线程编程入门

    背景知识: 在前一个实训中我们介绍了进程,但有时人们认为用fork调用来创建新进程的代价太高.在这种情况下,如果能让一个进程同时做零件事情或至少看起来是这样将会非常有用.而且,你可能希望能有两件或更多 ...

  4. bleve搜索引擎源码分析之索引——mapping真复杂啊

    接下来看看下面index部分的源码实现: data := struct { Name string Des string }{ Name: "hello world this is bone ...

  5. Java语法基础练习2

    ---恢复内容开始--- 1.仔细阅读示例:EnumTest.java分析结果 代码: 运行结果: 分析:枚举类型就是一个类,枚举中的常量就是枚举类型中的实例,可把字符串转化为枚举:而且他本身是一个类 ...

  6. windows 2003 server 64 位 IIS 6下部署 32位网站

    在 C:\WINDOWS\system32\inetsrv\MetaBase.xml 设置节点 在 开始--->运行--->输入一下代码,回车即可,就会跳出正在安装NET2.0 代码为   ...

  7. 深入理解JMM(Java内存模型) --(一)

    并发编程模型的分类 在并发编程中,我们需要处理两个关键问题:线程之间如何通信及线程之间如何同步(这里的线程是指并发执行的活动实体).通信是指线程之间以何种机制来交换信息.在命令式编程中,线程之间的通信 ...

  8. String类的直接赋值和构造方法赋值的区别

    直接赋值:只开辟一块堆内存空间,而且保存的字符串可以自动入池,以供其他内容相同的字符串对象使用. 构造方法:开辟两块堆内存空间,有一块成为垃圾,并且字符串的内容无法自动入池,但是可以使用String类 ...

  9. WPF-按钮美化

    我们不多哔哔,先放图: 美化按钮背景: 当我们用系统默认的按钮风格似乎太老套,而且不太美观,某些情况下我们需要对按钮进行美化和重绘,只有这样才能满足我们的需要 按钮美化思维引导: 图中1 为控件Bor ...

  10. 数据结构 - 链栈的实行(C语言)

    数据结构-链栈的实现 1 链栈的定义 现在来看看栈的链式存储结构,简称为链栈. 想想看栈只是栈顶来做插入和删除操作,栈顶放在链表的头部还是尾部呢?由于单链表有头指针,而栈顶指针也是必须的,那干吗不让它 ...