设为首页 收藏本站
查看: 1024|回复: 0

[经验分享] 基于Tomcat7的WebSocket.兼容IE(客户端需Flash10)

[复制链接]

尚未签到

发表于 2017-2-28 11:35:58 | 显示全部楼层 |阅读模式
  有点时间.研究了一下.发现Tomcat7.0.27 和jetty 都有支持.
  把这个几天研究的结果记录一下
  检索资料:
  基于Tomcat的WebSocket(5月8日更新)

jquery websocket 插件

Flash Socket通信的安全策略问题 843端口

C++与Flex之间socket通信policy-file-request解决方案
  https://github.com/gimite/web-socket-js   这插件用来做兼容性的

  服务端程序直接拿 Tomcat示例源码. 代码位置见Tomcat_HOME\webapps\examples\WEB-INF\classes\websocket\chat\*

  有几个问题备注:

  1. Tomcat 7.0.27 版本 20秒如果不发送消息,就会掉线.  基于Tomcat的WebSocket(5月8日更新) 这里 19楼 yaolifei 童鞋的回答.我的做法就是每隔10秒发送一个字符到服务器. 好在 下一版会解决.

  2. 当前的7.0.27版本 ,WebScoket中 request.getSession() 获取不到任何东西.经过测试观察.还会把整个当前站点的session销毁. 所以在网上也看到直接在websocketServlet中获取session.十分的不解.(设置会话属性在其他普通servlet中)

  3. flash的安全机制问题.需要服务器另开一个843端口的socket连接.用来处理策略文件.和flex在http交互中的crossdomain类似.

  4. 目前我处理不能获取session,是通过连接websocket时传递参数来实现的.不知道有没有其他方式

  5. 测试过程中发现 opera , IE9 , qq浏览器(包括360这样的) 都不支持websocket . 但是遨游支持了.

  
  代码片段:

    web.xml



     <listener>  //这里用于启动和关闭843端口的socket
<listener-class>cn.vs9.chat.listener.ServletContextListener</listener-class>
</listener>
<servlet>  //这个直接抄Tomcat示例
<servlet-name>chat</servlet-name>
<servlet-class>cn.vs9.chat.servlet.websocket.ChatWebSocketServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>chat</servlet-name>
<url-pattern>/chat/chat.htm</url-pattern>
</servlet-mapping>
  聊天页面: web-socket-js 判断当前浏览器是否原声支持websocket,如果不支持,就使用flash



<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<html>
<head>
<title></title>
<style>
</style>
<script type="text/javascript" src="scripts/swfobject.js"></script>
<script type="text/javascript" src="scripts/jquery.js"></script>
<script type="text/javascript" src="scripts/web_socket.js"></script>
<script type="text/javascript" src="scripts/jquery.WebSocket.js"></script>
<script>
var ws;
var WEB_SOCKET_SWF_LOCATION = 'media/WebSocketMain.swf';
var WEB_SOCKET_DEBUG = true;
$(function() {
$("#sendBtn").on("click",send);
connection();
});
function connection(){
ws = $.websocket({  
domain:"127.0.0.1",
protocol:"WebSocketDemo/chat/chat.htm" ,
onOpen:function(event){  
showMessage("已成功登录");  
},  
onError:function(event){
alert("error:"+ event)
},  
onMessage:function(result){  
receiveMessage(result);
},
onClose:function(event){
ws = null;
}
});  
}
function send(){
if(!ws){
alert("已经断开聊天室");
return;
}
var msg=$.trim($("#messageInput").val());
if(msg==""){return;}
ws.send(msg);  
$("#messageInput").val("").focus();;
}
function receiveMessage(result){
showMessage(result);
}
function showMessage(msg){
$("#public").append("<div>"+msg+"</div>");
}

</script>
</head>
<body>
<div id="public" style="height:500px;border:1px solid;"></div>

<div class="input">
<input type="text" id="messageInput" onKeyDown="if (event.keyCode==13)$('#sendBtn').click()" maxlength="100" size="40" tabindex="1" />
<input type="button"  id="sendBtn" value="提交" >
</div>
</body>
</html>
  效果: 据说是IE8 也能,我的是IE9,有兴趣的测试吧

DSC0000.jpg

  上源码:  
  WebScoket Demo下载地址

  
  
  
  
  
  
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-348402-1-1.html 上篇帖子: SiteMesh3原理和SpringMVC + FreeMarker + SiteMesh3问题 下篇帖子: 手机网游客户端指南-网络通信
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表