Skip to content

Commit d7cdfb1

Browse files
authored
Fix bilibilipush 20240404 (#884)
* ✨ 添加cookie * ✨ 添加签名 * 🐛 修改嵌套错误 * 🐛 优化infoURL * ✨ 添加cookie
1 parent cf0e87a commit d7cdfb1

File tree

1 file changed

+28
-9
lines changed

1 file changed

+28
-9
lines changed

plugin/bilibili/bilibilipush.go

Lines changed: 28 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ import (
2424
const (
2525
ua = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Safari/537.36"
2626
referer = "https://space.bilibili.com/%v"
27-
infoURL = "https://api.bilibili.com/x/space/wbi/acc/info?mid=%v&token=&platform=web&web_location=1550101"
27+
infoURL = "https://api.bilibili.com/x/space/wbi/acc/info?mid=%v"
2828
)
2929

3030
// bdb bilibili推送数据库
@@ -77,7 +77,7 @@ func init() {
7777

7878
en.OnRegex(`^添加[B|b]站订阅\s?(.{1,25})$`, zero.UserOrGrpAdmin, getPara).SetBlock(true).Handle(func(ctx *zero.Ctx) {
7979
buid, _ := strconv.ParseInt(ctx.State["uid"].(string), 10, 64)
80-
name, err := getName(buid)
80+
name, err := getName(buid, cfg)
8181
if err != nil || name == "" {
8282
ctx.SendChain(message.Text("ERROR: ", err))
8383
return
@@ -95,7 +95,7 @@ func init() {
9595

9696
en.OnRegex(`^取消[B|b]站订阅\s?(.{1,25})$`, zero.UserOrGrpAdmin, getPara).SetBlock(true).Handle(func(ctx *zero.Ctx) {
9797
buid, _ := strconv.ParseInt(ctx.State["uid"].(string), 10, 64)
98-
name, err := getName(buid)
98+
name, err := getName(buid, cfg)
9999
if err != nil {
100100
ctx.SendChain(message.Text("ERROR: ", err))
101101
return
@@ -112,7 +112,7 @@ func init() {
112112
})
113113
en.OnRegex(`^取消[B|b]站动态订阅\s?(.{1,25})$`, zero.UserOrGrpAdmin, getPara).SetBlock(true).Handle(func(ctx *zero.Ctx) {
114114
buid, _ := strconv.ParseInt(ctx.State["uid"].(string), 10, 64)
115-
name, err := getName(buid)
115+
name, err := getName(buid, cfg)
116116
if err != nil {
117117
ctx.SendChain(message.Text("ERROR: ", err))
118118
return
@@ -133,7 +133,7 @@ func init() {
133133
if gid == 0 {
134134
gid = -ctx.Event.UserID
135135
}
136-
name, err := getName(buid)
136+
name, err := getName(buid, cfg)
137137
if err != nil {
138138
ctx.SendChain(message.Text("ERROR: ", err))
139139
return
@@ -200,10 +200,18 @@ func changeAtAll(gid int64, b int) (err error) {
200200
}
201201

202202
// 取得uid的名字
203-
func getName(buid int64) (name string, err error) {
203+
func getName(buid int64, cookiecfg *bz.CookieConfig) (name string, err error) {
204204
var ok bool
205205
if name, ok = upMap[buid]; !ok {
206206
data, err := web.RequestDataWithHeaders(web.NewDefaultClient(), bz.SignURL(fmt.Sprintf(infoURL, buid)), "GET", func(r *http.Request) error {
207+
if cookiecfg != nil {
208+
cookie := ""
209+
cookie, err = cookiecfg.Load()
210+
if err != nil {
211+
return err
212+
}
213+
r.Header.Add("Cookie", cookie)
214+
}
207215
r.Header.Set("User-Agent", ua)
208216
return nil
209217
}, nil)
@@ -262,8 +270,19 @@ func unsubscribeLive(buid, groupid int64) (err error) {
262270
return bdb.insertOrUpdateLiveAndDynamic(bpMap)
263271
}
264272

265-
func getUserDynamicCard(buid int64) (cardList []gjson.Result, err error) {
266-
data, err := web.RequestDataWith(web.NewDefaultClient(), fmt.Sprintf(bz.SpaceHistoryURL, buid, 0), "GET", referer, ua, nil)
273+
func getUserDynamicCard(buid int64, cookiecfg *bz.CookieConfig) (cardList []gjson.Result, err error) {
274+
data, err := web.RequestDataWithHeaders(web.NewDefaultClient(), fmt.Sprintf(bz.SpaceHistoryURL, buid, 0), "GET", func(req *http.Request) error {
275+
if cookiecfg != nil {
276+
cookie := ""
277+
cookie, err = cookiecfg.Load()
278+
if err != nil {
279+
return err
280+
}
281+
req.Header.Add("Cookie", cookie)
282+
}
283+
req.Header.Add("User-Agent", ua)
284+
return nil
285+
}, nil)
267286
if err != nil {
268287
return
269288
}
@@ -289,7 +308,7 @@ func sendDynamic(ctx *zero.Ctx) error {
289308
uids := bdb.getAllBuidByDynamic()
290309
for _, buid := range uids {
291310
time.Sleep(2 * time.Second)
292-
cardList, err := getUserDynamicCard(buid)
311+
cardList, err := getUserDynamicCard(buid, cfg)
293312
if err != nil {
294313
return err
295314
}

0 commit comments

Comments
 (0)