【SSH项目实战】国税协同平台-16.登录过滤器

简介:
我们上一次做完了登录功能,也将登录信息保存在了session中,接下来我们来继续完善我们的登录部分。

我们先来验证一下之前我们的用户信息是否保存在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中保存成功。

接下来完成我们的“退出”功能(也即是注销,清除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),会发现其跳转到登录界面。说明我们拦截成功。

正常登录是成功的,登陆之后再跳转至其他页面也是可以的。

至此我们完成了登录的过滤器。下一次我们完成权限的鉴定(不是想访问哪个模块就访问哪个模块的)。

转载请注明出处:http://blog.csdn.net/acmman/article/details/49658319

相关文章
|
3月前
|
JavaScript 应用服务中间件 Linux
【应用服务 App Service】解决无法从Azure门户SSH登录问题
【应用服务 App Service】解决无法从Azure门户SSH登录问题
|
3月前
|
机器学习/深度学习 存储 Linux
【机器学习 Azure Machine Learning】使用VS Code登录到Linux VM上 (Remote-SSH), 及可直接通过VS Code编辑VM中的文件
【机器学习 Azure Machine Learning】使用VS Code登录到Linux VM上 (Remote-SSH), 及可直接通过VS Code编辑VM中的文件
|
3月前
|
安全 Shell Linux
如何禁止某个用户使用ssh登录
本文介绍了五种禁止用户通过SSH登录的方法:1) 修改`/etc/ssh/sshd_config`文件中的`DenyUsers`和`DenyGroups`来阻止特定用户或用户组登录;2) 将用户的默认shell设置为`/usr/sbin/nologin`或`/bin/false`以禁用其SSH访问;3) 利用PAM(可插入认证模块)通过编辑`/etc/security/sshd.conf`来限制登录权限;4) 通过编辑`/etc/hosts.deny`文件拒绝特定用户的SSH访问;5) 锁定或禁用用户账号以阻止所有类型的登录。每种方法都提供了详细的步骤指导。
380 1
|
3月前
|
存储 安全 测试技术
【超实用却暗藏杀机】sshpass:一键免密SSH登录的神器,为何生产环境却要敬而远之?探秘背后的安全隐患与替代方案!
【8月更文挑战第16天】sshpass 是一款便捷工具,可实现自动化SSH登录,简化脚本中的远程连接流程。通过后台自动处理密码输入,便于执行远程操作,如 `sshpass -p &#39;yourpassword&#39; ssh user@remotehost`。也可结合更多SSH选项使用,例如指定私钥文件。然而,因需明文传递密码,存在较大安全隐患,不适于生产环境;推荐使用公钥认证以增强安全性。
165 4
|
3月前
|
安全 Linux Shell
Linux系统之间实现免密码登录(SSH无密码登录
【8月更文挑战第21天】要在Linux系统间实现SSH免密码登录,需先在源机器生成SSH密钥对,然后将公钥复制到目标机器的`.ssh/authorized_keys`文件中。可通过`ssh-keygen`命令生成密钥,并使用`ssh-copy-id`命令传输公钥。最后测试SSH连接,确保能无密码登录。若目标机器缺少相关目录或文件,需手动创建并设置适当权限。完成这些步骤后,即可实现安全便捷的免密码登录。
107 0
|
3月前
|
Ubuntu Linux 网络安全
在Linux中,如何禁用root用户直接SSH登录?
在Linux中,如何禁用root用户直接SSH登录?
|
3月前
|
存储 安全 Linux
说到Linux安全,SSH限制IP登录绕不开这3种方法!
说到Linux安全,SSH限制IP登录绕不开这3种方法!
125 0
|
2天前
|
监控 Ubuntu Linux
使用VSCode通过SSH远程登录阿里云Linux服务器异常崩溃
通过 VSCode 的 Remote - SSH 插件远程连接阿里云 Ubuntu 22 服务器时,会因高 CPU 使用率导致连接断开。经排查发现,VSCode 连接根目录 ".." 时会频繁调用"rg"(ripgrep)进行文件搜索,导致 CPU 负载过高。解决方法是将连接目录改为"root"(或其他具体的路径),避免不必要的文件检索,从而恢复正常连接。
|
5月前
|
安全 Linux Shell
Linux中SSH命令介绍
Linux中SSH命令介绍
127 2
|
3月前
|
安全 Linux 网络安全
在Linux中,如何配置SSH以确保远程连接的安全?
在Linux中,如何配置SSH以确保远程连接的安全?