WebSocket使用整理

java服务搭建及前端websocket测试

在MyEclipse中部署Tomcat
1.点击Window->Preferences->MyEclipse->Servers->Tomcat
2.选中你的Tomcat版本
3.设置为Enable
4.点击Tomcat home directory后的Brows…
5.找到Tomcat的根目录,点击确定,回到Tomcat页面点击Apply,点击OK

创建工程
1.File->New Service Project
2.输入工程名称,如WebSocketTest,点击Finish
3.右键工程->Build Path->Configure Build Path…->Libraries->Add External JARs…
4.将tomcat中lib目录下tomcat-websocket.jar和websocket-api.jar选中,点击打开,回到Build Path页面点击OK(测试时用的tomcat8.x)
5.点击Run右下角的Deploy MyEclipse J2EE Project to Server…
6.在Project中选中WebSocketTest,点击Add,在Server中选中Tomcat8.x,点击Finish(如果Server中没有Tomcat8.x,请先部署Tomcat)
7.在src中新建Class文件,如MyWebSocketTest,内容如下

import java.io.IOException;

import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;


@ServerEndpoint("/websocketTest")
public class MyWebSocketTest {
	@OnOpen
	public void onOpen(Session session){         
	   System.out.println("open succeed!");
	}
	
	@OnClose
	public void onClose(){
		System.out.println("close succeed!");
	}
	@OnMessage
	public void onMessage(String message, Session session) throws IOException, InterruptedException{
		
		System.out.println("Received: " + message);
		
		session.getBasicRemote().sendText("hi");
		Thread.sleep(5000);
		session.getBasicRemote().sendText("send over!");
	}
	
	@OnError
	public void onError(Session session, Throwable error){
		System.out.println("websocket error!");
	}
}

8.在WebRoot下新建index.html,内容如下

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>websocket test</title>
    </head>
    <body>
  <div>
    <input type="submit" value="Start" onclick="start()" />
  </div>
  <div id="messages"></div>
  <script type="text/javascript">
    var webSocket = 
      new WebSocket('ws://localhost:8080/MyWebSocketTest/websocketTest');

    webSocket.onerror = function(event) {
      onError(event)
    };

    webSocket.onopen = function(event) {
      onOpen(event)
    };

    webSocket.onmessage = function(event) {
      onMessage(event)
    };

    function onMessage(event) {
      document.getElementById('messages').innerHTML 
        += '<br />' + event.data;
    }

    function onOpen(event) {
      document.getElementById('messages').innerHTML 
        = 'Connection established';
    }

    function onError(event) {
      console.log(event.data);
    }

    function start() {
      webSocket.send('hello');
      return false;
    }
  </script>
    
    </body>
</html>

原文地址:

http://www.oschina.net/translate/java-ee-html5-websocket-example

运行后效果

这里写图片描述

python中websocket测试

测试代码:

import json
import base64
from websocket import create_connection


url = 'ws://192.168.81.88:1230'
ws = create_connection(url)
data = 'send info'
ws.send(data)
print('收到回复消息:', ws.recv())

ws.close()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力减肥的小胖子5

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值