UserRouter.go 12 KB

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