auth.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package api
  2. import (
  3. "crypto/md5"
  4. "fmt"
  5. "github.com/0xJacky/Nginx-UI/model"
  6. "github.com/gin-gonic/gin"
  7. "log"
  8. "net/http"
  9. )
  10. type LoginUser struct {
  11. Name string `json:"name"`
  12. Password string `json:"password"`
  13. }
  14. func Login(c *gin.Context) {
  15. var user LoginUser
  16. err := c.BindJSON(&user)
  17. if err != nil {
  18. log.Println(err)
  19. }
  20. var u model.Auth
  21. u, err = model.GetUser(user.Name)
  22. if err != nil {
  23. log.Println(err)
  24. }
  25. data := []byte(user.Password)
  26. has := md5.Sum(data)
  27. md5str := fmt.Sprintf("%x", has) // 将[]byte转成16进制
  28. if u.Password != md5str {
  29. c.JSON(http.StatusForbidden, gin.H{
  30. "message": "Incorrect name or password",
  31. })
  32. return
  33. }
  34. var token string
  35. token, err = model.GenerateJWT(u.Name)
  36. if err != nil {
  37. c.JSON(http.StatusInternalServerError, gin.H{
  38. "message": err.Error(),
  39. })
  40. return
  41. }
  42. c.JSON(http.StatusOK, gin.H{
  43. "message": "ok",
  44. "token": token,
  45. })
  46. }
  47. func Logout(c *gin.Context) {
  48. token := c.GetHeader("Authorization")
  49. err := model.DeleteToken(token)
  50. if err != nil {
  51. c.JSON(http.StatusInternalServerError, gin.H{
  52. "message": err.Error(),
  53. })
  54. return
  55. }
  56. c.JSON(http.StatusNoContent, gin.H{})
  57. }