LoginFromSms.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. package youngee_talent_service
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/gogf/gf/crypto/gmd5"
  6. "github.com/gogf/gf/frame/g"
  7. "github.com/gogf/gf/net/ghttp"
  8. "github.com/gogf/gf/os/gtime"
  9. "net/http"
  10. "youngmini_server/app/dao"
  11. "youngmini_server/app/model"
  12. "youngmini_server/app/model/youngee_talent_model"
  13. "youngmini_server/app/utils"
  14. )
  15. type LoginReq struct {
  16. Code string `json:"code"` //来自uni.login返回的code
  17. Phone string `json:"phone"`
  18. Vcode string `json:"vcode"`
  19. }
  20. // 通过短信登录
  21. func LoginFromSms(r *ghttp.Request) *TalentHttpResult {
  22. l := LoginReq{}
  23. err := r.ParseForm(&l)
  24. if err != nil {
  25. fmt.Printf("前端数据解析错误")
  26. }
  27. //通过手机号和验证码构造出key。
  28. VcodeKey := fmt.Sprintf("%s%s", "c_user:", l.Phone)
  29. //viewCount, err := g.Redis().DoVar("GET", projectViewKey)
  30. Vcode, err := g.Redis().DoVar("GET", VcodeKey)
  31. //验证码正确
  32. if Vcode.String() == l.Vcode {
  33. //进行微信登录
  34. appId := g.Config().GetString("miniapp.appid")
  35. secret := g.Config().GetString("miniapp.appsecret")
  36. url := fmt.Sprintf(urlformat, appId, secret, l.Code)
  37. //通过前端uni.login获得了code用于拼接url
  38. resp, err := http.Get(url)
  39. if err != nil {
  40. return &TalentHttpResult{Code: -2, Msg: err.Error()}
  41. }
  42. //http.Get(url)之后要关闭
  43. defer resp.Body.Close()
  44. // 解码微信服务端传来的信息
  45. wxResp := WxLoginResult{}
  46. decoder := json.NewDecoder(resp.Body)
  47. if err = decoder.Decode(&wxResp); err != nil {
  48. return &TalentHttpResult{Code: -3, Msg: "decode json from wx fail"}
  49. }
  50. if wxResp.ErrCode != 0 {
  51. fmt.Printf("错误码:%d, 错误信息:%s", wxResp.ErrCode, wxResp.ErrMsg)
  52. return &TalentHttpResult{Code: -4, Msg: fmt.Sprintf("errCode:%d, errmsg:%s", wxResp.ErrCode, wxResp.ErrMsg)}
  53. }
  54. // 根据电话号码,查询达人信息。达人与电话号码一一对应
  55. rec, err := g.DB().Model("youngee_talent_info").One("talent_phone_number", l.Phone)
  56. if err != nil {
  57. return &TalentHttpResult{Code: -5, Msg: "get talent info failed"}
  58. }
  59. // 如果达人被拉黑,则返回
  60. if rec != nil && rec[dao.YoungeeTalentInfo.Columns.InBlacklist].Int() > 0 {
  61. return &TalentHttpResult{Code: -6, Msg: "in black list"}
  62. }
  63. //手机号登录使用默认名称和头像
  64. //获得登录后的返回结果对象
  65. res := youngee_talent_model.LoginResultData{}
  66. var newTalentId string
  67. var defaultAvatar = "https://horastar.obs.cn-east-3.myhuaweicloud.com/talent/logoxin01.png"
  68. if rec == nil {
  69. // 如果数据库中不存在此达人,则插入新的达人信息
  70. // 首先生成达人唯一id
  71. newTalentId = utils.GetUuid.GetTalentId()
  72. talentInfo := model.YoungeeTalentInfo{
  73. Id: newTalentId,
  74. TalentWxOpenid: wxResp.OpenId,
  75. Avatar: defaultAvatar, //使用默认头像
  76. TalentWxNickname: "样叽用户" + newTalentId, //使用默认名称
  77. TalentPhoneNumber: l.Phone, //达人电话
  78. Canwithdraw: 0,
  79. Income: 0,
  80. Withdrawing: 0,
  81. Withdrawed: 0,
  82. LastLoginDate: gtime.Now(),
  83. CreateDate: gtime.Now(),
  84. }
  85. res.Avatar = defaultAvatar
  86. res.Nickname = "样叽用户" + newTalentId
  87. _, err = g.DB().Model(dao.YoungeeTalentInfo.Table).Data(talentInfo).Insert()
  88. if err != nil {
  89. return &TalentHttpResult{Code: -7, Msg: "get talentId failed"}
  90. }
  91. } else { //已存在达人,则读取达人id
  92. newTalentId = rec["id"].String()
  93. res.Avatar = rec["avatar"].String()
  94. res.Nickname = rec["talent_wx_nickname"].String()
  95. // 更新达人最近登录时间
  96. _, err = g.DB().Model(dao.YoungeeTalentInfo.Table).Data(
  97. g.Map{
  98. "last_login_date": gtime.Now(),
  99. }).Where("id", newTalentId).Update()
  100. if err != nil {
  101. return &TalentHttpResult{Code: -8, Msg: "update talent last login date failed"}
  102. }
  103. }
  104. // 用微信的openid和SessionKey的md5做为token。会一直生效
  105. token, err := gmd5.EncryptString(wxResp.OpenId + wxResp.SessionKey)
  106. fmt.Println("token is " + token)
  107. if err != nil {
  108. return &TalentHttpResult{Code: -9, Msg: "generate key failed"}
  109. }
  110. res.Token = token
  111. // 以token为键保存session 存储在服务器中
  112. //自动生成一个 session ID 并通过 Cookie 将其发送给客户端,以便在后续请求中识别该客户端的会话
  113. //自动生成一个 session ID,并通过 `Set-Cookie` 头将其发送给客户端,前端可以通过r.header['Set-Cookie']获取cookie
  114. err = r.Session.Set(token, g.Map{
  115. "talentId": newTalentId,
  116. "wxOpenId": wxResp.OpenId,
  117. "wxSessionKey": wxResp.SessionKey,
  118. })
  119. if err != nil {
  120. return &TalentHttpResult{Code: -10, Msg: "set session failed"}
  121. }
  122. return &TalentHttpResult{Code: 0, Msg: "SmsLoginSuccess", Data: res}
  123. } else { //验证码不正确
  124. return &TalentHttpResult{Code: -1, Msg: "验证码错误"}
  125. }
  126. }