浏览 3037 次
锁定老帖子 主题:关于拦截器中对接口方法的使用的请教
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-05-28
但是在该session中存在的对象是put()时的对象,而不是与数据库同步更新的对象,即当我们update数据库中的数据该session中的数据会保持不变.我所遇到的问题就是由此产生的。 我这两天发了一篇帖子关于单用户登录,具体算法与实践都已经实施完成。并且在单独的action中也测试过这个单用户登录的功能。可是当我准备把它写成拦截器时,因为上述的那个问题,致使拦截器中代码条件永远满足 public String intercept(ActionInvocation invocation) throws Exception { Customer customer =(Customer) invocation.getInvocationContext().getSession().get("customer"); if(customer!=null){ HttpServletRequest request = ServletActionContext.getRequest(); HttpSession session = request.getSession(); String hashcode=session.getId(); if(hashcode!=null){ String hashcodetemp=customer.getPointcode(); if(hashcodetemp.equals(hashcode)){ ThreadLocalUser.set(customer); String result = invocation.invoke(); ThreadLocalUser.set(null); return result; } ActionContext.getContext().getSession().clear(); ActionSupport action = (ActionSupport) invocation.getAction(); action.addActionError("^o^你的账号已经在其它地方登录^o^"); return Action.LOGIN; } ActionSupport action = (ActionSupport) invocation.getAction(); return Action.LOGIN; } return Action.LOGIN; } 这就是我的拦截器代码 最主要的错误出现在这里 String hashcodetemp=customer.getPointcode(); 由于上述session中的问题,致使这个条件基本上永远满足。 因为只有这个customer对象是从数据库中查阅的,那么才能使得这个条件有判断作用。我也尝试过使用接口中的方法通过这个customerid来获得数据库中该对象.可一直达不到满足情况。另外我在测试action中测试过这个算法,具体代码如下,(效果成功) HttpServletRequest request=(HttpServletRequest)ActionContext.getContext().get(ServletActionContext.HTTP_REQUEST);//获得requset HttpSession session = request.getSession(); session.getId(); if(!session.getId().equals(customer.getPointcode())){ ActionContext.getContext().getSession().clear(); this.addActionMessage("^o^当前账户已经在其他地方登录,请重新登录^o^"); return INPUT; } 希望有兴趣或有这种经验的一起来探讨解决下 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-08-20
我也遇到和你一样的问题!!
主要问题是 调用DAO (我是调用DAO)层的时候!数据库的链接实例没有打开!! 拦截器有参数!<param></param> 中间有一个@符号!我在找这是什么意思! |
|
返回顶楼 | |