go goth封装第三方认证库示例详解
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《go goth封装第三方认证库示例详解》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
简介
当前很多网站直接采用第三方认证登录,例如支付宝/微信/ Github 等。goth封装了接入第三方认证的方法,并且内置实现了很多第三方认证的实现:
图中截取的只是goth
支持的一部分,完整列表可在其GitHub 首页查看。
快速使用
本文代码使用 Go Modules。
创建目录并初始化:
$ mkdir goth && cd goth $ go mod init github.com/darjun/go-daily-lib/goth
安装goth
库:
$ go get -u github.com/markbates/goth
我们设计了两个页面,一个登录页面:
// login.tpl <a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq6ycZiUkYunsZXKqJh5n5a9nmrbm9Cda5m9gpzFnGGixpGKn5SQgqKu3LOifWSJ0bJ4mNuGqrluhq2Bqa-GlJ2-s4Flf32kbL-3s2uNrITfvoiHzobQsW4' rel='nofollow'>Login With GitHub</a>
点击登录链接会请求/auth/github?provider=github
。
一个主界面:
// home.tpl <p><a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq6ycaOSa52uybu3ro5ko5XFfIfNgdyxo4Hffpu8hoFosn2KnH-Ni6OyzatrjZ-E3rOImJmHqrmzhph9qq9khWW-s5Kaf4p2dQ' rel='nofollow'>logout</a></p> <p>Name: {{.Name}} [{{.LastName}}, {{.FirstName}}]</p> <p>Email: {{.Email}}</p> <p>NickName: {{.NickName}}</p> <p>Location: {{.Location}}</p> <p>AvatarURL: {{.AvatarURL}} <img src="%7B%7B.AvatarURL%7D%7D" alt="go goth封装第三方认证库示例详解" ></p> <p>Description: {{.Description}}</p> <p>UserID: {{.UserID}}</p> <p>AccessToken: {{.AccessToken}}</p> <p>ExpiresAt: {{.ExpiresAt}}</p> <p>RefreshToken: {{.RefreshToken}}</p>
显示用户的基本信息。
同样地,我们使用html/template
标准模板库来加载和管理页面模板:
var ( ptTemplate *template.Template ) func init() { ptTemplate = template.Must(template.New("").ParseGlob("tpls/*.tpl")) }
主页面处理如下:
func HomeHandler(w http.ResponseWriter, r *http.Request) { user, err := gothic.CompleteUserAuth(w, r) if err != nil { http.Redirect(w, r, "/login/github", http.StatusTemporaryRedirect) return } ptTemplate.ExecuteTemplate(w, "home.tpl", user) }
如果用户登录了,gothic.CompleteUserAuth(w, r)
会返回一个非空的User
对象,该类型有如下字段:
type User struct { RawData map[string]interface{} Provider string Email string Name string FirstName string LastName string NickName string Description string UserID string AvatarURL string Location string AccessToken string AccessTokenSecret string RefreshToken string ExpiresAt time.Time IDToken string }
如果已登录,显示主界面信息。如果未登录,重定向到登录界面:
func LoginHandler(w http.ResponseWriter, r *http.Request) { ptTemplate.ExecuteTemplate(w, "login.tpl", nil) }
点击登录,由AuthHandler
处理请求:
func AuthHandler(w http.ResponseWriter, r *http.Request) { gothic.BeginAuthHandler(w, r) }
调用gothic.BeginAuthHandler(w, r)
开始跳转到 GitHub 的验证界面。GitHub 验证完成后,浏览器会重定向到/auth/github/callback
处理:
func CallbackHandler(w http.ResponseWriter, r *http.Request) { user, err := gothic.CompleteUserAuth(w, r) if err != nil { fmt.Fprintln(w, err) return } ptTemplate.ExecuteTemplate(w, "home.tpl", user) }
如果登录成功,在 CallbackHandler
中,我们可以调用gothic.CompleteUserAuth(w, r)
取出User
对象,然后显示主页面。最后是消息路由设置:
r := mux.NewRouter() r.HandleFunc("/", HomeHandler) r.HandleFunc("/login/github", LoginHandler) r.HandleFunc("/logout/github", LogoutHandler) r.HandleFunc("/auth/github", AuthHandler) r.HandleFunc("/auth/github/callback", CallbackHandler) log.Println("listening on localhost:8080") log.Fatal(http.ListenAndServe(":8080", r))
goth
为我们封装了 GitHub 的验证过程,但是我们需要在 GitHub 上新增一个 OAuth App,生成 Client ID 和 Client Secret。
首先,登录 GitHub 账号,在右侧头像下拉框选择 Settings:
选择左侧 Developer Settings:
左侧选择 OAuth App,右侧点击 New OAuth App:
输入信息,重点是Authorization callback URL
,这是 GitHub 验证成功之后的回调:
生成 App 之后,Client ID 会自动生成,但是 Client Secret 需要再点击右侧的按钮Generate a new client token
生成:
生成了 Client Secret:
想要在程序中使用 Github,首先要创建一个 GitHub 的 Provider,调用github
子包的New()
方法:
githubProvider := github.New(clientKey, clientSecret, "http://localhost:8080/auth/github/callback")
第一个参数为 Client ID,第二个参数为 Client Secret,这两个是由上面的 OAuth App 生成的,第三个参数为回调的链接,这个必须与 OAuth App 创建时设置的一样。
然后应用这个 Provider:
goth.UseProviders(githubProvider)
准备工作完成,长吁一口气。现在运行程序:
$ SECRET_KEY="secret" go run main.go
浏览器访问localhost:8080
,由于没有登录,重定向到localhost:8080/login/github
:
点击Login with GitHub
,会重定向到 GitHub 授权页面:
点击授权,成功之后用户信息会保存在 session
中。跳转到主页面,显示我的信息:
更换 store
goth
底层使用上一篇文章中介绍的gorilla/sessions库来存储登录信息,而默认采用的是 cookie 作为存储。另外选项默认采用:
如果需要更改存储方式或选项,我们可以在程序启动前,设置gothic.Store
字段。例如我们要更换为 redistore:
store, _ = redistore.NewRediStore(10, "tcp", ":6379", "", []byte("redis-key")) key := "" maxAge := 86400 * 30 // 30 days isProd := false store := sessions.NewCookieStore([]byte(key)) store.MaxAge(maxAge) store.Options.Path = "/" store.Options.HttpOnly = true store.Options.Secure = isProd gothic.Store = store
总结
大家如果发现好玩、好用的 Go 语言库,欢迎到 Go 每日一库 GitHub 上提交 issue?
参考
goth GitHub:https://github.com/markbates/goth
Go 每日一库 GitHub:https://github.com/darjun/go-daily-lib
到这里,我们也就讲完了《go goth封装第三方认证库示例详解》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于golang的知识点!

- 上一篇
- Gogorillasecurecookie库的安装使用详解

- 下一篇
- GoJava算法之Excel表列名称示例详解
-
- Golang · Go教程 | 7分钟前 | 连接池 索引优化 批量处理 Golang数据库优化 预编译SQL
- Golang数据库优化与批量处理方法
- 280浏览 收藏
-
- Golang · Go教程 | 17分钟前 |
- Golang项目模块化结构推荐方案
- 475浏览 收藏
-
- Golang · Go教程 | 39分钟前 |
- Go语言会话管理实战指南
- 404浏览 收藏
-
- Golang · Go教程 | 39分钟前 |
- Go语言Web服务器性能优化实战
- 436浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go语言数组与切片全解析
- 301浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang并发错误处理与恢复技巧
- 492浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Windows11安装Golang教程详解
- 327浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- SublimeText3配置Golang开发插件推荐
- 497浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Go语言UbuntuPPA安装后配置GOPATH方法
- 124浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang模块初始化与项目配置详解
- 279浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang模块版本锁定与go.sum校验详解
- 444浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 519次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 509次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 537次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 588次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 506次使用
-
- go语言csrf库使用实现原理示例解析
- 2022-12-22 173浏览
-
- Golang 基于flag库实现一个简单命令行工具
- 2022-12-23 240浏览
-
- Gogorilla/sessions库安装使用
- 2022-12-30 470浏览
-
- Gogorillasecurecookie库的安装使用详解
- 2022-12-30 150浏览
-
- Go位集合相关操作bitset库安装使用
- 2022-12-27 343浏览