Tomcat下开发websocket进行二维码扫码登录

本文介绍了在Tomcat 7.0.64版本下,利用Java API for WebSocket (JSR 356) 和 SSH (Struts2, Spring, Hibernate) 开发二维码扫码登录的环境配置和开发过程。遇到的问题是Tomcat从7.0.73版本开始对URL的限制,通过修改`catalina.properties`文件解决。代码开发部分提到了pom.xml中添加的相关依赖,并推荐了使用qrcode.js和WebSocket进行web端实现。" 127945894,15389848,JAVA实现校园失物招领管理系统源码解析,"['JAVA开发', 'Spring框架', '前端开发', '数据库管理', 'Web应用']

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

一、开发环境:

tomcat(apache-tomcat-7.0.64),Java API for WebSocket(JSR 356),ssh(struts2-2.3.36,spring-3.2.7.RELEASE, hibernate-3.6.10.Final)

1:Tomcat从7.0.27开始支持WebSocket,从7.0.47开始支持JSR-356。刚开始本想使用apache-tomcat-7.0.90.但是启动后导致系统报错:Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC。经查找发现是由于在tomcat 7.0.73添加对http请求url的规范限制,不允许使用包含未编码的花括号的url进行请求。当然这个不是重点,重点是这个限制在tomcat 7.0.73中是必选的,这就导致一些现有网站要升级tomcat的时候出现严重的问题。所以在tomcat 7.0.73版本中,有人指出该限制做成必选属于BUG。于是在7.0.73版本后,tomcat维护者把该限制做成可选的,这个修改体现在tomcat中的 catalina.properties 文件中,该文件添加一个属性 tomcat.util.http.parser.HttpParser.requestTargetAllow=|。这个属性是用来决定是否限制不经过编码的花括号({})的,默认是注掉的,也就是说默认是限制的。但是把注释去掉后还是报错,所以选择了apache-tomcat-7.0.64。

2:代码开发

pom中增加:

		<dependency>
			<groupId>org.apache.tomcat</groupId>
		    <artifactId>tomcat-websocket-api</artifactId>
		    <version>7.0.64</version>
		    <scope>provided</scope>
		</dependency>

参照SR-356:https://www.oracle.com/technetwork/articles/java/jsr356-1937161.html开发java代码,

web代码:使用qrcode.js,浏览器自带websocket。

https://github.com/davidshimjs/qrcodejs

 

http://hc.apache.org/httpcomponents-client-4.5.x/tutorial/html/connmgmt.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值