单点登录身份鉴权系统 authset 源码阅读
authset 目前尚处开闭源开发中
第三方登录鉴权
微信
微信网站应用登录功能参考文档:https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html
授权流程说明:微信OAuth2.0授权登录让微信用户使用微信身份安全登录第三方应用或网站,在微信用户授权登录已接入微信OAuth2.0的第三方应用后,第三方可以获取到用户的接口调用凭证(access_token),通过access_token可以进行微信开放平台授权关系接口调用,从而可实现获取微信用户基本开放信息和帮助用户实现基础开放功能等。 微信OAuth2.0授权登录目前支持authorization_code模式,适用于拥有server端的应用授权。
该模式整体流程为:
- 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数;
- 通过code参数加上AppID和AppSecret等,通过API换取access_token;
- 通过access_token进行接口调用,获取用户基本数据资源或帮助用户实现基本操作。
1 |
|
文档:https://developers.google.com/identity/protocols/oauth2/web-server?hl=zh-cn#obtainingaccesstokens
搭建项目框架
本项目使用 Go语言:一种编译型、并发型、垃圾回收型、面向对象的编程语言,具有简洁、高效、可靠等特点。主要使用的技术栈有:
- gin框架:一种基于Go语言的轻量级、高性能、支持中间件的Web框架,具有快速、灵活、易用等特点。
- http包:Go语言标准库中的一个包,提供了创建和处理HTTP协议的客户端和服务器端的功能。
1 |
|
我会尽力根据目录树说明该程序的执行调用顺序。一般来说,程序的执行调用顺序是这样的:程序会执行main.go
文件中的main函数,这是程序的入口点。然后,main函数会调用config目录中的config.go文件中的InitConfig函数,加载配置文件并初始化配置结构体。接着,main函数会调用data目录中的base.go文件中的InitDB和InitRedis函数,初始化数据库和缓存连接池,并赋值给data目录中的data.go文件中的全局数据层实例变量Data。然后,main函数会调用services目录中的services.go文件中的NewService函数,创建一个服务层实例,并赋值给server目录中的server.go文件中的全局服务实例变量Server。接着,main函数会调用router目录中的router.go文件中的NewRouter函数,创建一个路由引擎,并注册中间件、路由组、路由规则等。然后,main函数会调用server目录中的http.go文件中的NewHTTPServer函数,创建一个HTTP服务实例,并传入路由引擎和配置信息。接着,main函数会调用HTTP服务实例的Start方法,启动HTTP服务,并监听端口和处理请求。
1 |
|
然后,当客户端发送请求到服务器时,请求会经过以下几个步骤:首先,请求会被跨域资源共享(CORS)中间件处理,检查请求是否符合跨域访问规则,如果不符合则返回错误响应,如果符合则继续下一步。然后,请求会被超时中间件处理,设置请求处理的最大时间,如果超过则返回错误响应,如果没有超过则继续下一步。接着,请求会被路由引擎匹配到对应的路由规则和处理器函数,比如用户相关路由规则和处理器函数在router目录中的user.go文件中定义。然后,处理器函数会从请求中获取参数,并调用request目录中对应参数结构体的验证方法,验证参数是否合法,如果不合法则返回错误响应,如果合法则继续下一步。接着,处理器函数会调用服务层实例的对应业务逻辑方法,比如用户相关业务逻辑方法在services目录中的user.go文件中定义。然后,业务逻辑方法会调用数据层实例的对应数据操作方法,比如用户相关数据操作方法在data目录中的user.go文件中定义。接着,数据操作方法会使用数据库或缓存连接池执行相应的SQL语句或缓存命令,并返回结果或错误。然后,业务逻辑方法会根据数据操作方法返回的结果或错误进行相应的处理,并返回结果或错误。接着,处理器函数会根据业务逻辑方法返回的结果或错误进行相应的处理,并返回响应给客户端。
- api 目录是用来定义API接口的,包含了v1版本的API文件。
- api.go文件是用来定义通用的API响应结构和错误码的。
- user.go文件是用来定义用户相关的API接口和参数验证的,比如注册、登录、登出等。
- config 目录是用来存放配置信息的,包含了config.go文件和各种配置项的文件。
- config.go文件是用来加载配置文件和初始化配置结构体的。
- http.go文件是用来定义HTTP服务的配置项的,比如端口、超时时间等。
- mysql.go文件是用来定义MySQL数据库的配置项的,比如地址、用户名、密码等。
- redis.go文件是用来定义Redis缓存的配置项的,比如地址、密码、数据库等。
- config.yaml文件是用来存放具体的配置值的,比如开发环境和生产环境的不同配置。
- data 目录是用来操作数据库和缓存的,包含了base.go文件和各种数据模型的文件。
- base.go文件是用来初始化数据库和缓存连接池的,以及提供一些通用的数据操作方法的。
- data.go文件是用来定义数据层接口和错误类型的,以及提供一个全局的数据层实例的。
- user.go文件是用来实现用户数据模型和数据层接口的,比如创建用户、查询用户、更新用户等。
- go.mod和go.sum文件是用来管理项目依赖包的,记录了项目使用了哪些第三方库和版本号。
- main.go 文件是项目的入口文件,负责初始化配置、数据层、服务层、中间件、路由等,并启动HTTP服务。
- middlewares 目录是用来定义中间件的,包含了cors.go文件和timeout.go文件。
- cors.go文件是用来定义跨域资源共享(CORS)中间件的,允许客户端跨域访问API接口。
- timeout.go文件是用来定义超时中间件的,设置每个请求处理的最大时间,超过则返回错误响应。
- request 目录是用来定义请求参数结构体的,包含了user.go文件。
- user.go文件是用来定义用户相关请求参数结构体的,比如注册参数、登录参数等,并实现参数验证方法。
- router目录是用来定义路由规则和处理器函数的,包含了router.go文件和各种路由模块文件。
- router.go文件是用来初始化路由引擎和注册中间件、路由组、路由规则等的。
- user.go文件是用来定义用户相关路由规则和处理器函数的,比如注册路由、登录路由等,并调用服务层方法处理业务逻辑。
- server目录是用来封装HTTP服务相关逻辑的,包含了http.go文件和server.go文件。
- http.go文件是用来定义HTTP服务结构体和方法的,比如创建HTTP服务、启动HTTP服务、关闭HTTP服务等,并实现优雅地关闭HTTP服务功能。
- server.go文件是用来定义服务接口和错误类型的,并提供一个全局服务实例变量。
- services目录是用来实现业务逻辑层的,包含了services.go文件和各种业务模块文件。
- services.go文件是用来实现服务接口和提供一些通用服务方法的,比如生成JWT令牌、验证JWT令牌等。
- user.go文件是用来实现用户相关业务逻辑层方法的,比如注册用户、登录用户、登出用户等,并调用数据层方法操作数据库或缓存。
- wire.go和wire_gen.go文件是使用wire库生成依赖注入代码的源码和输出码。wire库可以帮助我们自动地将各个组件连接起来,避免手动地写初始化代码。
这段代码定义了一个名为newApp的函数,该函数接受两个参数:engine和conf。engine是一个gin.Engine类型的指针,它是一个用于创建HTTP路由和中间件的框架。conf是一个config.Server类型的指针,它是一个用于存储服务器配置的结构体。
函数的返回值是一个*http.Server类型的指针,它是一个用于创建HTTP服务器的结构体。函数的主要作用是根据给定的engine和conf创建一个HTTP服务器,并返回它。
1 |
|
这段代码对整体项目的影响主要有:
- 它提供了一个统一的入口函数,方便在其他地方调用和创建HTTP服务器。
- 它实现了对gin框架和服务器配置的封装,简化了HTTP服务器的创建过程。
- 它增加了项目的可读性和可维护性,因为它使用了清晰的命名和注释。
1 |
|
API 层
1 |
|
这段代码定义了一个名为 Handle
的结构体,它包含一个指向 services.Usercase
结构体的指针。Usercase
是一个服务层结构体,用于处理业务逻辑。
NewHandle
函数是一个构造函数,它接受一个 services.Usercase
结构体指针作为参数,并返回一个 Handle
结构体指针。在函数内部,使用传入的 usercase
参数创建一个新的 Handle
结构体,并将其返回。
ProviderSet
是一个 wire.Set
,它使用 NewHandle
函数创建一个新的 Handle
结构体。这个 ProviderSet
可以在依赖注入中使用,用于提供 Handle
结构体的实例。
总的来说,这段代码定义了一个 Handle
结构体和一个 NewHandle
函数,用于创建 Handle
结构体的实例。这个结构体包含一个指向 services.Usercase
结构体的指针,用于处理业务逻辑。ProviderSet
是一个依赖注入的集合,用于提供 Handle
结构体的实例。
1 |
|
twiter
- Oauth 第三方授权登陆 facebook google twitter instagram:https://blog.csdn.net/amy260231120/article/details/114385026
- https://developer.twitter.com/zh-cn/docs/authentication/oauth-2-0/bearer-tokens
- https://developer.twitter.com/en/docs/authentication/oauth-2-0
参考资料
单点登录身份鉴权系统 authset 源码阅读