page_auth_handler.go 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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)
  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. func (c *PageOAuthHandler) SetFuncCheckOpenIDExisting(handler func(string) bool) {
  33. c.checkOpenIDExistingFunc = handler
  34. }
  35. //SetFuncAfterGetUserInfo 设置获得用户信息后执行
  36. func (c *PageOAuthHandler) SetFuncAfterGetUserInfo(handler func(oauth.UserInfo)) {
  37. c.afterGetUserInfoFunc = handler
  38. }
  39. //Handle handler
  40. func (c *PageOAuthHandler) Handle() (err error) {
  41. code := c.Query("code")
  42. state := c.Query("state")
  43. c.urlNeedOAuth = c.Query("target")
  44. if code != "" {
  45. var acsTkn oauth.ResAccessToken
  46. acsTkn, err = c.GetUserAccessToken(code)
  47. if err != nil {
  48. return
  49. }
  50. openID := acsTkn.OpenID
  51. if c.checkOpenIDExistingFunc(openID) { //系统中已经存在openID
  52. http.Redirect(c.Writer, c.Request, c.urlNeedOAuth, 302)
  53. return
  54. }
  55. if state == "base" {
  56. c.Redirect(c.getCallbackURL(), "snsapi_userinfo", "userinfo")
  57. return
  58. }
  59. c.UserInfo, err = c.GetUserInfo(acsTkn.AccessToken, openID)
  60. if err == nil {
  61. c.afterGetUserInfoFunc(c.UserInfo)
  62. http.Redirect(c.Writer, c.Request, c.urlNeedOAuth, 302)
  63. return
  64. }
  65. }
  66. c.Redirect(c.getCallbackURL(), "snsapi_base", "base")
  67. return
  68. }