登录操作

人机验证方式登录包含账号密码登录与手机短信验证码登录

注:扫码登录不需要进行人机验证,故不使用以下接口

扫码登录

验证登录

人机验证流程:

  1. 请求验证码参数,得到登录密钥key与极验idgt和极验KEYchallenge
  2. 进行滑动or点击验证
  3. 返回验证结果validateseccode,进行短信或密码登录

申请captcha验证码

https://passport.bilibili.com/x/passport-login/captcha?source=main_web

请求方式:GET

json回复:

根对象:

字段类型内容备注
codenum返回值0:成功
messagestr返回信息
ttlnum1
dataobj信息本体

data对象:

字段类型内容备注
geetestobj极验captcha数据
tencentobj(?)作用尚不明确
tokenstr登录 API token与 captcha 无关,与登录接口有关
typestr验证方式用于判断使用哪一种验证方式,目前所见只有极验
geetest:极验

geetest对象:

字段类型内容备注
gtstr极验id一般为固定值
challengestr极验KEY由B站后端产生用于人机验证

示例:

curl 'https://passport.bilibili.com/x/passport-login/captcha?source=main_web'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "type": "geetest",
        "token": "00fbe75cc2864ba0af969231f193a974",
        "geetest": {
            "challenge": "a57d9be17505d4a15ed84694c48fbf74",
            "gt": "ac597a4506fee079629df5d8b66dd4fe"
        },
        "tencent": {
            "appid": ""
        }
    }
}

进行验证

本文档为 Bilibili 文档,验证码为 geetest 极验open in new window 提供,故不提供相关 API

附: 手动验证器open in new window及其源码open in new window

  1. 打开手动验证器,在1、2分别填入上面API返回的gtchallenge
  2. 点击按钮3,稍等加载验证码,点击按钮4进行验证
  3. 验证完成后,点击按钮5生成验证结果
  4. 使用最开始获得到的keychallenge和刚获得到的validateseccode继续之后的登录操作

继续登录