码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SpringSecurity Oauth2实战 - 02 搭建资源服务器


    文章目录

        • 1. server-resource 服务
          • 1. Token存储配置类 TokenStoreAutoConfiguration
          • 2. 资源服务器配置类 ResourceServerAutoConfiguration
        • 2. knowledge 业务服务
          • 1. 配置文件 application.yml
          • 2. 资源接口 HelloController
          • 3. 启动项目测试

    上篇文章我们搭建了授权服务器:SprgingSecurity Oauth2实战 - 01 搭建授权服务器(密码模式),这里搭建资源服务器来访问受限资源

    1. server-resource 服务

    1. Token存储配置类 TokenStoreAutoConfiguration

    这个存储配置类在搭建授权服务器的时候就讲到过,资源服务器和授权服务器需要使用同一个token存储方式

    @Configuration
    public class TokenStoreAutoConfiguration {
    
        @Autowired
        private RedisConnectionFactory connectionFactory;
    
        @Bean
        public TokenStore tokenStore() {
            RedisTokenStore redisTokenStore = new CustomRedisTokenStore(connectionFactory);
            redisTokenStore.setAuthenticationKeyGenerator(new CustomAuthenticationKeyGenerator());
            return redisTokenStore;
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    /**
     * 自定义的RedisTokenStore处理
     */
    public class CustomRedisTokenStore extends RedisTokenStore {
    
        public CustomRedisTokenStore(RedisConnectionFactory connectionFactory) {
            super(connectionFactory);
        }
    
        @Override
        public OAuth2AccessToken readAccessToken(String tokenValue) {
            return super.readAccessToken(tokenValue);
        }
    
        @Override
        public void removeAccessToken(OAuth2AccessToken accessToken) {
            super.removeAccessToken(accessToken);
        }
    
        @Override
        public void removeAccessTokenUsingRefreshToken(OAuth2RefreshToken refreshToken) {
            super.removeAccessTokenUsingRefreshToken(refreshToken);
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    public class CustomAuthenticationKeyGenerator extends DefaultAuthenticationKeyGenerator {
    
        private static final String RAND = "keyGeneratorRand";
    
        @Override
        protected String generateKey(Map<String, String> values) {
            // 加入一个随机的要素,保证每次调用时生成的们的hash都不一样
            values.put(RAND, UUID.randomUUID().toString());
            return super.generateKey(values);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    2. 资源服务器配置类 ResourceServerAutoConfiguration
    @Slf4j
    @Configuration
    @EnableResourceServer
    @EnableGlobalMethodSecurity(prePostEnabled = true)
    public class ResourceServerAutoConfiguration extends ResourceServerConfigurerAdapter {
    
        @Autowired
        private TokenStore tokenStore;
    
        @Value("${spring.application.name}")
        private String appName;
    
        @Override
        public void configure(ResourceServerSecurityConfigurer resources) {
            resources.resourceId(appName);
            resources.tokenStore(tokenStore);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    2. knowledge 业务服务

    1. 配置文件 application.yml
    server:
      port: 8082
    spring:
      application:
        name: knowledge
      # 数据库
      datasource:
        driver-class-name: com.mysql.jdbc.Driver
        username: root
        password: root
        url: jdbc:mysql://localhost:3306/authority?characterEncoding=utf-8&useSSL=false&serverTimezone=Hongkong
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    2. 资源接口 HelloController
    @RestController
    @RequestMapping("/api/v1")
    public class HelloController {
    
        @GetMapping("/hello")
        public String hello(){
            return "hello spring security";
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    3. 启动项目测试

    ① 到授权服务器获取 token:

    在这里插入图片描述

    ② 根据 access_token 访问受限资源:

    在这里插入图片描述

    ③ 如果不携带access_token,则会报错:

    在这里插入图片描述

  • 相关阅读:
    App的回归测试,有什么高效的测试方法?
    QTransform 笔记
    http 跨域资源共享详解
    【星海出品】flask (二) request替代VUE测试flask接口
    【win12】服务器windows server2012因为DNS配置失败而导致无法上网的解决办法【手动配置DNS试试->取消自动获取】
    加密算法md5、AES、RSA、Base64的区别
    小程序中各个组件以及其作用
    通过 TiUP 部署 DM 集群的拓扑文件配置
    树莓派安装retropie 打造属于你的小霸王街机游戏机
    【AI视野·今日Robot 机器人论文速览 第三十八期】Thu, 21 Sep 2023
  • 原文地址:https://blog.csdn.net/qq_42764468/article/details/127677683
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号