我们先来验证一下之前我们的用户信息是否保存在session中,我们在主系统的首页来显示用户的信息:
这个位置如果出现了用户的信息,说明我们的session封装信息成功!
我们在主页的欢迎xxx部分添加session中保存的user的name值的显示:
- <td align="right">
- <a><b></b><font color="red">欢迎您, <s:property value="#session.SYS_USER.name"/>
- </font></a>
- </td>
接下来是所属部门:
- <tr>
- <td colspan="2">所属部门:
- <s:property value="#session.SYS_USER.dept"/></td>
- </tr>
然后是头像(有头像显示头像,没有显示默认头像):
- <td width="76" height="100" align="center" valign="middle">
- <div class="left-tx">
- <s:if test="%{#session.SYS_USER.headImg != null && #session.SYS_USER.headImg !=''}">
- <img src="${ctx}/upload/<s:property value='#session.SYS_USER.headImg'/>" width="70" height="70" />
- </s:if><s:else>
- <img src="${ctx}/images/home/gs09.png" width="70" height="70" />
- </s:else>
- </div>
- </td>
然后重启服务器,我们登录“李向阳”的账号密码,到主页时这三个地方分别显示:
接下来完成我们的“退出”功能(也即是注销,清除session中的用户信息):
我们在LoginAction添加logout()方法并添加如下语句:
- //退出,注销
- public String logout(){
- //清除session中的用户信息
- ServletActionContext.getRequest().getSession().removeAttribute(Constant.USER);
- return toLoginUI();
- }
然后在jsp界面上给退出加上链接:
- <td align="left" valign="middle" >
- <a href="${ctx }/sys/login_logout.action">退出
- </a></td>
但是我们还有一个致命的问题,即使我们做了登录,但是我们的页面链接是可以任意访问不用登录的,我们使用登录过滤器来解决这个问题。
我们要做一个登录校验,当用户试图访问一个页面的时候,我们检测其是否登录,没有登录的用户我们是不予显示信息的。
我们来设计我们的登录过滤器:
下面就开始编码实现:
LoginFilter.java
- package cn.edu.hpu.tax.core.filter;
- import java.io.IOException;
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import cn.edu.hpu.tax.core.content.Constant;
- public class LoginFilter implements Filter {
- @Override
- public void destroy() {
- }
- @Override
- public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse,
- FilterChain chain) throws IOException, ServletException {
- HttpServletRequest request=(HttpServletRequest)servletRequest;
- HttpServletResponse response=(HttpServletResponse)servletResponse;
- String uri=request.getRequestURI();
- //判断当前请求地址是否是登录地址
- if(!uri.contains("sys/login_")){
- //非登录请求
- if(request.getSession().getAttribute(Constant.USER)!=null){
- //说明已经登录过,放行
- chain.doFilter(request, response);
- }else{
- //没有登录,跳转到登录界面
- response.sendRedirect(request.getContextPath()+"sys/login_toLoginUI.action");
- }
- }else{
- //登录请求,直接放行
- chain.doFilter(request, response);
- }
- }
- @Override
- public void init(FilterConfig chain) throws ServletException {
- }
- }
然后在web.xml中配置过滤器(要放在struts拦截器的前面):
- <!-- struts2过滤器配置 -->
- <filter>
- <filter-name>loginFilter</filter-name>
- <filter-class>cn.edu.hpu.tax.core.filter.LoginFilter</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>loginFilter</filter-name>
- <url-pattern>*.action</url-pattern>
- </filter-mapping>
然后我们来验证一下,首先我们不登录,直接访问主页(http://localhost/HpuTax/sys/home.action),会发现其跳转到登录界面。说明我们拦截成功。
正常登录是成功的,登陆之后再跳转至其他页面也是可以的。
至此我们完成了登录的过滤器。