首页 > 其他分享 >转-OAuth2.0 原理流程及其单点登录和权限控制

转-OAuth2.0 原理流程及其单点登录和权限控制

时间:2024-07-09 17:57:41浏览次数:8  
标签:档案局 OAuth2.0 单点 登录 张三 用户 授权 权限 public

原文链接

单点登录是多域名企业站点流行的登录方式。本文以现实生活场景辅助理解,力争彻底理清 OAuth2.0 实现单点登录的原理流程。同时总结了权限控制的实现方案,及其在微服务架构中的应用。

1 什么是单点登录

1.1 多点登录

传统的多点登录系统中,每个站点都实现了本站专用的帐号数据库和登录模块。各站点的登录状态相互不认可,各站点需要逐一手工登录。如下图,有两个术语含义如下:

  • 认证(authentication): 验证用户的身份;
  • 授权(authorization): 验证用户的访问权限。

1706260087945.png

1.2 单点登录

单点登录,英文是 Single Sign On,缩写为 SSO。

多个站点(192.168.1.20X)共用一台认证授权服务器(192.168.1.110,用户数据库和认证授权模块共用)。用户经由其中任何一个站点(比如 192.168.1.201)登录后,可以免登录访问其他所有站点。而且,各站点间可以通过该登录状态直接交互。

1706260115462.png

2 OAuth2 认证授权的原理流程

2.1 生活实例【★★重点★★】

为了直观的理解 OAuth2.0 原理流程,我们假设这样一个生活场景:

(1)档案局A(客户端 / Client):以“档案局ID/密码”标识,是掌握档案资源的机构。并列还有很多档案局B/C/…,每个档案局存储的档案内容(资源 / Resource)不一样,比如政治、经济、军事、文化等;

(2)公民张三(资源所有者 / Resource Owner):以“用户名/密码”标识,需要到各个档案局查档案;

(3)派出所(授权服务器 / Authentication Server):可以是单个巨大的派出所,也可以是数据共享的派出所集群,掌管的信息、提供的对外接口功能有:

  • 档案局信息:所有档案局的“档案局ID/密码”,证明档案局的身份;
  • 公民信息:所有公民的“用户名/密码”,能提供张三是张三的用户身份证明(认证 / Authentication)
  • 公民对于档案局的权限:有张公民和档案局的权限的映射表,可查得各公民对各档案局是否有操作权限(授权 / Authorization)。通常,设计中会增加官职(角色 / Role)一层,各公民属于哪个官职(角色),哪个官职(角色)对于特定档案局有操作权限。

2.1.1 张三首次访问档案局A

张三之前从未到访档案局,第一次来档案局。对照下图序号理解:

(1)张三来到“档案局A”的“档案处”,该处要求实名登记后才能查询,被指示到“用户登记处”办理(HTTP重定向);

(2)张三来到“档案局A”的“用户登记处”,既不能证明身份(认证),又不能证明自己有查档案A的权限(授权)。张三携带档案局A的标识(client-id),被重定向至“授权信开具处”;

(3)张三来到“派出所”的“授权信开具处”,出示档案局A的标识,希望开具授权信(授权)。该处要求首先证明身份(认证),被重定向至“用户身份验证处”;

(4)张三来到“派出所”的“用户身份验证处”,领取了用户身份表(网页登录表单 Form);

(5)张三填上自己的用户名和密码,交给(提交 / Submit)“用户身份验证处”,该处从私用数据库中查得用户名密码匹配,确定此人是张三,开具身份证明信,完成认证。张三带上身份证明信和档案局A的标识,被重定向至“授权信开具处”;

(6)张三再次来到“授权信开具处”,出示身份证明信和档案局A的标识,该处从私用数据库中查得,张三的官职是市长级别(角色),该官职具有档案局A的查询权限,就开具“允许张三查询档案局A”的授权信(授权码 / code),张三带上授权信被重定向至“档案局”的“用户登录处”;

(7)张三到了“档案局”的“用户登录处”,该处私下拿出档案局A的标识(client-id)和密码,再附上张三出示的授权信(code),向“派出所”的“腰牌发放处”为张三申请的“腰牌”(token),将来张三可以带着这个腰牌表明身份和权限。又被重定向到“档案处”;

(8)张三的会话(Session)已经关联上了腰牌(token),可以直接通过“档案处”查档案。

1706260138545.png

2.1.2 张三首次访问档案局B

张三已经成功访问了档案局A,现在他要访问档案局B。对照下图序号理解:

(1)/(2) 同上;

(3)张三已经有“身份证明信”,直接在“派出所”的“授权信开具处”成功开具“访问档案局B”的授权信;

(4)/(5)/(6) 免了;

(7)“档案局B”的“用户登记处”完成登记;

(8)“档案局B”的“档案处”查得档案。

1706260155880.png

2.1.3 张三再次访问档案局A

张三已经成功访问了档案局A,现在他要访问档案局A。对照下图序号理解:

(1)直接成功查到了档案;

(2~8)都免了。

1706260177919.png

2.2 HTTP 重定向原理

HTTP 协议中,浏览器的 REQUEST 发给服务器之后,服务器如果发现该业务不属于自己管辖,会把你支派到自身服务器或其他服务器(host)的某个接口(uri)。正如我们去政府部门办事,每到一个窗口,工作人员会说“你带上材料A,到本所的X窗口,或者其他Y所的Z窗口”进行下一个手续。

1706260200813.png

2.3 SSO 工作流程

至此,就不难理解 OAuth 2.0 的认证/授权流程,此处不再赘述。请拿下图对照“2.1 生活实例”一节来理解。

1706260216697.png

2.4 OAuth2.0 进阶

根据官方标准,OAuth 2.0 共用四种授权模式:

  • Authorization Code: 用在服务端应用之间,这种最复杂,也是本文采用的模式;
  • Implicit: 用在移动app或者web app(这些app是在用户的设备上的,如在手机上调起微信来进行认证授权)
  • Resource Owner Password Credentials(password): 应用直接都是受信任的(都是由一家公司开发的,本例子使用)
  • Client Credentials: 用在应用API访问。

1706260240129.png

3 基于 SpringBoot 实现认证/授权

官方文档:Spring Cloud Security

3.1 授权服务器(Authorization Server)

(1) pom.xml

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-oauth2</artifactId>
</dependency>

(2) application.properties

server.port=8110 ## 监听端口

(3) AuthorizationServerApplication.java

@EnableResourceServer 
// 启用资源服务器
public class AuthorizationServerApplication 
{    
	// ...
}

(4) 配置授权服务的参数

@Configuration  
@EnableAuthorizationServer  
public class Oauth2AuthorizationServerConfigurer extends AuthorizationServerConfigurerAdapter {  
    @Override  
    public void configure(final ClientDetailsServiceConfigurer clients) throws Exception {  
        clients.inMemory()  
                .withClient("webapp").secret("secret") //客户端 id/secret  
                .authorizedGrantTypes("authorization code") //授权妈模式  
                .scopes("user_info")  
                .autoApprove(true) //自动审批  
                .accessTokenValiditySeconds(3600); //有效期1hour  
    }  
}  
  
@Configuration  
public class Oauth2WebSecurityConfigurer extends WebSecurityConfigurerAdapter {  
    @Override  
    protected void configure(HttpSecurity http) throws Exception {  
        http.requestMatchers()  
                .antMatchers("/login", "/oauth/authorize/oauth/logout")  
                .and().authorizeRequests().anyRequest().authenticated()  
                .and().formLogin().permitAll();  
    }  
  
    @Override  
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {  
        auth.inMemoryAuthentication().withUser("admin").password("admin123").roles("ADMIN");  
    }  
}

3.2 客户端(Client, 业务网站)

(1) pom.xml

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-oauth2</artifactId>
</dependency>

(2) application.properties

server port=8080  
security.oauth2.client.client-id=webapp  
security.oauth2.client.client-secret=secret  
security.oauth2.client.access-token-uri=http://localhost:8110/oauth/token  
security.oauth2.client.user-authorization-uri=http://localhost:8110/oauth/authorize  
security.oauth2.resource.user-info-uri=http://localhost:8110/oauth/user

(3) 配置 WEB 安全

@Configuration  
@EnableOAuth2Sso  
public class Oauth2WebsecurityConfigurer extends WebSecurityConfigurerAdapter {  
    @Override  
    public void configure(HttpSecurity http) throws Exception {  
        http.antMatcher("/**").authorizeRequests()  
                .antMatchers("/", "/login").permitAll()  
                .anyRequest().authenticated();  
    }  
}  
  
@RestController  
public class Oauth2ClientController {  
    @GetMapping("/")  
    public ModelAndView index() {  
        return new ModelAndView("index");  
    }  
  
    @GetMapping("/welcome")  
    public ModelAndView welcome() {  
        return new ModelAndView("welcome");  
    }  
}

3.3 用户权限控制(基于角色)

  • 授权服务器中,定义各用户拥有的角色: user=USER, admin=ADMIN/USER, root=ROOT/ADMIN/USER
  • 业务网站中(client),注解标明哪些角色可
@RestController  
public class Oauth2ClientController {  
    @GetMapping("/welcome")  
    public ModelAndView welcome() {  
        return new ModelAndView("welcome");  
    }  
  
    @GetMapping("/api/user")  
    @PreAuthorize("hasAuthority('USER')")  
    public Map<String, Object> apiUser() {  
    }  
  
    @GetMapping("/api/admin")  
    @PreAuthorize("hasAuthority('ADMIN')")  
    public Map<String, Object> apiAdmin() {  
    }  
  
    @GetMapping("/api/root")  
    @PreAuthorize("hasAuthority('ROOT')")  
    public Map<String, Object> apiRoot() {  
    }  
}

4 综合运用

4.1 权限控制方案

下图是基本的认证/授权控制方案,主要设计了认证授权服务器上相关数据表的基本定义。可对照本文“2.1 生活实例”一节来理解。

1706261125133.png

4.2 在微服务架构中的应用

与常规服务架构不同,在微服务架构中,Authorization Server/Resource Server 是作为微服务存在的,用户的登录可以通过API网关一次性完成,无需与无法跳转至内网的 Authorization Server 来完成。

1706261141918.png

标签:档案局,OAuth2.0,单点,登录,张三,用户,授权,权限,public
From: https://www.cnblogs.com/booleandev/p/18292488/transferoauth20-principles-process-and-onepo

相关文章

  • OAuth2.0登录的四种方式
    OAuth登录的四种方式1.授权码授权码(authorizationcode)方式,指的是第三方应用先申请一个授权码,然后再用该码获取令牌。这种方式是最常用的流程,安全性也最高,它适用于那些有后端的Web应用。授权码通过前端传送,令牌则是储存在后端,而且所有与资源服务器的通信都在后端完成。这样......
  • 使用资源编排 ROS 轻松部署单点网站——以 WordPress 为例
    介绍WordPress是一款免费开源的网站内容管理系统(CMS),它可以帮助用户简单快捷地创建和管理自己的网站,包括博客、新闻网站、电子商务网站、社交网络等等。WordPress有丰富的主题和插件库,使得用户可以轻松地为网站定制外观和功能。WordPress的易用性和可扩展性使其成为世界上最受欢......
  • .NET6 Swagger右上角的Authorize权限按钮不显示,如何开启
    首先.NET6是自带Swagger的,无需手动引入,但是有个问题,最初的Swagger是没有开启Authorize按钮的。 最初的模样如何把它显示出来并将token信息加入header中呢?只需在program.cs页面中加入如下代码:builder.Services.AddSwaggerGen(c=>{varsecurity=newOpenApiSecuri......
  • SSO UAA 单点登录
    作为SpringCloud中的一员,SpringCloudSecurity是对微服务架构中所面临的安全性问题进行抽象并实现的工具。SpringCloudSecurity具备以下特点:基于OAuth2和OpenID协议的可配置的SSO登录机制,基于Token保障资源访问安全,另外,引入UAA(UserAccountandAuthentication,用户账户和认......
  • 3.1 Jenkins用户权限管理
    Jenkins默认使用的是自带的数据库管理用户,支持同步LDAP、Github等认证集成。关于用户与权限管理是Jenkins比较弱的一点,当大规模授权的时候建议使用API接口授权,否则当你打开web页面授权时,会很乱加载缓慢,最终导致保存失败权限丢失。用户管理配置用户接入入口:系统管理->全局安......
  • Holder模式(Holder Pattern):公司员工权限管理系统实战案例分析
    肖哥弹架构跟大家“弹弹”业务中设计模式的使用,需要代码关注欢迎点赞,点赞,点赞。关注公号Solomon肖哥弹架构获取更多精彩内容在一个大型公司中,员工根据其职位和部门被赋予不同的权限。这些权限可能包括访问敏感数据、审批财务报告、提交报销等。随着公司规模的增长......
  • IIS部署后运行报错:“C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporar
    IIS报错当前标识(IISAPPPOOL.NETv4.5)没有对“C:\Windows\Microsoft.NET\Framework64\v4.0.30319\TemporaryASP.NETFiles”的写访问权限。解决方法:1、以管理员权限运行PowerShell2、输入以下指令:C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Aspnet_regiis.exe-ga'......
  • Grafana9的dashboard权限问题
    grafana升级到9之后会有一个问题,在给用户分配组织Organizations权限的时候,这个用户是没有查看dashboard的权限的。只有当分配了edit和admin才能看到dashboard,但是这样权限就太大了。在9版本之后,把dashboard的权限细化了,不但需要在用户侧分配权限,还需要到每个dashboard去分配......
  • 数据库新开账号,并授予了相应表的查询权限。访问时,其他PC端远程被拒绝
    报错信息        DBMS:Casesensitivity:plain=mixed,delimited=exactDriver:(ver.,JDBC)Effectiveversion:MySQL(ver.0.0)[28000][1045]Accessdeniedforuser'woer_mysql_oa'@'172.16.41.94'(usingpassword:YES). 原因    上述报错可以......
  • 【认证授权】权限系统设计详解
    【认证授权】权限系统设计详解1.权限系统设计概述2.主流权限模型概述ACL模型:访问控制列表DAC模型:自主访问控制MAC模型:强制访问控制RBAC:基于角色的权限访问控制ABAC模型:基于属性的访问控制3.RBAC的深度拓展4.RBAC权限管理的在实际系统中的应用5.企业案例:转转新权限......