websocket入门demo一直报404 3C

今天下午照着网上的案例弄了一个websocket的入门demo。但是自己照着打了一份后一直报404。
WebSocket connection to 'ws://127.0.0.1:8080/websocket1/websocket' failed:
Error during WebSocket handshake: Unexpected response code: 404
因为是最简单的demo。没有拦截器什么的。该配的注解还有方法都有写了。

2个回答

查看下你的通讯请求路径,404的错误指的是没有找到资源

qq_36324464
咸鱼哥哥 我把网上那个demo复制到了本地运行还是访问不到。url我也没写错啊- -。。但是就是报错。
2 年多之前 回复

妈蛋。。解决了。tomcat版本换了就好了。之前一直用tomcat7。网上也说tomcat7可以用。但是我用就报错。换成tomcat8就没问题了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
nginx配置了WebSocket 谷歌浏览器会报404.

用域名访问项目没问题,用域名访问项目WebSocket功能谷歌浏览器就报 WebSocket connection to 'ws://sodb.qdairport.com/qdsodb/websocket/admin' failed: Error during WebSocket handshake: Unexpected response code: 404 用ip加端口访问项目WebSocket功能可以正常连接上 nginx配置文件 #user nobody; worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #设置允许上传内容大小 client_max_body_size 200M; client_body_buffer_size 128k; gzip on; #配置域名和ip upstream sodb.qdairport.com { server 10.48.1.16:8080 weight=1; #权重为1 server 10.48.1.17:8080 weight=1; #权重为2 } server { listen 80; server_name sodb.qdairport.com; location / { proxy_pass http://sodb.qdairport.com; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_connect_timeout 3; proxy_read_timeout 3600; proxy_send_timeout 60; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } } } ``` ```

WebSocket建立连接时候发生404错误,不知道是路径还是其他什么错误

初学WebSocket,做了一个Demo,出现404错误。 WebSocket connection to 'ws://localhost:8088/chat/begin?uname=xiaoming' failed: Error during WebSocket handshake: Unexpected response code: 404 JS代码: ``` var chat={}; chat.socket=null; var uname="<%=request.getSession().getAttribute("uname")%>" function conn(){ connect("ws://localhost:8088/chat/begin?uname="+uname); } function connect(host){ if("WebSocket" in window){ chat.socket=new WebSocket(host); }else if("MoWebSocket" in window){ chat.socket=new MoWebSocket(host); }else{ console.log("当前浏览器不支持WebSocket"); return; } } ``` 后台终端代码: ``` @ServerEndpoint("/begin") public class ChatServer { @OnOpen public void start(Session session){ System.out.println(session.getQueryString()); } } ``` 使用的是eclipse开发,Web服务器使用Tomcat7,jdk版本是1.8。

websocket jsp端出现404

tomcat 8 jdk 1.7 eclipse中Build id: 20140925-1800 在java后台写的websocket前端jsp中始终出现404的错误,网上查了下有说差jar包的有说tomcat 7以上的,我这都满足了要求为什么还要报错呢?请各位帮我看看嘛 ![这是我在网上查的所要的jar包](https://img-ask.csdn.net/upload/201604/13/1460514758_283083.jpg) ![这是后台的java代码](https://img-ask.csdn.net/upload/201604/13/1460514811_436826.jpg) @ServerEndpoint(value = "/websocket/chat") public class ChatAnnotation { private static final Log log = LogFactory.getLog(ChatAnnotation.class); private static final String GUEST_PREFIX = "Guest"; private static final AtomicInteger connectionIds = new AtomicInteger(0); private static final Map<String,Object> connections = new HashMap<String,Object>(); private final String nickname; private Session session; public ChatAnnotation() { nickname = GUEST_PREFIX + connectionIds.getAndIncrement(); } @OnOpen public void start(Session session) { this.session = session; connections.put(nickname, this); String message = String.format("* %s %s", nickname, "has joined."); broadcast(message); } @OnClose public void end() { connections.remove(this); String message = String.format("* %s %s", nickname, "has disconnected."); broadcast(message); } /** * 消息发送触发方法 * @param message */ @OnMessage public void incoming(String message) { // Never trust the client String filteredMessage = String.format("%s: %s", nickname, HTMLFilter.filter(message.toString())); broadcast(filteredMessage); } @OnError public void onError(Throwable t) throws Throwable { log.error("Chat Error: " + t.toString(), t); } /** * 消息发送方法 * @param msg */ private static void broadcast(String msg) { if(msg.indexOf("Guest0")!=-1){ sendUser(msg); } else{ sendAll(msg); } } /** * 向所有用户发送 * @param msg */ public static void sendAll(String msg){ for (String key : connections.keySet()) { ChatAnnotation client = null ; try { client = (ChatAnnotation) connections.get(key); synchronized (client) { client.session.getBasicRemote().sendText(msg); } } catch (IOException e) { log.debug("Chat Error: Failed to send message to client", e); connections.remove(client); try { client.session.close(); } catch (IOException e1) { // Ignore } String message = String.format("* %s %s", client.nickname, "has been disconnected."); broadcast(message); } } } /** * 向指定用户发送消息 * @param msg */ public static void sendUser(String msg){ ChatAnnotation c = (ChatAnnotation)connections.get("Guest0"); try { c.session.getBasicRemote().sendText(msg); } catch (IOException e) { log.debug("Chat Error: Failed to send message to client", e); connections.remove(c); try { c.session.close(); } catch (IOException e1) { // Ignore } String message = String.format("* %s %s", c.nickname, "has been disconnected."); broadcast(message); } } } ![这是html中的调用后台的ws](https://img-ask.csdn.net/upload/201604/13/1460514862_61891.jpg) <!DOCTYPE HTML> <html> <head> <script type="text/javascript"> function WebSocketTest() { if ("WebSocket" in window) { alert("WebSocket is supported by your Browser!"); // Let us open a web socket var ws = new WebSocket("ws://192.168.2.158:8080/WebRTC/websocket/chat"); ws.onopen = function() { // Web Socket is connected, send data using send() ws.send("Message to send"); alert("Message is sent..."); }; ws.onmessage = function (evt) { var received_msg = evt.data; alert("Message is received..."); }; ws.onclose = function() { // websocket is closed. alert("Connection is closed..."); }; } else { // The browser doesn't support WebSocket alert("WebSocket NOT supported by your Browser!"); } } </script> </head> <body> <div id="sse"> <a href="javascript:WebSocketTest()">Run WebSocket</a> </div> </body> </html> ![这是tomcat8中server.xml配置访问的项目路径](https://img-ask.csdn.net/upload/201604/13/1460514886_438147.jpg)

外网访问时websocket报错404何解?

使用tomcat的websocket,但是出现用域名绑定后内网访问websocket成功,但是外网访问websocket后页面报错404,后台无报错,百度了下都说是tomcat7下的jar包冲突,但尝试了好像并不是这么回事...求大佬解救一下!!!!![图片说明](https://img-ask.csdn.net/upload/201909/27/1569575833_322304.jpg)

Spring 下websock注解方式注册,chrome连接一直报404错误

Spring4.0,用的是注解配置类的方式注册websocket,chrome一直报404错误,后台代码如下@Configuration @EnableWebMvc @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { registry.addHandler(new WebSocketHander(),"/new").addInterceptors(new HandshakeInterceptor()); --- 前台代码: if ('WebSocket' in window) { websocket = new WebSocket("ws://localhost:8080/MyWebSocket/new"); ----- 请问哪里写错了呢!第一次用!

springmvc 整合websocket 报错 404

第一: pom 配置文件: <dependency> <groupId>javax.websocket</groupId> <artifactId>javax.websocket-api</artifactId> <version>1.0</version> <scope>provided</scope><!--这个是从网上看的是为了解决jar包冲突的 --> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-websocket</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-messaging</artifactId> <version>4.1.6.RELEASE</version> </dependency> 第二步: 【注册,启动 websocket server 和 握手拦截器 】 @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { System.out.println("....注册......"); registry.addHandler(myhandler(), "/websocket").addInterceptors(myInterceptors()).setAllowedOrigins("*"); registry.addHandler(myhandler(), "/sockjs/websocket").addInterceptors(myInterceptors()).withSockJS(); } @Bean public WebSocketHandler myhandler() { System.out.println("....服务端......"); return new WebsocketEndPoint(); } @Bean public HandshakeInterceptor myInterceptors() { System.out.println("....握手拦截器......"); return new HandshakeInterceptor(); } } public class WebsocketEndPoint extends TextWebSocketHandler { private Logger logger = LoggerFactory.getLogger(WebsocketEndPoint.class); @Override protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { super.handleTextMessage(session, message); logger.debug("GOMA === > WebSocketEndPoint.handlerTextMessage..."); TextMessage returnMessage = new TextMessage(message.getPayload()+" received at server"); session.sendMessage(returnMessage); } } public class HandshakeInterceptor extends HttpSessionHandshakeInterceptor { private Logger logger = Logger.getLogger(getClass()); @Override public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Map<String, Object> attributes) throws Exception { logger.debug("GOMA ===> Before Handshake"); return super.beforeHandshake(request, response, wsHandler, attributes); } @Override public void afterHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Exception ex) { logger.debug("GOMA ===> After Handshake"); super.afterHandshake(request, response, wsHandler, ex); } } 第三步:页面 client 我的tomcat 的端口是 9018 socket = new WebSocket('ws://localhost:9018/testSocket/websocket'); 运行报错: WebSocket connection to 'ws://localhost:9018/testSocket/websocket' failed: Error during WebSocket handshake: Unexpected response code: 400 这是为啥? 都配置了 ,为啥 是404 奇怪~~~ 那个大神给我解决一下

Javaweb使用websocket时候产生404错误,后台无报错

web服务器:tomcat8,用eclipse开发,导入了websocket需要的jar包,建立连接成功,但是在后台终端向前台发送数据时候,出现 **Uncaught TypeError: Cannot set property 'onmessage' of null** 已经查阅网上各种有关资料了,依然不能解决这个问题,希望大神帮忙看下哪里出问题了。下面贴出代码 前端代码: ``` <script type="text/javascript"> //建立websocket对象 var chat={}; chat.socket=null; var uname='<%=request.getSession().getAttribute("uname")%>'; function conn() { //执行建立连接 connect("ws://localhost:8085/chat/begin?uname="+uname); chat.socket.onmessage=function(event){ console.log(event.data) } } function connect(host){ if("WebSocket" in window){ socket=new WebSocket(host); }else if("MoWebSocket" in window){ socket=new MoWebSocket(host); }else{ console.log("当前浏览器不支持socket"); return; } } </script> ``` 后台终端代码: ``` @ServerEndpoint("/begin") public class ChatServer { Session session; private String uname; private static Map<String,ChatServer> member=new HashMap<String,ChatServer>(); @OnOpen public void start(Session session){ this.session=session; String []art=session.getQueryString().split("="); System.out.println(art[1]); if(art.length>=2){ this.uname=art[1]; member.put(uname, this); } } private void welcome(){ for(ChatServer mem: member.values()){ if(mem==this){ this.send("欢迎您登录成功"); }else{ mem.send("欢迎"+this.uname+"登录"); } } } private void send(String message){ try { session.getBasicRemote().sendText(message); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } ``` ServerApplicationConfig: ``` public class Scanner implements ServerApplicationConfig{ @Override public Set<Class<?>> getAnnotatedEndpointClasses(Set<Class<?>> arg0) { return arg0; } @Override public Set<ServerEndpointConfig> getEndpointConfigs(Set<Class<? extends Endpoint>> arg0) { return null; } } ```

springMVC中使用websocket报错404

![图片说明](https://img-ask.csdn.net/upload/201612/01/1480567442_423163.png) ## 似乎是springmvc拦截了ws请求,怎么才能让springMVC不拦截WS呢 JS代码 ``` var websocket = null; //判断当前浏览器是否支持WebSocket if('WebSocket' in window){ websocket = new WebSocket("ws://localhost:8080/VM2.0/websocket"); } else{ alert('浏览器不支持websocket,请更换浏览器'); }; //连接发生错误的回调方法 websocket.onerror = function(){ console.log("websocket连接失败"); }; //连接成功建立的回调方法 websocket.onopen = function(event){ console.log("websocket连接成功"); }; ``` java代码 ``` //静态变量,用来记录当前在线连接数。应该把它设计成线程安全的。 private static int onlineCount = 0; //concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。若要实现服务端与单一客户端通信的话,可以使用Map来存放,其中Key可以为用户标识 private static CopyOnWriteArraySet<MySocket> webSocketSet = new CopyOnWriteArraySet<MySocket>(); //与某个客户端的连接会话,需要通过它来给客户端发送数据 private Session session; /** * 存储当前有效的session对象 */ private static Queue<Session> sessionSet = new ConcurrentLinkedQueue<Session>(); /** * 连接建立成功调用的方法 * @param session 可选的参数。session为与某个客户端的连接会话,需要通过它来给客户端发送数据 */ @OnOpen public void onOpen(Session currentSession){ if(sessionSet.contains(currentSession) == false){ sessionSet.add(currentSession); System.out.println("WebSocketTest.onOpen()================Add=" + sessionSet.size()); } System.out.println("Server say:Client connected"); } ```

Websocket握手失败404(golang服务器)

<div class="post-text" itemprop="text"> <p>I have a simple go web server which serves on port localhost:8080 an public folder containing both an html file as well as a client script with websocket logic.</p> <p>in my <a href="https://gist.github.com/Kielan/98706aaf5dc0be9d6fbe" rel="nofollow">main.go file</a></p> <pre><code>listener, err := net.listen("tcp", "localhost:8080") if err != nil { log.Fatal(err) } //full code in gist https://gist.github.com/Kielan/98706aaf5dc0be9d6fbe </code></pre> <p>then in my client script </p> <pre><code>try { var sock = new WebSocket("ws://127.0.0.1:8080"); console.log("Websocket - status: " + sock.readyState); sock.onopen = function(message) { console.log("CONNECTION opened..." + this.readyState); //onmessage, onerr, onclose, ect... } </code></pre> <p>I get the error in chrome</p> <pre><code>WebSocket connection to 'ws://127.0.0.1:8080/' failed: Error during WebSocket handshake: Unexpected response code: 200 </code></pre> <p>and Firefox</p> <pre><code>Firefox can't establish a connection to the server at ws://127.0.0.1:8080/. </code></pre> <p>I found <a href="http://procbits.com/connecting-to-a-sockjs-server-from-native-html5-websocket" rel="nofollow">this article</a> referring to node.js indicating to add /websocket to my client websocket string, though it did not solve the problem and resulted in a 404</p> <p>I thought response code 200 is good, do I need to convert the request to a websocket somehow and maybe it is defaulting to http? If so how can I do this?</p> </div>

求助!websocket连接后端一直不返回连接成功

前端 let wsuri= global.wsURL+"/slims/v1/websocket/"; if ("WebSocket" in window) { console.log("您的浏览器支持查看在线人数") } else { alert('当前浏览器不支持查看人员在线状态'); } this.websockt = new WebSocket(wsuri); this.websockt.onmessage = this.websocketonmessage; this.websockt.onerror = this.websocketonerror; this.websockt.onclose = this.websocketclose; this.websockt.onopen =this.websocketonopen; // Web Socket 已连接上,使用 send() 方法发送数据s console.log('数据发送中...') this.websockt.send('Holle') console.log('数据发送完成') } this.websockt.send = this.websocketsend; }, websocketonopen(){ //连接建立之后执行send方法发送数据 console.log("xxxx"); }, websocketonerror(){//连接建立失败重连 console.log("重新连接") this.initWebSocket(); }, websocketonmessage(e){ //数据接收 console.log("数据接收") }, websocketsend(Data){//数据发送 console.log("数据发送"); this.websockt .send("幸福9999");debugger alert(8888); }, websocketclose(e){//关闭连接 console.log("关闭连接") this.websockt.onclose(); }, }, 后台 : @OnOpen public void onOpen(Session session, EndpointConfig sce) throws IOException { this.session = session; //Object转换成Long Long uuid = Long.valueOf(String.valueOf(sce.getUserProperties().get("uuid"))); if (null == uuid) { onClose(); } webSocketSet.add(this); //线程安全的原子数+1 subOnlineCount(); System.out.println("有链接加入,当前人数为:" + getOnline_num()); this.session.getAsyncRemote().sendText("有链接加入,当前人数为:" + getOnline_num()); map.put(session, uuid); System.out.println("当前登录人uid" + uuid); String stats = "0"; //是首次登陆的人 if (0 == userSocketService.list(Condition.create().eq("uid", uuid)).size()) { UserSocket usersocket = new UserSocket(); usersocket.setUid(uuid); usersocket.setStats(stats); usersocket.setCompany_id(0L); userSocketService.saves(usersocket); } else { UserSocket usersocket = new UserSocket(); usersocket.setUid(uuid); usersocket.setStats("0"); userSocketService.update(usersocket, Condition.create().eq("uid", uuid)); } sendMessage("------------------------后台-----) 可以连接上,但是没法发消息,正常这里应该显示状态码是101的,但是一直显示在链接中明明后台已经收到请求了,到底是怎么回事呢? ![图片说明](https://img-ask.csdn.net/upload/201810/17/1539757022_269768.png)

手机浏览器websocket,无法连接一直error

``` var websocket = null; if ('WebSocket' in window) { websocket = new WebSocket("ws://localhost:8080/springws/websocket/socketServer.do"); } else if ('MozWebSocket' in window) { websocket = new MozWebSocket("ws://localhost:8080/springws/websocket/socketServer.do"); } else { websocket = new SockJS("http://localhost:8080/springws/sockjs/socketServer.do"); } websocket.onopen = onOpen; websocket.onmessage = onMessage; websocket.onerror = onError; websocket.onclose = onClose; ``` 一直是监听到error,请问有了解的吗。 电脑端浏览器是正常的,手机浏览器检测有WebSocket

spring整合websocket出错,Unexpected response code: 404

1. 下面是代码: public class MarcoHandler extends AbstractWebSocketHandler { @Override protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { System.out.println("Received message:"+message.getPayload()); Thread.sleep(2000); session.sendMessage(new TextMessage("Polo!")); } } websocket的xml配置 <websocket:handlers> <websocket:mapping handler="marcoHandler" path="/marco"/> </websocket:handlers> <bean id="marcoHandler" class="com.camle.entity.MarcoHandler"/> web.xml的配置 ``` <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:websocket.xml</param-value> </context-param> ``` javascript代码 <script type="text/javascript"> var url = 'ws://'+window.location.host+'/mvcAndWebsocket/marco'; var sock = new WebSocket(url); sock.onopen = function(){ console.log('Opening'); sayMarco(); }; sock.onmessage = function(e){ console.log('Received message:',e.data); setTimeout(function(){sayMarco()},2000); }; sock.onclose = function(){ alert(window.location.host); console.log('Closing'); }; function sayMarco(){ console.log('Sending Marco!'); sock.send('Marco!'); } </script>

springcloud下websocket无法通过网关连接

在springcloud下使用websocket,前端框架使用vue 若前端直接调用websocket的服务(不走网关),则可正常连接(url: http://localhost:8604/webSocketServer)) 若前端通过网关来连接websocket的服务,则会报404和一些跨域的问题。(url: http:localhost:9091/system-otherService/webSocketServer) 注: 8604为webSocket服务的端口,9091为网关的端口 前端: ![图片说明](https://img-ask.csdn.net/upload/201808/24/1535099271_464422.png) 后台: websocket配置: ![图片说明](https://img-ask.csdn.net/upload/201808/24/1535099351_587376.png) 网关路由![图片说明](https://img-ask.csdn.net/upload/201808/24/1535099397_526124.png) network: ![图片说明](https://img-ask.csdn.net/upload/201808/24/1535099412_427241.png) 错误信息:![图片说明](https://img-ask.csdn.net/upload/201808/24/1535099424_768522.png)

请问springmvc+websocket为什么总是连接不上,报404

![图片说明](https://img-ask.csdn.net/upload/201707/31/1501496072_609731.png) ![图片说明](https://img-ask.csdn.net/upload/201707/31/1501496082_272303.png)

websocket注解方式下URL错误?

我用的是Spring+ibatis框架 服务器是tomcat7.0.64 ; jdk版本是7 使用Websocket注解方式实现 但是URL在浏览器中一直报404 java后台: @ServerEndpoint(value = "/websocket") 前端HTML的js: var webSocket = new WebSocket('ws://localhost:8080/projectName/websocket');

websocket问题 ,请大神指教

初学websocket 为什么访问一直不对啊 代码贴出来 -------------------------------------------------------- <script type="text/javascript"> function subOpen(){ var ws; var target="ws://localhost:8080/websocket/demo"; if ('WebSocket' in window) { ws = new WebSocket(target); } else if ('MozWebSocket' in window) { ws = new MozWebSocket(target); } else { alert('WebSocket is not supported by this browser.'); return; } } </script> ----------------------------------------- @ServerEndpoint("/demo") public class DemoSocket { @OnOpen public void open(Session session){ System.out.println(session.getId()+"--------------"); } } 打印不出来。。。

webSocket客户端报302,不知道哪里写错了。

请看下面代码: ``` <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!doctype html> <html> <head> <meta charset="UTF-8" content="text/html"> <meta name="Keywords" content=""> <meta name="Description" content=""> <title>基于Java服务端消息主动推送技术</title> <style type="text/css"> *{ margin:0; padding:0; } body{ background:url("image/bg.jpg") no-repeat; background-size:cover; } .chatbox{ width:700px; height:500px; margin:100px auto; font-size:12px; font-family:"微软雅黑"; color:#666; } h1{ text-align:center; font-size:30px; color:green; text-shadow:5px 10px 10px #111; } .chatbox .c_info{ text-align:left; line-height:46px; } .inputText{ height:30px; border:0; outline:none; text-indent:1em; font-size:14px; font-family:"微软雅黑"; color:#61B52D; border: 1px solid #61B52D; } .btn{ width:80px; text-indent:0; background:#9AD02D; color:#fff; margin-left: 10px; } .chatbox .c_message{ width:97%; height:300px; overflow:auto; border:1px solid yellow; font-size:24px; color:#9DA791; padding-left:20px; box-shadow:2px 10px 10px #111; /* background: #EAF9BE; */ } .chatbox .c_send{ margin-top: 10px; } </style> </head> <body> <div class="chatbox"> <h1>基于Java服务端消息主动推送技术</h1> <div class="c_info"> 服务器地址:<input type="text" value="localhost:8080/webSocket" id="addr" class="inputText" style="width:350px"/> 用户名:<input type="text" value="Yinwq" id="userName" class="inputText"/> <input type="button" id="con" class="inputText btn" value="连接" /> </div> <div class="c_message"> </div> <div class="c_send"> <input type="text" id="sendText" class="inputText" style="width:592px" /> <input type="button" id="sendBtn" class="inputText btn" value="发送" /> </div> </div> </body> <!-- 引入jquery类库 --> <script type="text/javascript" src="js/jquery-1.11.2.min.js"></script> <script type="text/javascript"> var connected = false; var ws; $(function(){ $(".c_send").hide(); //1.判断浏览器是否支持webSocket if(window.WebSocket || window.MozWebSocket){ printMsg("您的浏览器支持WebSocket,您可以尝试连接到聊天服务器!" , "OK"); }else{ printMsg("您的浏览器不支持WebSocket,您可以换其他浏览器!" , "ERROR"); $("#con").attr("disabled","true"); } }) //打印信息 function printMsg(msg,msgType){ if(msgType == "OK"){ msg = "<span style='color:green'>"+msg+"</span>"; } if(msgType == "ERROR"){ msg = "<span style='color:red'>"+msg+"</span>" } $(".c_message").append(msg + "<br/>"); } //点击连接的时候触发事件 $("#con").click(function(){ if(connected){ //已连接 ws.send("["+$("#userName").val()+"]离开了聊天室"); connected = false; ws.close(); }else{//没有连接 printMsg("正在准备连接,请稍等!", ""); var url = "ws://"+ $("#addr").val(); if("WebSocket" in window){ //ws = new WebSocket(url); ws = new WebSocket('ws://localhost:8080/webSocket'); }else if ("MozWebSocket" in window) { ws = new MozWebSocket(url); } //连接成功后设置连接状态 connected = true; $("#con").val("断开"); //注册事件 ws.onopen = function(event){ openWs(event); }; ws.onmessage = function(event){ msgWs(event); }; ws.onclose = function(event){ closeWs(event); }; ws.onerror = function(event){ errorWs(event); }; } }); //打开socket function openWs(event){ printMsg("连接已建立...!", "OK"); //建立连接的时候 ws.send("["+$("#userName")+"]进入了聊天室"); $(".c_send").show(); }; //接收消息 function msgWs(event){ printMsg(evnet.data); }; //关闭连接 function closeWs(event){ $("#con").val("连接"); //隐藏发送div $(".c_send").hide(); }; //产生错误 function errorWs(event){ printMsg("与服务器连接错误.." , "ERROR"); }; //点击发送触发事件 $("#sendBtn").click(function(){ //获取发送内容 var text = $("#sendText").val(); ws.send($("#userName").val() + "说:" + text); $("#sendText").val("");//清空发送框 }); </script> </html> ``` 浏览器报错 ![图片说明](https://img-ask.csdn.net/upload/201601/11/1452477841_505407.png) ![图片说明](https://img-ask.csdn.net/upload/201601/11/1452477853_561170.png)

netty websocket服务ie报证书错误

netty提供的websocket服务,采用SSL安全协议。证书库使用的是tomcat.keystore。证书无效。现在问题是,无效证书在chrome,opera,safari下可以正常访问wss协议下的websocket,在IE,edge,firefox下无法访问 握手不成功 。使用的是tomcat提供的websocket,没有问题。现在需要采用netty实现的websocket

websocket httpsession return null

我在做spring mvc+websocket时遇到session为null的问题。 ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462784616_157633.jpg) 我在登录的controller里记录了session ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462784683_952487.jpg) 我查到网上有一个解释是httpsession创建早于websocket, ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462784797_681397.jpg) 具体的链接是http://stackoverflow.com/questions/20240591/websocket-httpsession-returns-null。 我不知道如何保证ServletRequestListener早于WebSocket?或者利用其它方式可以解决? 我的一些配置如下: WebsocketEndPoint ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462784938_20263.jpg) spring.xml ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462785045_930020.jpg) ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462785057_619415.jpg) jsp ![图片说明](https://img-ask.csdn.net/upload/201605/09/1462785072_885923.jpg)

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

再不跳槽,应届毕业生拿的都比我多了!

跳槽几乎是每个人职业生涯的一部分,很多HR说“三年两跳”已经是一个跳槽频繁与否的阈值了,可为什么市面上有很多程序员不到一年就跳槽呢?他们不担心影响履历吗? PayScale之前发布的**《员工最短任期公司排行榜》中,两家码农大厂Amazon和Google**,以1年和1.1年的员工任期中位数分列第二、第四名。 PayScale:员工最短任期公司排行榜 意外的是,任期中位数极小的这两家公司,薪资...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

数据库——玩转SQL语句(以MySQL为例)

一、前言 照着大学的SQL server来学

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

程序员写出这样的代码,能不挨骂吗?

当你换槽填坑时,面对一个新的环境。能够快速熟练,上手实现业务需求是关键。但是,哪些因素会影响你快速上手呢?是原有代码写的不够好?还是注释写的不够好?昨夜...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

01、Java入门(Getting Started);02、集成开发环境(IDE);03、项目结构(Eclipse JavaProject);04、类和对象(Classes and Objects);05:词法结构(Lexical Structure);06:数据类型和变量(Data Type and Variables);07:运算符(Operators);08:控制流程语句(Control Flow Statements);

Java岗开发3年,公司临时抽查算法,离职后这几题我记一辈子

前几天我们公司做了一件蠢事,非常非常愚蠢的事情。我原以为从学校出来之后,除了找工作有测试外,不会有任何与考试有关的事儿。 但是,天有不测风云,公司技术总监、人事总监两位大佬突然降临到我们事业线,叫上我老大,给我们组织了一场别开生面的“考试”。 那是一个风和日丽的下午,我翘着二郎腿,左手端着一杯卡布奇诺,右手抓着我的罗技鼠标,滚动着轮轴,穿梭在头条热点之间。 “淡黄的长裙~蓬松的头发...

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

立即提问
相关内容推荐