黑马程序员技术交流社区

标题: 【郑州校区】Java之品优购课程讲义_day04(7) [打印本页]

作者: 谷粒姐姐    时间: 2018-8-13 14:06
标题: 【郑州校区】Java之品优购课程讲义_day04(7)
5.商家系统登录与安全控制
5.1 需求分析
完成商家系统登陆与安全控制,商家账号来自数据库,并实现密码加密
5.2 自定义认证类
(1)pom.xml、web.xml        、login.html        参照运营商管理后台
(2)在        pinyougou-shop-web        创  建        com.pinyougou.service        包 , 包 下 创 建 类
UserDetailsServiceImpl.java 实现 UserDetailsService 接口
[AppleScript] 纯文本查看 复制代码
package  com.pinyougou.service; import  java.util.ArrayList; import  java.util.List;
import  org.springframework.security.core.GrantedAuthority;

import  org.springframework.security.core.authority.SimpleGrantedAuthority;

import  org.springframework.security.core.userdetails.User;
import  org.springframework.security.core.userdetails.UserDetails;

import  org.springframework.security.core.userdetails.UserDetailsService;

import  org.springframework.security.core.userdetails.UsernameNotFoundException;

/**

*认证类

*@author  Administrator

*

*/

public  class  UserDetailsServiceImpl  implements  UserDetailsService  { @Override
public  UserDetails  loadUserByUsername(String  username)  throws
UsernameNotFoundException  {

List<GrantedAuthority>  grantedAuths  =  new  ArrayList<GrantedAuthority>(); grantedAuths.add(new  SimpleGrantedAuthority("ROLE_SELLER"));
return  new  User(username,"123456",  grantedAuths);

}

}
(3)在 pinyougou-shop-web 的 spring 目录下创建 spring-security.xml
[AppleScript] 纯文本查看 复制代码
<!-- 以下页面不被拦截 -->

<http  pattern="/*.html"  security="none"></http>


<http  pattern="/css/**"  security="none"></http>


<http  pattern="/img/**"  security="none"></http>


<http  pattern="/js/**"  security="none"></http>


<http  pattern="/plugins/**"  security="none"></http>
<http  pattern="/seller/add.do"  security="none"></http>

<!-- 页面拦截规则 -->

<http  use-expressions="false">


<intercept-url  pattern="/**"  access="ROLE_SELLER"  />


<form-login  login-page="/shoplogin.html"
default-target-url="/admin/index.html"  authentication-failure-url="/shoplogin.html" always-use-default-target="true"/>

<csrf  disabled="true"/>


<headers>


<frame-options  policy="SAMEORIGIN"/>


</headers>


<logout/>


</http>

<!-- 认证管理器 -->

<authentication-manager>


<authentication-provider  user-service-ref="userDetailService">


</authentication-provider>


</authentication-manager>
<beans:bean  id="userDetailService" class="com.pinyougou.service.UserDetailServiceImpl"></beans:bean>
经过上述配置,用户在输入密码 123456 时就会通过(用户名随意)







欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2