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

一、开发环境:

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中增加:

		
			org.apache.tomcat
		    tomcat-websocket-api
		    7.0.64
		    provided
		

参照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

你可能感兴趣的:(Tomcat下开发websocket进行二维码扫码登录)