我们使用geronimo-servlet 3.0
和Tomcat 8
来运行一个servlet,它将使用如下的会话
@Service
public class SessionServiceImpl implements SessionService
{
@Autowired(required = false)
private HttpServletRequest request;
private HttpSession session = null;
@Override
public void setUser(User user)
{
session = request.getSession();
if (session != null)
{
session.setAttribute(SessionAttribute.user.name(), user);
}
}
@Override
public void setData(String data)
{
session = request.getSession();
if (session != null)
{
session.setAttribute(SessionAttribute.data.name(), data);
}
}
@Override
public HttpSession getSession()
{
session = request.getSession();
session.setAttribute("TimeoutBased", System.currentTimeMillis());
return session;
}
}
在其他服务中,例如,AuthService调用sessionService,如下所示
public class AuthServiceImpl extends CustomizedServlet implements AuthService
{
@Autowired
private SessionService sessionService;
@Override
public BaseModel login(BaseModel user) {
...
sessionService.setUser(userEntity);
...
sessionService.setData(data);
}
}
CustomizedServlet是GWT的com.google.gwt.user.server.rpc.RemoteServiceServlet
。登录方法是Web客户端登录。这一切都正常。
但是,有时,由于未知原因,Google Chrome浏览器打开的每个请求都会更改会话。
此外,在调试模式下,我看到会话ID在一个请求中保持更改,如下图所示。
第一个请求响应如下
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Set-Cookie: JSESSIONID=53144E2C46D6DF7C5986D56F01A6961E; Path=/ABC/; HttpOnly
Content-Encoding: gzip
Content-Disposition: attachment
Content-Type: application/json;charset=utf-8
Content-Length: 1909
Date: Tue, 07 Mar 2017 01:42:13 GMT
彗星的另一个servlet是第二个请求,请求中没有jsessionid
GET /ABC/CometServlet?qndOeINh HTTP/1.1
Host: web.test.abc.com:8080
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36
Content-Type: application/x-javascript;
Accept: */*
Referer: http://web.test.abc.com:8080/ABC/
Accept-Encoding: gzip, deflate, sdch
Accept-Language: zh-TW,zh;q=0.8,ja;q=0.6
Cookie: username=%7B%22state%22%3A%22s%3Aadmin%22%7D;
毕竟,如果我清除chrome的网站数据,它会继续正常工作。尚未弄清楚这种情况的根本原因。有没有人有经验或有任何想法?
答案 0 :(得分:0)
不知道这是否有帮助,但我也遇到了会话问题。 JSESSIONID正在改变每个请求的值。这只是由JSF标记引起的:
<h:link outcome="${loguinBean.logOut()}" value="LogOut" />
出于某种原因,当我成功登录并刷新页面时,会话将不断丢失。删除该标记并将其替换为<h:commandLink>
内的<h:form>
后,一切正常。