LoginFromSms.go 5.0 KB

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