UserRouter.go 15 KB

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