增加了海报功能(未完善),redis选库,小程序后台去掉对frame中的jwt依赖
parent
d972b2b661
commit
cfae0404fc
|
|
@ -0,0 +1,94 @@
|
||||||
|
package com.ruoyi.config;
|
||||||
|
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.http.HttpMethod;
|
||||||
|
import org.springframework.security.authentication.AuthenticationManager;
|
||||||
|
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
|
||||||
|
import org.springframework.security.config.http.SessionCreationPolicy;
|
||||||
|
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* spring security配置
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
*/
|
||||||
|
@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true)
|
||||||
|
public class SecurityConfig extends WebSecurityConfigurerAdapter {
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 解决 无法直接注入 AuthenticationManager
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
@Bean
|
||||||
|
@Override
|
||||||
|
public AuthenticationManager authenticationManagerBean() throws Exception {
|
||||||
|
return super.authenticationManagerBean();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* anyRequest | 匹配所有请求路径
|
||||||
|
* access | SpringEl表达式结果为true时可以访问
|
||||||
|
* anonymous | 匿名可以访问
|
||||||
|
* denyAll | 用户不能访问
|
||||||
|
* fullyAuthenticated | 用户完全认证可以访问(非remember-me下自动登录)
|
||||||
|
* hasAnyAuthority | 如果有参数,参数表示权限,则其中任何一个权限可以访问
|
||||||
|
* hasAnyRole | 如果有参数,参数表示角色,则其中任何一个角色可以访问
|
||||||
|
*
|
||||||
|
* @ss.hasPermi | 如果有参数,参数表示权限,则其权限可以访问
|
||||||
|
* hasIpAddress | 如果有参数,参数表示IP地址,如果用户IP和参数匹配,则可以访问
|
||||||
|
* hasRole | 如果有参数,参数表示角色,则其角色可以访问
|
||||||
|
* permitAll | 用户可以任意访问
|
||||||
|
* rememberMe | 允许通过remember-me登录的用户访问
|
||||||
|
* authenticated | 用户登录后可访问
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void configure(HttpSecurity httpSecurity) throws Exception {
|
||||||
|
httpSecurity
|
||||||
|
// CRSF禁用,因为不使用session
|
||||||
|
.csrf().disable()
|
||||||
|
|
||||||
|
// 基于token,所以不需要session
|
||||||
|
.sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS).and()
|
||||||
|
// 过滤请求
|
||||||
|
.authorizeRequests()
|
||||||
|
// 对于登录login 验证码captchaImage 允许匿名访问
|
||||||
|
.antMatchers("/login", "/captchaImage", "/baseinfoset","/infoset/**","/aliyun/oss/**").anonymous()
|
||||||
|
.antMatchers(
|
||||||
|
HttpMethod.GET,
|
||||||
|
"/*.html",
|
||||||
|
"/**/*.html",
|
||||||
|
"/**/*.css",
|
||||||
|
"/**/*.js"
|
||||||
|
).permitAll()
|
||||||
|
.antMatchers("/**/**").anonymous()
|
||||||
|
.antMatchers("/common/download**").anonymous()
|
||||||
|
.antMatchers("/common/download/resource**").anonymous()
|
||||||
|
.antMatchers("/swagger-ui.html").anonymous()
|
||||||
|
.antMatchers("/swagger-resources/**").anonymous()
|
||||||
|
.antMatchers("/webjars/**").anonymous()
|
||||||
|
.antMatchers("/*/api-docs").anonymous()
|
||||||
|
.antMatchers("/druid/**").anonymous()
|
||||||
|
// 除上面外的所有请求全部需要鉴权认证
|
||||||
|
.anyRequest().authenticated()
|
||||||
|
.and()
|
||||||
|
.headers().frameOptions().disable();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 强散列哈希加密实现
|
||||||
|
*/
|
||||||
|
@Bean
|
||||||
|
public BCryptPasswordEncoder bCryptPasswordEncoder() {
|
||||||
|
return new BCryptPasswordEncoder();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue