• 阶段5 3.微服务项目【学成在线】_day16 Spring Security Oauth2_18-认证接口开发-接口开发-service


    定义AuthController


    实现刚才写的api接口


    controller定义热requestMapping 是 / 就可以了。

    因为我们的登陆跟路径就是/auth. 这样到login就是 /auth/userlogin


    定义Service


    在controller里面注入Service。我们需要在service里面定义申请令牌的方法authService。里面需要账号、密码、clientId和CLientSecret

    clientId和clientApp已经在配置文件内配置好了。可以直接注入到Controller里面就可以了。

    通过@Value注入进来

    定义一个对象来存储令牌




    在service内定义方法

    方法叫做login



    这样方法就会在Service里面创建了

    可以把之前写的测试的方法 直接复制过来 拿来用。

    注入




    复制过来的方法 只是把获取到了令牌。并没有把令牌存储到Redis。所以建议复制来的代码 单独定义一个方法叫做申请令牌的方法



    applyToken申请令牌的方法

    还有一个获取httpBasic的方法也复制过来。


    替换为传过来的变量


    bodyMap就是我们拿到的下面令牌的整个json信息


    主方法调用,如果为空。那么就抛出异常


    再定义一个异常的错误代码

    存储到redis

    注入StringRedisTemplate


    主方法调用redis存储

    redis过期时间在配置文件内配置了

    注入过期时间

    存储redis,如果没有成功就抛出存储失败的异常。

    异常类里面再定义一个


    最终参数返回

    service认证的方法完成

  • 相关阅读:
    获取N年,N月,N日后或者前的日期函数
    ABAP 上传图片
    SF 小技巧
    针式打印机问题
    ABAP 捕获回车键
    md04 取数函数
    根据选择屏幕创建12个月份
    php isset 的作用
    php 指针概念 指针引用
    php中global与$GLOBALS的用法及区别
  • 原文地址:https://www.cnblogs.com/wangjunwei/p/11638114.html
Copyright © 2020-2023  润新知