spring security remember-me
来源:互联网 发布:腾讯unity3d招聘 编辑:程序博客网 时间:2024/06/05 21:18
1.controller
package net.yym.web.controller.home;import com.google.common.base.Optional;import net.yym.core.entity.Doctor;import net.yym.web.controller.BaseController;import net.yym.web.security.LoginUserInfo;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import javax.servlet.http.HttpServletRequest;/** * 登陆跳转控制器 * * @author yym */@Controllerpublic class HomeController extends BaseController { private static Logger logger = LoggerFactory.getLogger(HomeController.class); @Autowired private LoginUserInfo loginUserInfo; @RequestMapping("/") public String index() { return "redirect:home"; } @RequestMapping("/login") public String login(@RequestParam(required = false)String error,HttpServletRequest request) { if (error != null){ request.setAttribute("error","用户名或密码错误"); } return "home/login"; } @RequestMapping("/home") public String home(HttpServletRequest request) { Optional<Doctor> optional = loginUserInfo.getDoctor(); if (optional.isPresent()){ request.getSession().setAttribute("doctorName", optional.get().getName()); } return "redirect:patient/list"; }}
2.spring-security.xml
<?xml version="1.0" encoding="UTF-8"?><beans:beans xmlns="http://www.springframework.org/schema/security" xmlns:beans="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-4.1.xsd" default-lazy-init="true"> <!-- http安全配置 --> <!-- 设置禁止spring-security拦截的路径 --> <http pattern="/login*" security="none"/> <http pattern="/" security="none"/> <http pattern="/WEB-INF/views/home/*.jsp" security="none"/> <http pattern="/WEB-INF/views/shared/*.jsp" security="none"/> <http auto-config="true" use-expressions="true"> <form-login login-page="/login" default-target-url="/home" always-use-default-target="true" login-processing-url="/j_spring_security_check" authentication-failure-url="/login?error=true"/> <csrf disabled="true"/> <logout logout-success-url="/login" logout-url="/logout"/> <remember-me key="chd" services-ref="rememberMeServices"/> <intercept-url pattern="/**" access="hasAnyRole('ROLE_USER')"/> </http> <!-- 认证配置, 使用userDetailsService提供的用户信息 --> <authentication-manager alias="authenticationManager" erase-credentials="false"> <authentication-provider ref="authenticationProvider"/> </authentication-manager> <beans:bean id="authenticationProvider" class="org.springframework.security.authentication.dao.DaoAuthenticationProvider"> <beans:property name="userDetailsService" ref="memberDetailService"/> <beans:property name="hideUserNotFoundExceptions" value="false"/> <beans:property name="passwordEncoder" ref="passwordEncoder"/> </beans:bean> <!-- 实现 remember-me 功能 --> <beans:bean id="rememberMeServices" class="org.springframework.security.web.authentication.rememberme.TokenBasedRememberMeServices"> <beans:constructor-arg value="chd" index="0"/> <beans:constructor-arg ref="memberDetailService" index="1"/> </beans:bean> <!-- 项目实现的用户查询服务 --> <beans:bean id="memberDetailService" class="net.yixinjia.web.security.AuthenticationService"/> <!-- 用户的密码加密或解密 --> <beans:bean id="passwordEncoder" class="org.springframework.security.authentication.encoding.Md5PasswordEncoder"/></beans:beans>
3.login.jsp
<form id="login_form" action="j_spring_security_check" method="post"> <div class="form-group m-bottom-md"> <input type="text" class="form-control" name="username" placeholder="请输入用户名"> </div> <div class="form-group"> <input type="password" class="form-control" name="password" placeholder="请输入密码"> </div> <div class="form-group"> <div class="custom-checkbox"> <input type="checkbox" id="remember_me" name="remember-me"> <label for="remember_me"></label> </div> 记住密码 </div> <div style="color: red"> <c:if test="${not empty error}"> 用户名或密码错误 </c:if> </div> <div class="m-top-md p-top-sm"> <a href="javascript:document:login_form.submit();" class="btn btn-success block">登录</a> </div></form>
0 0
- spring security remember-me
- 求教spring security remember me
- Spring Security Remember Me Example
- 12. Spring Security Remember-Me功能
- Spring Security笔记:Remember Me(下次自动登录)
- Spring Security(12)——Remember-Me功能
- spring security 安全框架remember me,demo学习
- Spring Security(12)——Remember-Me功能
- Spring Security(12)——Remember-Me功能
- Spring Security(12)——Remember-Me功能
- spring security起步五:Remember Me功能实现
- Spring Security(12)——Remember-Me功能
- Spring Security(12)——Remember-Me功能
- Spring Security笔记:Remember Me(下次自动登录)
- Spring Security 中实现 Remember Me 记住密码功能
- 解决Spring Security 开启remember-me(持久化),session并发控制后重启服务器remember-me持久化凭证消失问题
- Spring Seucrity 之 Remember Me
- Spring Seucrity 之 Remember Me
- CGI相关知识
- 【Python】Python_learning5:使用python计算生日日期
- js将当前时间日期格式化输出
- Unity3D游戏开发框架-资源管理类ResourceManage
- eclipse 设置豆沙绿
- spring security remember-me
- Xcode自动注释插件
- UVA 1543 Telescope
- 基于小波变换的图像压缩
- Arch 下安装飞常准上传套件
- Redis Web界面管理工具
- 非缓冲文本操作
- java中assert关键字
- ASP.NET基础与入门:WebForm,事件驱动编程,Page类