page_auth_handler.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package bridge
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "github.com/yaotian/gowechat/mp/oauth"
  7. "github.com/yaotian/gowechat/wxcontext"
  8. )
  9. //PageOAuthHandler 微信网页授权
  10. type PageOAuthHandler struct {
  11. // *wxcontext.Context
  12. *oauth.Oauth
  13. oAuthCallbackURL string
  14. urlNeedOAuth string
  15. openID string
  16. openIDExisting bool
  17. checkOpenIDExistingFunc func(openID string) bool
  18. oauth.UserInfo
  19. afterGetUserInfoFunc func(user oauth.UserInfo) bool
  20. }
  21. //NewPageOAuthHandler PageOAuthHandler初始化
  22. func NewPageOAuthHandler(context *wxcontext.Context, oAuthCallbackURL string) *PageOAuthHandler {
  23. pa := new(PageOAuthHandler)
  24. pa.Oauth = oauth.NewOauth(context)
  25. pa.oAuthCallbackURL = oAuthCallbackURL
  26. return pa
  27. }
  28. func (c *PageOAuthHandler) getCallbackURL() (u string) {
  29. return fmt.Sprintf("%s?target=%s", c.oAuthCallbackURL, url.QueryEscape(c.urlNeedOAuth))
  30. }
  31. /*SetFuncCheckOpenIDExisting 设置检查OpenID在您的系统中是否已经存在
  32. handler:
  33. func(openID string) (existing bool){
  34. //用获得的openID,检查是否在你的系统中已经存在此用户
  35. //如果存在,调用你的Login方法,设置cookie, session等,然后return true
  36. //如果你的系统中不存在此openID用户, return false, handler会自动去获取用户信息
  37. }
  38. */
  39. func (c *PageOAuthHandler) SetFuncCheckOpenIDExisting(handler func(string) bool) {
  40. c.checkOpenIDExistingFunc = handler
  41. }
  42. /*SetFuncAfterGetUserInfo 设置获得用户信息后执行
  43. handler:
  44. func(user oauth.UserInfo) (needStop bool) {
  45. //handler已经获得了用户信息,你可以用此信息,自动为用户完成一些动作,比如注册,头像等
  46. //默认needStop为false, 表示handler会自动redirect到你最开始需要授权的网页,此时你的系统已经完成了自动登陆等动作
  47. //如果你需要redirect到你需要的url,直接调用http.redirect; return true。 表示需要停止后面的动作
  48. }
  49. */
  50. func (c *PageOAuthHandler) SetFuncAfterGetUserInfo(handler func(oauth.UserInfo) bool) {
  51. c.afterGetUserInfoFunc = handler
  52. }
  53. //Handle handler
  54. func (c *PageOAuthHandler) Handle() (err error) {
  55. code := c.Query("code")
  56. state := c.Query("state")
  57. c.urlNeedOAuth = c.Query("target")
  58. if code != "" {
  59. var acsTkn oauth.ResAccessToken
  60. acsTkn, err = c.GetUserAccessToken(code)
  61. if err != nil {
  62. return
  63. }
  64. openID := acsTkn.OpenID
  65. if c.checkOpenIDExistingFunc(openID) { //系统中已经存在openID
  66. http.Redirect(c.Writer, c.Request, c.urlNeedOAuth, 302)
  67. return
  68. }
  69. if state == "base" {
  70. c.Redirect(c.getCallbackURL(), "snsapi_userinfo", "userinfo")
  71. return
  72. }
  73. c.UserInfo, err = c.GetUserInfo(acsTkn.AccessToken, openID)
  74. if err == nil {
  75. if !c.afterGetUserInfoFunc(c.UserInfo) {
  76. http.Redirect(c.Writer, c.Request, c.urlNeedOAuth, 302)
  77. }
  78. return
  79. }
  80. }
  81. c.Redirect(c.getCallbackURL(), "snsapi_base", "base")
  82. return
  83. }