实现标准的Spring Security OAuth服务提供商

这里写图片描述
oauth官网
这里写图片描述
application.properties

# 自定义认证服务器id
security.oauth2.client.client-id= zhupengwei
security.oauth2.client.clientSecret=zhupengwei

这里写图片描述

/**
 * 自定义用户逻辑
 * Created by ZhuPengWei on 2017/11/27.
 */
@Component
public class MyUserDetailService implements UserDetailsService, SocialUserDetailsService {

    /**
     * 日志处理类
     */
    private Logger logger = LoggerFactory.getLogger(this.getClass());

    @Autowired
    private PasswordEncoder passwordEncoder;

    /**
     * 根据用户名加载用户信息
     *
     * @param username 用户名
     * @return UserDetails
     * @throws UsernameNotFoundException
     */
    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
        logger.info("表单登录用户名:" + username);
        return buildUser(username);
    }

    @Override
    public SocialUserDetails loadUserByUserId(String userId) throws UsernameNotFoundException {
        logger.info("社交登陆用户id" + userId);
        return buildUser(userId);
    }

    private SocialUserDetails buildUser(String userId) {
        //根据用户名称查找用户信息
        //根据查找到的用户信息判断用户是否被冻结
        String password = passwordEncoder.encode("123456");
        logger.info("数据库密码是:" + password);
        return new SocialUser(
                userId,
                password,
                true,
                true,
                true,
                true,
                AuthorityUtils.commaSeparatedStringToAuthorityList("admin,ROLE_USER"));
    }
}

配置完成之后跳过去会带着授权码
这里写图片描述

授权码模式 post请求
这里写图片描述

密码模式
这里写图片描述

配置资源服务器

/**
 * Created by ZhuPengWei on 2017/12/24.
 */
@Configuration
@EnableResourceServer
public class SpringResourceServerConfig {
}

这里写图片描述

猜你喜欢

转载自blog.csdn.net/qq_36144258/article/details/79413485