【SSH项目实战】国税协同平台-16.登录过滤器
来源:互联网 发布:冒泡排序javascript 编辑:程序博客网 时间:2024/04/30 10:35
我们上一次做完了登录功能,也将登录信息保存在了session中,接下来我们来继续完善我们的登录部分。
我们先来验证一下之前我们的用户信息是否保存在session中,我们在主系统的首页来显示用户的信息:
这个位置如果出现了用户的信息,说明我们的session封装信息成功!
我们在主页的欢迎xxx部分添加session中保存的user的name值的显示:
接下来是所属部门:
然后是头像(有头像显示头像,没有显示默认头像):
然后重启服务器,我们登录“李向阳”的账号密码,到主页时这三个地方分别显示:
接下来完成我们的“退出”功能(也即是注销,清除session中的用户信息):
我们在LoginAction添加logout()方法并添加如下语句:
然后在jsp界面上给退出加上链接:
但是我们还有一个致命的问题,即使我们做了登录,但是我们的页面链接是可以任意访问不用登录的,我们使用登录过滤器来解决这个问题。
我们要做一个登录校验,当用户试图访问一个页面的时候,我们检测其是否登录,没有登录的用户我们是不予显示信息的。
我们来设计我们的登录过滤器:
下面就开始编码实现:
LoginFilter.java
然后在web.xml中配置过滤器(要放在struts拦截器的前面):
然后我们来验证一下,首先我们不登录,直接访问主页(http://localhost/HpuTax/sys/home.action),会发现其跳转到登录界面。说明我们拦截成功。
正常登录是成功的,登陆之后再跳转至其他页面也是可以的。
我们先来验证一下之前我们的用户信息是否保存在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 {@Overridepublic void destroy() { }@Overridepublic 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);}}@Overridepublic 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),会发现其跳转到登录界面。说明我们拦截成功。
正常登录是成功的,登陆之后再跳转至其他页面也是可以的。
至此我们完成了登录的过滤器。下一次我们完成权限的鉴定(不是想访问哪个模块就访问哪个模块的)。
转载请注明出处:http://blog.csdn.net/acmman/article/details/49658319
0 0
- 【SSH项目实战】国税协同平台-16.登录过滤器
- 【SSH项目实战】国税协同平台-16.登录过滤器
- SSH项目实战】国税协同平台-16.登录过滤器
- 【SSH项目实战】国税协同平台-14.系统、子系统首页&登录功能1
- 【SSH项目实战】国税协同平台-15.系统、子系统首页&登录功能2
- 【SSH项目实战】国税协同平台-17.权限鉴定&解决登录嵌套
- 【SSH项目实战】国税协同平台-15.系统、子系统首页&登录功能2
- 【SSH项目实战】国税协同平台-14.系统、子系统首页&登录功能1
- 【SSH项目实战】国税协同平台-17.权限鉴定&解决登录嵌套
- 【SSH项目实战】国税协同平台-1.项目介绍
- 【SSH项目实战】国税协同平台-1.项目介绍
- 【SSH项目实战】国税协同平台-1.项目介绍
- 【SSH项目实战】国税协同平台-5.头像上传功能
- 【SSH项目实战】国税协同平台-9.全局异常映射
- 【SSH项目实战】国税协同平台-20.异步信息发布
- 【SSH项目实战】国税协同平台-22.逆向工程
- 【SSH项目实战】国税协同平台-23.抽取BaseService
- 【SSH项目实战】国税协同平台-26.分页功能编写
- 远程计算机需要网络级别身份验证,而您的计算机不支持该验证的解决方法
- 关于打包自定义标签,并导入项目使用时,出现java.lang.NoClassDefFoundError: JspException异常,解决方法和注意事项!
- LintCode:排颜色 II
- 【洛谷T577】【模板】template 最短路 SPFA+dij
- 如何用Swift实现一个好玩的弹性动画
- 【SSH项目实战】国税协同平台-16.登录过滤器
- LintCode:接雨水
- 检查网络状态信息的API
- LintCode:搜索旋转排序数组
- C++对象模型--默认构造函数
- 这样的简历,到哪里都是被淘汰的命!
- JRE System Library [jdk1.7]和Server Library [Apache Tomcat v6.0]为绑定错误解决方案
- IoC
- Linux之命令的组合