From 710df5998f9c7db6b8ee8d88894507f20034a79e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8F=A9?= <1939311091@qq.com> Date: Wed, 16 Aug 2023 16:48:45 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E4=B8=AD=E9=97=B4=E4=BB=B6?= =?UTF-8?q?=EF=BC=8C=E5=88=A0=E9=99=A4=E5=86=97=E4=BD=99=E9=89=B4=E6=9D=83?= =?UTF-8?q?=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- controllers/comment.go | 11 ----------- controllers/favorite.go | 21 ++------------------- controllers/follow.go | 38 +------------------------------------- controllers/message.go | 19 +------------------ controllers/user.go | 10 +--------- controllers/video.go | 13 ------------- main.go | 3 ++- routers/router.go | 12 ++++++------ utils/token.go | 26 ++++++-------------------- 9 files changed, 19 insertions(+), 134 deletions(-) diff --git a/controllers/comment.go b/controllers/comment.go index ed1a293..9dd68b4 100644 --- a/controllers/comment.go +++ b/controllers/comment.go @@ -20,17 +20,6 @@ func (c *CommentController) CommentAction() { commentContext := c.GetString("comment_text") // 评论内容 commentId, _ := strconv.Atoi(c.GetString("comment_id")) // 评论id - // 鉴权 - if err := utils.ValidateToken(tokenString); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - "comment": nil, - } - c.ServeJSON() - return - } - // 解析token user, err := utils.GetUserFromToken(tokenString) if err != nil { diff --git a/controllers/favorite.go b/controllers/favorite.go index 23cbd1b..0f54e3d 100644 --- a/controllers/favorite.go +++ b/controllers/favorite.go @@ -17,15 +17,7 @@ func (c *FavoriteController) FavoriteAction() { tokenString := c.GetString("token") // 用户鉴权 videoId, _ := strconv.Atoi(c.GetString("video_id")) // 视频id actionType, _ := strconv.Atoi(c.GetString("action_type")) // 1-点赞,2-取消点赞 - // 鉴权 - if err := utils.ValidateToken(tokenString); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - } - c.ServeJSON() - return - } + // 不能给自己点赞 username, err := utils.GetUsernameFromToken(tokenString) if err != nil { @@ -104,16 +96,7 @@ func (c *FavoriteController) FavoriteList() { // 获取必要参数 userId, _ := strconv.Atoi(c.GetString("user_id")) // 用户id tokenString := c.GetString("token") // 用户鉴权token - // 鉴权 - if err := utils.ValidateToken(tokenString); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - "video_list": nil, - } - c.ServeJSON() - return - } + // 解析token user, err := utils.GetUserFromToken(tokenString) if err != nil { diff --git a/controllers/follow.go b/controllers/follow.go index 5f2abba..658e498 100644 --- a/controllers/follow.go +++ b/controllers/follow.go @@ -22,16 +22,6 @@ func (c *FollowController) ActionRelation() { toUserId, _ := c.GetInt("to_user_id") actionType, _ := c.GetInt("action_type") - // 鉴权 - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - } - c.ServeJSON() - return - } - fromUserId, _ := utils.GetUserIdFromToken(token) if fromUserId == toUserId { @@ -94,15 +84,7 @@ func (c *FollowController) ActionRelation() { // 获取关注列表 func (c *FollowController) ListFollowRelation() { token := c.GetString("token") - // 鉴权 - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - } - c.ServeJSON() - return - } + userId, _ := c.GetInt("user_id") followList, err := GetAllFollowByUserId(c, userId, token) if err != nil { @@ -134,15 +116,6 @@ func (c *FollowController) ListFollowerRelation() { return } token := c.GetString("token") - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token验证失败", - "video_list": nil, - } - c.ServeJSON() - return - } // 查询当前用户的粉丝关系 var follows []models.Follow @@ -184,15 +157,6 @@ func (c *FollowController) ListFriendRelation() { } token := c.GetString("token") - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token验证失败", - "video_list": nil, - } - c.ServeJSON() - return - } // 定义一个切片来存储多个粉丝关系查询结果 var follows []models.Follow diff --git a/controllers/message.go b/controllers/message.go index 2dc32de..cfb82d3 100644 --- a/controllers/message.go +++ b/controllers/message.go @@ -18,15 +18,7 @@ type MessageController struct { func (c *MessageController) ChatMessage() { token := c.GetString("token") toUserId, _ := c.GetInt("to_user_id") - // 鉴权 - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token鉴权失败", - } - c.ServeJSON() - return - } + fromUserId, _ := utils.GetUserIdFromToken(token) if fromUserId == toUserId { @@ -91,15 +83,6 @@ func (c *MessageController) ActionMessage() { return } - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token验证失败", - "video_list": nil, - } - c.ServeJSON() - return - } actionType := c.GetString("action_type") if actionType == "1" { toUserId, err := strconv.Atoi(c.GetString("to_user_id")) diff --git a/controllers/user.go b/controllers/user.go index f067f10..3b55e77 100644 --- a/controllers/user.go +++ b/controllers/user.go @@ -96,15 +96,7 @@ func (c *UserController) Login() { func (c *UserController) Info() { uid, _ := c.GetInt("user_id") token := c.GetString("token") - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token验证失败", - "user": nil, - } - c.ServeJSON() - return - } + userInfo := c.GetUserInfo(uid, token) c.Data["json"] = map[string]interface{}{ "status_code": 0, diff --git a/controllers/video.go b/controllers/video.go index ab62006..194fc1a 100644 --- a/controllers/video.go +++ b/controllers/video.go @@ -77,10 +77,6 @@ func (c *VideoController) Feed() { func (c *VideoController) Publish() { token := c.GetString("token") title := c.GetString("title") - if err := utils.ValidateToken(token); err != nil { - c.PublishFail("token验证失败") - return - } user, _ := utils.GetUserFromToken(token) if url := c.UploadMP4(c.GetFile("data")); url == "" { @@ -134,15 +130,6 @@ func (c *VideoController) PublishFail(msg string) { func (c *VideoController) List() { uid, _ := c.GetInt("user_id") token := c.GetString("token") - if err := utils.ValidateToken(token); err != nil { - c.Data["json"] = map[string]interface{}{ - "status_code": 1, - "status_msg": "token验证失败", - "video_list": nil, - } - c.ServeJSON() - return - } var ( videos []*models.Video videoList []*object.VideoInfo diff --git a/main.go b/main.go index 9199b03..10d78fa 100644 --- a/main.go +++ b/main.go @@ -3,10 +3,11 @@ package main import ( _ "ByteRhythm/models" _ "ByteRhythm/routers" + "ByteRhythm/utils" "github.com/beego/beego/v2/server/web" ) func main() { - //web.InsertFilter("*", web.BeforeRouter, utils.FilterToken) + web.InsertFilter("*", web.BeforeRouter, utils.FilterToken) web.Run() } diff --git a/routers/router.go b/routers/router.go index 9553355..5fe92e6 100644 --- a/routers/router.go +++ b/routers/router.go @@ -28,14 +28,14 @@ func init() { web.NSRouter("/list/", &controllers.CommentController{}, "get:CommentList"), ), web.NSNamespace("/relation", - web.NSRouter("/action", &controllers.FollowController{}, "post:ActionRelation"), - web.NSRouter("/follow/list", &controllers.FollowController{}, "get:ListFollowRelation"), - web.NSRouter("/follower/list", &controllers.FollowController{}, "get:ListFollowerRelation"), - web.NSRouter("/friend/list", &controllers.FollowController{}, "get:ListFriendRelation"), + web.NSRouter("/action/", &controllers.FollowController{}, "post:ActionRelation"), + web.NSRouter("/follow/list/", &controllers.FollowController{}, "get:ListFollowRelation"), + web.NSRouter("/follower/list/", &controllers.FollowController{}, "get:ListFollowerRelation"), + web.NSRouter("/friend/list/", &controllers.FollowController{}, "get:ListFriendRelation"), ), web.NSNamespace("/message", - web.NSRouter("/chat", &controllers.MessageController{}, "get:ChatMessage"), - web.NSRouter("/action", &controllers.MessageController{}, "post:ActionMessage"), + web.NSRouter("/chat/", &controllers.MessageController{}, "get:ChatMessage"), + web.NSRouter("/action/", &controllers.MessageController{}, "post:ActionMessage"), ), ) web.AddNamespace(ns) diff --git a/utils/token.go b/utils/token.go index 8c84124..989eed5 100644 --- a/utils/token.go +++ b/utils/token.go @@ -6,7 +6,6 @@ import ( "github.com/beego/beego/v2/core/logs" "github.com/beego/beego/v2/server/web/context" "github.com/dgrijalva/jwt-go" - "strings" "time" ) @@ -105,26 +104,13 @@ func GenerateToken(user models.User, expiredSeconds int) (tokenString string) { } var FilterToken = func(ctx *context.Context) { - logs.Info("current router path is ", ctx.Request.RequestURI) - - if ctx.Request.RequestURI != "/douyin/user/login/" && ctx.Input.Header("Authorization") == "" { - logs.Error("without token, unauthorized !!") - ctx.ResponseWriter.WriteHeader(401) - ctx.ResponseWriter.Write([]byte("no permission")) - return - } - - if ctx.Request.RequestURI != "/douyin/user/login/" && ctx.Input.Header("Authorization") != "" { - token := ctx.Input.Header("Authorization") - token = strings.Split(token, " ")[0] // Split by space to get the actual token - - //logs.Info("current token: ", token) - - // Validate token + //获取token字段的值,token在url中传递 + if token := ctx.Input.Query("token"); token != "" { if err := ValidateToken(token); err != nil { - logs.Error("invalid or expired token: ", err) - ctx.ResponseWriter.WriteHeader(401) - ctx.ResponseWriter.Write([]byte("invalid or expired token")) + ctx.Output.JSON(map[string]interface{}{ + "status_code": 1, + "status_msg": "token验证失败", + }, false, false) return } }