Skip to content
forked from CuteReimu/bilibili

哔哩哔哩bilibili的API的Go SDK

License

Notifications You must be signed in to change notification settings

rat857/bilibili

 
 

Repository files navigation

哔哩哔哩-API-Go版本

本项目是基于Go语言编写的哔哩哔哩API调用。目前常用的接口已经基本完成,具体进度可以看这里

声明

  1. 本项目遵守 AGPL 开源协议。
  2. 本项目基于 SocialSisterYi/bilibili-API-collect 中描述的接口编写。请尊重该项目作者的努力,遵循该项目的开源要求,禁止一切商业使用。
  3. 请勿滥用,本项目仅用于学习和测试!利用本项目提供的接口、文档等造成不良影响及后果与本人无关。
  4. 由于本项目的特殊性,可能随时停止开发或删档
  5. 本项目为开源项目,不接受任何形式的催单和索取行为,更不容许存在付费内容

PS:目前,B站调用接口时强制使用 https 协议

快速开始

由于B站最近对所有搜索类接口都加上了Wbi签名认证的风控策略,本项目还没有对其进行兼容,因此这些搜索类接口可能会返回“-403:非法访问”的错误。

不过,GetUserVideos接口好像又可以在不使用Wbi签名的情况下用了。本着代码能跑就不要乱动它的原则,因此就没管。

本项目的注释不会太多,使用时建议对照着 SocialSisterYi/bilibili-API-collect 的文档查看。

本项目预计不会编写单元测试代码。一则因为各项数据会频繁变动,难以写成固定的结果;二则因为每次单元测试都要大量请求B站API,会对其产生不必要的压力。

安装

go get -u github.com/CuteReimu/bilibili

在项目中引用即可使用

import "github.com/CuteReimu/bilibili"

首次登录

方法一:扫码登录

首先获取二维码:

qrCode, _ := bilibili.GetQRCode()
buf, _ := qrCode.Encode()
img, _ := png.Decode(buf) // 或者写入文件 os.WriteFile("qrcode.png", buf, 0644)
// 也可以调用 qrCode.Print() 将二维码打印在控制台

扫码并确认成功后,发送登录请求:

err := bilibili.LoginWithQRCode(qrCode)
if err == nil {
    log.Println("登录成功")
}

方法二:账号密码登录

首先获取人机验证参数:

captchaResult, _ := bilibili.Captcha()

captchaResult中的gtchallenge值保存下来,自行使用 手动验证器 进行人机验证,并获得validateseccode。然后使用账号密码进行登录即可:

err := bilibili.LoginWithPassword(userName, password, captchaResult, validate, seccode)
if err == nil {
    log.Println("登录成功")
}

方法三:使用短信验证码登录

首先用上述方法二相同的方式获取人机验证参数并进行人机验证。然后获取国际地区代码:

common, others, _ := bilibili.ListCountry()

当然,如果你已经确定cid的值,这一步可以跳过。中国大陆的cid就是1。

然后发送短信验证码:

captchaKey, _ := bilibili.SendSMS(tel, cid, captchaResult, validate, seccode)

然后就可以使用手机验证码登录了:

err := bilibili.LoginWithSMS(tel, cid, code, captchaKey) // 其中code是短信验证码
if err == nil {
    log.Println("登录成功")
}

储存Cookies

使用上述任意方式登录成功后,Cookies值就已经设置好了。你可以保存Cookies值方便下次启动程序时不需要重新登录。

// 获取cookiesString,自行存储,方便下次启动程序时不需要重新登录
cookiesString := bilibili.GetCookiesString()

// 设置cookiesString,就不需要登录操作了
bilibili.SetCookiesString(cookiesString)

同时登录多个账号

可以新建多个client,每个登录不同的账号。用这种方法使用的函数与直接调用bilibili包下的函数是完全一样的。

client := bilibili.New()
err := client.LoginWithQRCode(result)

设置超时时间和logger

bilibili.SetTimeout(20 * time.Second) // 设置超时时间
bilibili.SetLogger(logger) // 自定义logger

进度

目前常用的接口已经基本完成,计划在这个版本内的功能有:

  • 专栏
  • 评论
  • 动态
  • 收藏
  • 直播
  • 登录
  • 消息
  • 用户
  • 视频
  • 大会员

其余的非常用接口会在后续的版本中不断补充

About

哔哩哔哩bilibili的API的Go SDK

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%