UserRouter.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. package router
  2. import (
  3. "demo/configs"
  4. "demo/data/dao"
  5. "demo/data/dao/manage"
  6. "demo/data/domain"
  7. "demo/data/domain/vo"
  8. "demo/share"
  9. "demo/util"
  10. "fmt"
  11. "github.com/gin-gonic/gin"
  12. "github.com/mojocn/base64Captcha"
  13. "github.com/spf13/cast"
  14. "log"
  15. "math/big"
  16. "net/http"
  17. "regexp"
  18. "strconv"
  19. "time"
  20. )
  21. func UserRouth(engine *gin.RouterGroup) {
  22. user := engine.Group("/user")
  23. {
  24. //获取用户基本信息
  25. user.GET("/info", GetUserInfo)
  26. //获取用户钱包
  27. user.GET("/wallet", GetUserWallet)
  28. //修改名字
  29. user.PUT("/name", SetNameValue)
  30. //获取用户的订单信息
  31. user.POST("/order", GetUserOrder)
  32. //用户登录
  33. user.POST("/login", login)
  34. //注册
  35. user.POST("/register", register)
  36. //发送邮箱注册验证码
  37. user.POST("/registerCode", registerCode)
  38. //发送验证码
  39. user.POST("/sendSms", SendVerificationCode)
  40. //图片验证码
  41. user.GET("/captcha", VerificationCode)
  42. }
  43. }
  44. // GetUserInfo 获取用户的个人信息
  45. func GetUserInfo(c *gin.Context) {
  46. header := c.GetHeader("auth-sign")
  47. if header == "" {
  48. c.JSON(200, CreateResultError(401, "用户未登录"))
  49. return
  50. }
  51. claims, err := share.ParseToken(header)
  52. if err != nil {
  53. c.JSON(200, CreateResultError(401, "用户未登录"))
  54. return
  55. }
  56. var userInfo = configs.User{}
  57. _, err = configs.Engine.Table("user").Where("id = ?", claims["iss"]).Get(&userInfo)
  58. if err != nil {
  59. c.JSON(200, CreateResultError(401, "用户未登录"))
  60. return
  61. }
  62. c.JSON(200, CreateResultData(userInfo))
  63. }
  64. func GetUserWallet(c *gin.Context) {
  65. id := GetUserIdByToken(c)
  66. if id == 0 {
  67. return
  68. }
  69. var vo vo.UserWalletVo
  70. userWallet, err := dao.GetUserWalletByUserId(id)
  71. if err != nil {
  72. c.JSON(200, CreateResultError(500, "获取钱包失败"))
  73. }
  74. vo.Wallet = userWallet
  75. vo.CouponUserJDM, err = dao.GetUserCouponByUserId(id)
  76. if err != nil {
  77. c.JSON(200, CreateResultError(500, "获取优惠券失败"))
  78. }
  79. c.JSON(200, CreateResultData(vo))
  80. }
  81. func SetNameValue(c *gin.Context) {
  82. id := GetUserIdByToken(c)
  83. if id == 0 {
  84. return
  85. }
  86. name := c.Query("name")
  87. fmt.Println(name)
  88. _, b, err := manage.SetUser(map[string]interface{}{"name": name}, id)
  89. if err != nil {
  90. println(err.Error())
  91. c.JSON(200, CreateResultError(500, "修改失败"))
  92. return
  93. }
  94. if b {
  95. c.JSON(200, CreateResult())
  96. } else {
  97. c.JSON(200, CreateResultError(500, "修改失败"))
  98. }
  99. }
  100. // GetUserOrder 获取用户订单信息
  101. func GetUserOrder(c *gin.Context) {
  102. id := GetUserIdByToken(c)
  103. if id == 0 {
  104. return
  105. }
  106. data := share.GetJsonAnyParam(c)
  107. pageNum, _ := data("pageNum")
  108. pageSize, _ := data("pageSize")
  109. state, _ := data("state")
  110. vo, err := dao.GetListGoodsOrder(cast.ToString(state), id, cast.ToInt(pageNum), cast.ToInt(pageSize))
  111. if err != nil {
  112. c.JSON(200, CreateResultError(500, "获取订单失败"))
  113. }
  114. c.JSON(200, CreateResultData(vo))
  115. }
  116. ////
  117. func VerificationCode(c *gin.Context) {
  118. // 配置
  119. driver := base64Captcha.NewDriverDigit(80, 240, 4, 0.5, 80)
  120. store := base64Captcha.DefaultMemStore
  121. captcha := base64Captcha.NewCaptcha(driver, store)
  122. // 生成验证码
  123. id, b64s, answer, err := captcha.Generate()
  124. if err != nil {
  125. c.JSON(500, gin.H{"error": err.Error()})
  126. return
  127. }
  128. fmt.Println(answer)
  129. err = configs.RedisDb.Set(ctx, "VerificationCode_"+id, answer, 0).Err()
  130. if err != nil {
  131. fmt.Println(err)
  132. }
  133. err = configs.RedisDb.Expire(ctx, "VerificationCode_"+id, 60*time.Second).Err()
  134. if err != nil {
  135. panic(err)
  136. }
  137. // 返回验证码图片
  138. c.JSON(200, gin.H{
  139. "message": "获取成功!!!",
  140. "expires": time.Now().Add(time.Minute * 5).Unix(),
  141. "code": 200,
  142. "data": map[string]string{"id": id, "image": b64s},
  143. })
  144. }
  145. func login(c *gin.Context) {
  146. data := share.GetJsonAnyParam(c)
  147. var user configs.User
  148. var err error
  149. username, _ := data("username")
  150. password, _ := data("password")
  151. t, _ := data("type")
  152. // 定义正则表达式
  153. if cast.ToString(t) == "email" {
  154. regexPattern := `^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$`
  155. // 编译正则表达式
  156. reg, err := regexp.Compile(regexPattern)
  157. if err != nil {
  158. fmt.Println("编译正则表达式时出错:", err)
  159. return
  160. }
  161. //判断是否为邮箱格式
  162. matched := reg.MatchString(cast.ToString(username))
  163. if !matched {
  164. fmt.Println("无效的电子邮件格式.")
  165. c.JSON(http.StatusOK, CreateResultError(400, "邮箱格式错误!!!"))
  166. return
  167. }
  168. } else if cast.ToString(t) == "phone" {
  169. regexPattern := `^1[3-9]\d{9}$`
  170. // 编译正则表达式
  171. reg, err := regexp.Compile(regexPattern)
  172. if err != nil {
  173. fmt.Println("编译正则表达式时出错:", err)
  174. return
  175. }
  176. //判断是否为邮箱格式
  177. matched := reg.MatchString(cast.ToString(username))
  178. if !matched {
  179. fmt.Println("无效的手机号格式.")
  180. c.JSON(http.StatusOK, CreateResultError(400, "手机格式错误!!!"))
  181. return
  182. }
  183. }
  184. user, err = dao.Logins(cast.ToString(username), cast.ToString(password), cast.ToString(t))
  185. if err == nil && user.Id != 0 {
  186. fmt.Println("用户登录成功!!!")
  187. token, err := share.GenerateToken(cast.ToString(user.Id))
  188. if err == nil {
  189. c.Header("auth-sign", token)
  190. c.JSON(http.StatusOK, CreateResultData(map[string]string{"token": token}))
  191. } else {
  192. c.JSON(http.StatusOK, CreateResultError(400, "生成token失败!!!"))
  193. }
  194. } else {
  195. fmt.Println("用户登录失败!!!")
  196. c.JSON(http.StatusOK, CreateResultError(401, "用户密码错误!!!"))
  197. }
  198. }
  199. func registerCode(c *gin.Context) {
  200. data := share.GetJsonAnyParam(c)
  201. phone, _ := data("phone")
  202. //判断是否为手机格式
  203. if !checkPhone(c, cast.ToString(phone)) {
  204. return
  205. }
  206. //判断是否已经注册
  207. b, err := dao.ExistsPhone(cast.ToString(phone))
  208. if err != nil {
  209. fmt.Println(err)
  210. c.JSON(http.StatusOK, CreateResultError(200, "数据库错误!!!"))
  211. return
  212. }
  213. if b {
  214. c.JSON(http.StatusOK, CreateResultError(200, "手机号已注册!!!"))
  215. return
  216. }
  217. //判断是否重复注册
  218. get := configs.RedisDb.Exists(ctx, "PhoneVerificationCodeTime_"+cast.ToString(phone))
  219. if get.Val() == 1 {
  220. c.JSON(http.StatusOK, CreateResultError(200, "验证码已经发送,请等待"))
  221. return
  222. }
  223. //发送短信
  224. //sms := sendSms(b, cast.ToString(phone))
  225. //TODO 模拟发送短信
  226. sms := testSendSms()
  227. fmt.Println("发送成功!!!:验证码为:", sms)
  228. configs.RedisDb.Set(ctx, "PhoneVerificationCode_"+cast.ToString(phone), sms, 60*5*time.Second)
  229. configs.RedisDb.Set(ctx, "PhoneVerificationCodeTime_"+cast.ToString(phone), time.Now(), 60*time.Second)
  230. c.JSON(http.StatusOK, CreateResult())
  231. }
  232. func testSendSms() string {
  233. mins := big.NewInt(100000)
  234. maxs := big.NewInt(999999)
  235. randomNum := share.RandomInt(mins, maxs)
  236. //if matched {
  237. // //bools, err = configs.Engine.Table("user").Where("username = ?", username).Exist(&user)
  238. //
  239. // share.SendMail(username, strconv.Itoa(int(randomNum.Int64())))
  240. //
  241. //} else {
  242. // share.SendSms(strconv.Itoa(int(randomNum.Int64())), username)
  243. //}
  244. return randomNum.String()
  245. }
  246. func register(c *gin.Context) {
  247. data := share.GetJsonAnyParam(c)
  248. username, _ := data("username")
  249. password, _ := data("password")
  250. code, _ := data("code")
  251. phone, _ := data("phone")
  252. if !checkEmail(c, cast.ToString(username)) {
  253. return
  254. }
  255. if !checkPhone(c, cast.ToString(phone)) {
  256. return
  257. }
  258. if !checkCode(c, cast.ToString(code)) {
  259. return
  260. }
  261. if !checkPassword(c, cast.ToString(password)) {
  262. return
  263. }
  264. // 验证验证码
  265. get := configs.RedisDb.Get(ctx, "PhoneVerificationCode_"+cast.ToString(phone))
  266. fmt.Println(code, get.Val())
  267. if code != get.Val() {
  268. c.JSON(http.StatusOK, CreateResultError(400, "验证码错误!"))
  269. return
  270. }
  271. configs.RedisDb.Del(ctx, "PhoneVerificationCode_"+cast.ToString(phone))
  272. //判断是否已经注册
  273. b, err := dao.GetUserByPhoneOrEmail(cast.ToString(phone), cast.ToString(username))
  274. if err != nil {
  275. c.JSON(http.StatusOK, CreateResultError(400, "验证手机号及用户名,数据错误"))
  276. return
  277. }
  278. if b {
  279. c.JSON(http.StatusOK, CreateResultError(400, "手机号或邮箱已注册!!!"))
  280. return
  281. }
  282. timestamp := time.Now().Unix()
  283. user := configs.User{
  284. Username: cast.ToString(username),
  285. Password: cast.ToString(password),
  286. Creation_time: int(timestamp),
  287. Status: 0,
  288. Role_id: 2,
  289. Phone: cast.ToString(phone),
  290. Email: cast.ToString(username),
  291. Name: cast.ToString(username),
  292. RecommendCode: fmt.Sprint(strconv.FormatInt(timestamp, 16), util.RandomArrays(13, 62)),
  293. }
  294. user, err = dao.SaveNewUser(user)
  295. if err != nil {
  296. fmt.Println(err)
  297. c.JSON(http.StatusOK, CreateResultError(400, "数据库错误!!!"))
  298. return
  299. }
  300. if user.Id != 0 {
  301. fmt.Println("用户注册成功!!!")
  302. c.JSON(http.StatusOK, CreateResultData(map[string]any{"user": user}))
  303. //用户钱包添加
  304. manage.SaveUserWallet(&domain.UserWallet{UserId: user.Id})
  305. return
  306. } else {
  307. fmt.Println("用户注册失败!!!")
  308. c.JSON(http.StatusOK, CreateResultError(400, "用户注册失败!!!"))
  309. return
  310. }
  311. }
  312. func checkEmail(c *gin.Context, email string) bool {
  313. //// 定义正则表达式
  314. regexPattern := `^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$`
  315. reg, err := regexp.Compile(regexPattern)
  316. if err != nil {
  317. fmt.Println("Error compiling regex:", err)
  318. c.JSON(500, CreateResultError(500, "邮箱格式错误!!!"))
  319. return false
  320. }
  321. //判断是否为邮箱格式
  322. matched := reg.MatchString(cast.ToString(email))
  323. if !matched {
  324. fmt.Println("Error compiling regex:", err)
  325. c.JSON(500, CreateResultError(500, "邮箱格式错误!!!"))
  326. return false
  327. }
  328. return true
  329. }
  330. func checkPhone(c *gin.Context, phone string) bool {
  331. //// 定义正则表达式
  332. regexPattern := `^1[3-9]\d{9}$`
  333. reg, err := regexp.Compile(regexPattern)
  334. if err != nil {
  335. fmt.Println("1 Error compiling regex:", err)
  336. c.JSON(200, CreateResultError(500, "手机号格式错误!!!"))
  337. return false
  338. }
  339. matched := reg.MatchString(cast.ToString(phone))
  340. if !matched {
  341. fmt.Println("2 Error compiling regex:", err)
  342. c.JSON(200, CreateResultError(500, "手机号格式错误!!!"))
  343. return false
  344. }
  345. return true
  346. }
  347. func checkPassword(c *gin.Context, email string) bool {
  348. //// 定义正则表达式
  349. regexPattern := `^[a-zA-Z0-9,./<>?;'\\:"|\[\]{}~!@#$%^&*()_+=-]{6,32}$`
  350. reg, err := regexp.Compile(regexPattern)
  351. if err != nil {
  352. fmt.Println("Error compiling regex:", err)
  353. c.JSON(500, CreateResultError(500, "密码格式错误!!!"))
  354. return false
  355. }
  356. //判断是否为邮箱格式
  357. matched := reg.MatchString(cast.ToString(email))
  358. if !matched {
  359. fmt.Println("Error compiling regex:", err)
  360. c.JSON(500, CreateResultError(500, "密码格式错误!!!"))
  361. return false
  362. }
  363. return true
  364. }
  365. func checkCode(c *gin.Context, code string) bool {
  366. //// 定义正则表达式
  367. regexPattern := `^\d{6}$`
  368. reg, err := regexp.Compile(regexPattern)
  369. if err != nil {
  370. fmt.Println("Error compiling regex:", err)
  371. c.JSON(500, CreateResultError(500, "验证码格式错误!!!"))
  372. return false
  373. }
  374. //判断是否为邮箱格式
  375. matched := reg.MatchString(cast.ToString(code))
  376. if !matched {
  377. fmt.Println("Error compiling regex:", err)
  378. c.JSON(500, CreateResultError(500, "验证码格式错误!!!"))
  379. return false
  380. }
  381. return true
  382. }
  383. // SendVerificationCode 发送验证码
  384. func SendVerificationCode(c *gin.Context) {
  385. data := share.GetJsonAnyParam(c)
  386. var err error
  387. username, _ := data("username")
  388. code, _ := data("code")
  389. codeId, _ := data("codeId")
  390. val, err := configs.RedisDb.Get(ctx, cast.ToString(codeId)).Result()
  391. if err != nil {
  392. log.Fatal(err)
  393. }
  394. if val != cast.ToString(code) {
  395. c.JSON(200, gin.H{"code": 400, "message": "验证码错误!!!"})
  396. c.Abort()
  397. return
  398. }
  399. // 定义正则表达式
  400. regexPattern := `^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$`
  401. // 编译正则表达式
  402. reg, err := regexp.Compile(regexPattern)
  403. if err != nil {
  404. fmt.Println("Error compiling regex:", err)
  405. return
  406. }
  407. matched := reg.MatchString(cast.ToString(username))
  408. dao.SendSms(matched, cast.ToString(username))
  409. c.JSON(200, gin.H{"code": 200, "message": "发送成功!!!"})
  410. }