Jetty9 搭建WebSocket简单例子

本文介绍了如何在Eclipse上使用Jetty下载最新版本并搭建基本的WebSocket服务,包括所需类库、创建简单Web服务及WebSocketServlet实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载

最新的下载的地址已经移动到eclipse上:http://www.eclipse.org/jetty/downloads.php

目前的版本为9.0.0.M3

JDK版本要求7


所需要的类库


下载下来后,JETTY带了非常多的类库,经过测试发现,最简答的例子仅仅需要

javax.websocket-api-0.0.006.draft.jar
jetty-http-9.0.0.M3.jar
jetty-io-9.0.0.M3.jar
jetty-security-9.0.0.M3.jar
jetty-server-9.0.0.M3.jar
jetty-servlet-9.0.0.M3.jar
jetty-util-9.0.0.M3.jar
servlet-api-3.0.jar
websocket-api-9.0.0.M3.jar
websocket-common-9.0.0.M3.jar
websocket-server-9.0.0.M3.jar
websocket-servlet-9.0.0.M3.jar


创建最简单的WEB服务

建立Eclipse后,先建立一个启动类

Server server = new Server(8080);
try {
	server.start();
	server.join();
} catch (Exception e) {

	e.printStackTrace();
}

这样一个最简单对外提供WEB服务,默认都返回404




创建一个WebSocketServlet

从官网查看例子,MyEchoSocket和MyEchoServlet,BAIDU一下也有很多转载

唯一的变化是在接受请求连接的时候,向客户端发送一个包

	@Override
	public void onWebSocketConnect(WebSocketConnection connection) {
		this.outbound = connection;
		try {
			outbound.write("ok");
		} catch (IOException e) {
			e.printStackTrace();
		}
	}


加入到Server中
		Server server = new Server(8080);
		try {
			HandlerList handlerList = new HandlerList();
			ServletContextHandler context = new ServletContextHandler(
					ServletContextHandler.SESSIONS);
			context.setContextPath("/");
			context.addServlet(new ServletHolder(new MonitorStatusServlet()),
					"/monitor");
			context.addServlet(new ServletHolder(new MyEchoServlet()), "/echo");
			handlerList.addHandler(context);
			handlerList.addHandler(new DefaultHandler());
			server.setHandler(handlerList);

			server.start();
			server.join();
		} catch (Exception e) {

			e.printStackTrace();
		}

	}


其中MonitorStatusServlet是返回当前的状态,DefualtHandler用于实现其它任何请求都返回FORBIDDEN

/echo则调用WebSocket


编写客户端测试


<script type="text/javascript">
	var url = "ws://192.168.1.200:8080/echo";
	
	
	if(window.MozWebSocket) {
		this.connection = new MozWebSocket(url);
	} else {
		this.connection = new WebSocket(url);
	}

	 this.connection.onmessage = function(e) {
		alert(e.data);
	};

	this.connection.onopen = function(e) {
		this.connection.send("123456");
	};

	


            
</script>






### 关于 Navicat Premium 16 定时导出导入的配置教程 Navicat Premium 16 提供了一种便捷的方式来实现数据库的定时导出导入操作。通过其内置的任务调度功能,可以轻松安排定期执行的数据传输、备份或其他自动化任务[^3]。 #### 配置定时导出/导入的方法 1. **打开“计划”窗口** 启动 Navicat Premium 16 并连接到目标数据库后,在顶部菜单栏中选择 `工具` -> `计划`,或者右键单击某个已建立的连接并选择 `新建计划`[^4]。 2. **创建新计划** 在弹出的对话框中点击 `新建` 按钮来定义一个新的计划任务。此时会出现一个向导界面,引导用户逐步完成任务的设定。 3. **选择任务类型** 当前支持多种任务类别,对于导出导入需求而言,应分别选取如下选项: - 导出:选择 “数据传输” 类型。 - 导入:同样可选 “数据传输”,只需调整源与目标的方向即可[^4]。 4. **指定数据范围** 接下来需明确哪些表或视图参与此次操作。可以通过勾选具体对象列表中的条目来进行精确控制;也可以采用通配符批量处理整个模式下的所有实体[^4]。 5. **设置存储路径** 对于导出作业来说,必须指明文件保存的位置及其格式(CSV, Excel, TXT 等)。而针对导入流程,则相反地需要提供原始资料所在地址以及匹配的目标结构[^4]。 6. **规划触发时间** 利用内嵌的日历控件配合时刻参数输入框,准确划定初次启动日期及时刻,并决定后续重复频率(每日、每周、每月或是自定义间隔)[^3]。 7. **高级属性定制** 如果必要的话,还可以进一步优化邮件通知机制、错误重试策略等方面的内容以增强可靠性。 8. **验证与激活** 最终审查各项参数无误之后提交确认,这样就成功建立了所期望的功能实例。记得启用开关使其生效[^4]。 ```bash # 示例命令行模拟手动测试脚本 (仅作参考用途) navicatcli --export source_db="my_database" target_file="/path/to/exported_data.csv" navicatcli --import source_file="/another/path/import_source.json" destination_table="new_records" ``` 以上便是利用 Navicat Premium 16 设置周期性数据迁移的基本步骤概述。实际应用当中可能还会涉及到更多细节考量因素,请参照官方文档获取最权威指导信息[^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值