gpt4 book ai didi

spring-security - 社交登录,spring-security-oauth2 和 spring-security-jwt?

转载 作者:行者123 更新时间:2023-12-04 12:46:23 26 4
gpt4 key购买 nike

我正在开发一个休息服务,它将通过浏览器提供
浏览器单页应用程序和移动应用程序。目前我的服务正在运行
根本没有 Spring 。 oauth2 客户端是在过滤器内部实现的,所以可以说是“手动”。

我正在尝试将其迁移到 Spring Boot。
阅读了很多手册,搜索了很多信息,我试图了解是否
对于客户来说,以下实际上是可能的:

  • 在所有帮助下使用 facebook oauth2 服务授权(并获得 access_token)
    来自 spring-security-oauth2。
  • 创建一个 JWT 并将其传递给客户端,以便所有进一步的请求
    由 JWT 支持。

  • 因为在我看来 spring boot 是关于配置和声明的
    我想了解 spring-security-oauth2 和
    Spring 安全-jwt?

    我不是在寻求解决方案,而只是从知识承载者那里得到是/否,因为我深入了解
    Spring 手册和答案变得更进一步......

    最佳答案

    简短的回答:是的,你可以做到!

    您必须在 build.gradle 或 pom.xml 文件中添加安全依赖项:

    compile "org.springframework.boot:spring-boot-starter-security"
    compile "org.springframework.security:spring-security-config"
    compile "org.springframework.security:spring-security-data"
    compile "org.springframework.security:spring-security-web"

    compile "org.springframework.social:spring-social-security"
    compile "org.springframework.social:spring-social-google"
    compile "org.springframework.social:spring-social-facebook"
    compile "org.springframework.social:spring-social-twitter"

    那么你必须将社交配置与安全配置一起添加到你的项目中:
    @Configuration
    @EnableSocial
    public class SocialConfiguration implements SocialConfigurer {

    private final Logger log = LoggerFactory.getLogger(SocialConfiguration.class);

    private final SocialUserConnectionRepository socialUserConnectionRepository;

    private final Environment environment;

    public SocialConfiguration(SocialUserConnectionRepository socialUserConnectionRepository,
    Environment environment) {

    this.socialUserConnectionRepository = socialUserConnectionRepository;
    this.environment = environment;
    }

    @Bean
    public ConnectController connectController(ConnectionFactoryLocator connectionFactoryLocator,
    ConnectionRepository connectionRepository) {

    ConnectController controller = new ConnectController(connectionFactoryLocator, connectionRepository);
    controller.setApplicationUrl(environment.getProperty("spring.application.url"));
    return controller;
    }

    @Override
    public void addConnectionFactories(ConnectionFactoryConfigurer connectionFactoryConfigurer, Environment environment) {
    // Google configuration
    String googleClientId = environment.getProperty("spring.social.google.client-id");
    String googleClientSecret = environment.getProperty("spring.social.google.client-secret");
    if (googleClientId != null && googleClientSecret != null) {
    log.debug("Configuring GoogleConnectionFactory");
    connectionFactoryConfigurer.addConnectionFactory(
    new GoogleConnectionFactory(
    googleClientId,
    googleClientSecret
    )
    );
    } else {
    log.error("Cannot configure GoogleConnectionFactory id or secret null");
    }

    // Facebook configuration
    String facebookClientId = environment.getProperty("spring.social.facebook.client-id");
    String facebookClientSecret = environment.getProperty("spring.social.facebook.client-secret");
    if (facebookClientId != null && facebookClientSecret != null) {
    log.debug("Configuring FacebookConnectionFactory");
    connectionFactoryConfigurer.addConnectionFactory(
    new FacebookConnectionFactory(
    facebookClientId,
    facebookClientSecret
    )
    );
    } else {
    log.error("Cannot configure FacebookConnectionFactory id or secret null");
    }

    // Twitter configuration
    String twitterClientId = environment.getProperty("spring.social.twitter.client-id");
    String twitterClientSecret = environment.getProperty("spring.social.twitter.client-secret");
    if (twitterClientId != null && twitterClientSecret != null) {
    log.debug("Configuring TwitterConnectionFactory");
    connectionFactoryConfigurer.addConnectionFactory(
    new TwitterConnectionFactory(
    twitterClientId,
    twitterClientSecret
    )
    );
    } else {
    log.error("Cannot configure TwitterConnectionFactory id or secret null");
    }

    // jhipster-needle-add-social-connection-factory
    }

    @Override
    public UserIdSource getUserIdSource() {
    return new AuthenticationNameUserIdSource();
    }

    @Override
    public UsersConnectionRepository getUsersConnectionRepository(ConnectionFactoryLocator connectionFactoryLocator) {
    return new CustomSocialUsersConnectionRepository(socialUserConnectionRepository, connectionFactoryLocator);
    }

    @Bean
    public SignInAdapter signInAdapter(UserDetailsService userDetailsService, JHipsterProperties jHipsterProperties,
    TokenProvider tokenProvider) {
    return new CustomSignInAdapter(userDetailsService, jHipsterProperties,
    tokenProvider);
    }

    @Bean
    public ProviderSignInController providerSignInController(ConnectionFactoryLocator connectionFactoryLocator, UsersConnectionRepository usersConnectionRepository, SignInAdapter signInAdapter) {
    ProviderSignInController providerSignInController = new ProviderSignInController(connectionFactoryLocator, usersConnectionRepository, signInAdapter);
    providerSignInController.setSignUpUrl("/social/signup");
    providerSignInController.setApplicationUrl(environment.getProperty("spring.application.url"));
    return providerSignInController;
    }

    @Bean
    public ProviderSignInUtils getProviderSignInUtils(ConnectionFactoryLocator connectionFactoryLocator, UsersConnectionRepository usersConnectionRepository) {
    return new ProviderSignInUtils(connectionFactoryLocator, usersConnectionRepository);
    }
    }

    那么你必须为你的社交登录编写适配器:
    public class CustomSignInAdapter implements SignInAdapter {

    @SuppressWarnings("unused")
    private final Logger log = LoggerFactory.getLogger(CustomSignInAdapter.class);

    private final UserDetailsService userDetailsService;

    private final JHipsterProperties jHipsterProperties;

    private final TokenProvider tokenProvider;


    public CustomSignInAdapter(UserDetailsService userDetailsService, JHipsterProperties jHipsterProperties,
    TokenProvider tokenProvider) {
    this.userDetailsService = userDetailsService;
    this.jHipsterProperties = jHipsterProperties;
    this.tokenProvider = tokenProvider;
    }

    @Override
    public String signIn(String userId, Connection<?> connection, NativeWebRequest request){
    try {
    UserDetails user = userDetailsService.loadUserByUsername(userId);
    UsernamePasswordAuthenticationToken authenticationToken = new UsernamePasswordAuthenticationToken(
    user,
    null,
    user.getAuthorities());

    SecurityContextHolder.getContext().setAuthentication(authenticationToken);
    String jwt = tokenProvider.createToken(authenticationToken, false);
    ServletWebRequest servletWebRequest = (ServletWebRequest) request;
    servletWebRequest.getResponse().addCookie(getSocialAuthenticationCookie(jwt));
    } catch (AuthenticationException ae) {
    log.error("Social authentication error");
    log.trace("Authentication exception trace: {}", ae);
    }
    return jHipsterProperties.getSocial().getRedirectAfterSignIn();
    }

    private Cookie getSocialAuthenticationCookie(String token) {
    Cookie socialAuthCookie = new Cookie("social-authentication", token);
    socialAuthCookie.setPath("/");
    socialAuthCookie.setMaxAge(10);
    return socialAuthCookie;
    }
    }

    你可以在我的 github 中找到示例项目:
    https://github.com/ksadjad/oauth-test

    关于spring-security - 社交登录,spring-security-oauth2 和 spring-security-jwt?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37422211/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com