实现权限控制步骤如下:
**1. 配置访问权限**
```java
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
@Override
protected void configure(HttpSecurity http) throws Exception {
http.formLogin()
.loginPage("/to/login")
.loginProcessingUrl("/login")
.successForwardUrl("/success")
.failureForwardUrl("/fail");
http.authorizeRequests()
.antMatchers("/layui/**", "/to/login")
.permitAll()
//当用户有admin权限时才能访问/account/list01
.antMatchers("/account/list01").hasAuthority("admin")
//当用户有admin02,或admin03权限时才能访问/account/list02
.antMatchers("/account/list02").hasAnyAuthority("admin02", "admin03")
//当用户属于role角色时才能访问/account/list03,否则出现403页面
.antMatchers("/account/list03").hasRole("role")
//当用户属于role02,或role03角色时才能访问
.antMatchers("/account/list04").hasAnyRole("role02", "role03")
.anyRequest()
.authenticated();
http.csrf().disable();
}
}
```
**2. 在用户登录时加载当前用户所有的权限与角色**
```java
@Service
@RequiredArgsConstructor
public class LoginServiceImpl implements UserDetailsService {
final AccountService accountService;
final MenuMapper menuMapper;
final RoleMapper roleMapper;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
Account account = accountService.findByUsername(username);
if (account == null) {
throw new UsernameNotFoundException("用户名不存在!");
}
//从数据库中查询当前用户的权限与角色
List<Menu> menuList = menuMapper.findByAccountId(account.getId());
List<Role> roleList = roleMapper.findByAccountId(account.getId());
//存储权限与角色的集合
List<GrantedAuthority> authorities = new ArrayList<>(1);
//处理权限
for (Menu menu : menuList) {
authorities.add(new SimpleGrantedAuthority(menu.getPermission()));
}
//处理角色
for (Role role : roleList) {
//角色必须以 ROLE_ 字符串为前缀
authorities.add(new SimpleGrantedAuthority("ROLE_" + role.getName()));
}
return new User(username, account.getPassword(), authorities);
}
}
```
**3. 测试**
登录之后,有权限访问的则正常访问,没有权限访问的返回403页面。
```
Whitelabel Error Page
This application has no explicit mapping for /error, so you are seeing this as a fallback.
Fri Jun 10 20:21:37 CST 2022
There was an unexpected error (type=Forbidden, status=403).
Forbidden
```
- 跨域问题
- 跨域是什么
- 跨域解决方案
- 从后端解决
- nginx反向代理
- WebSocket
- websocket是什么
- websocket协议
- 使用场景
- 实现方式
- 注解与html5原生方式
- websocketAPI
- 实现步骤
- 文件上传
- 文件下载
- 广播通信
- 定时推送
- 编程与socketjs方式
- socketjs与stompjs框架
- 实现步骤
- 重载目的地
- SimpMessagingTemplate
- 定时向前端推送数据
- 5种监听事件
- 点对点通信
- 拦截器
- HandshakeInterceptor
- ChannelInterceptor
- poi之excel表格
- 表格版本
- POI常用类
- POI依赖
- 写表格
- 编写表格过程
- 单元格边框样式
- 单元格背景色
- 冻结行或列
- 单元格合并
- 单元格内换行
- 文档内跳转
- 读表格
- Web中的Excel操作
- 导出表格
- 读取表格
- poi之word文档
- word版本
- 写word
- 基本使用
- 标题样式
- 添加图片
- EasyExcel表格
- EasyExcel是什么
- 与其他Excel工具对比
- EasyExcel依赖
- 读Excel
- 简单读取
- 指定列位置
- 读取多个sheet
- 格式转换
- 多行表头
- 同步读
- 写Excel
- 简单写入
- 单元格样式
- 拦截器
- 列宽
- 冻结行或列
- 合并单元格
- 填充Excel
- SpringSecurity
- SpringSecurity是什么
- 同类型产品对比
- 环境搭建
- 相关概念
- 密码加密
- Web权限控制
- UserDetailsService接口
- 登录认证
- 自定义登录页
- 未授权跳转登录页
- 权限控制
- 自定义403页面
- 权限注解
- 记住我功能
- 注销功能
- CSRF
- CSRF是什么
- CSRF保护演示
- 前后端分离权限控制
- 环境搭建
- 认证实现
- 会话管理
- 动态权限管理
- 微服务权限控制
- 权限控制方案
- SpringBoot整合RabbitMQ
- 整合步骤
- Fanout交换机演示
- Direct交换机演示
- Topic交换机演示
- @RabbitListener方法
- JWT认证与授权
- 环境搭建
- 密码加密
- 认证与授权