import{_ as d,c as r,a as o,b as s,e as n,w as l,d as a,r as p,o as c}from"./app-Dgsdh8A6.js";const i={};function u(h,t){const e=p("RouteLink");return c(),r("div",null,[t[5]||(t[5]=o('

登录操作

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

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

扫码登录

',4)),s("ul",null,[s("li",null,[n(e,{to:"/docs/login/login_action/QR.html"},{default:l(()=>t[0]||(t[0]=[a("扫码登录")])),_:1,__:[0]})])]),t[6]||(t[6]=o('

验证登录

人机验证流程:

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

申请captcha验证码

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

请求方式:GET

',6)),s("p",null,[t[2]||(t[2]=a("注: 另外参见 ")),n(e,{to:"/docs/login/login_action/password.html#%E8%8E%B7%E5%8F%96-captcha"},{default:l(()=>t[1]||(t[1]=[a("密码登录-手机号验证-获取 captcha")])),_:1,__:[1]})]),t[7]||(t[7]=o(`

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": ""
        }
    }
}

申请captcha验证码 (旧版)

http://passport.bilibili.com/web/captcha/combine

请求方式:GET

该接口曾从文档移除过, 经过测试仍可正常使用

URL参数:

参数名类型内容必要性备注
platnum平台类型必要默认为 6

JSON回复:

根对象:

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

data对象:

字段类型内容备注
resultobj套了个娃
typenum1作用尚不明确

result对象:

字段类型内容备注
successnum1作用尚不明确
gtstr极验id一般为固定值
challengestr极验KEY由B站后端产生用于人机验证
keystr登录秘钥与 captcha 无关, 与登录接口有关, 亦作 token

示例:

curl 'https://passport.bilibili.com/web/captcha/combine?plat=6'
查看响应示例:
{
  "code": 0,
  "data": {
    "result": {
      "success": 1,
      "gt": "bd111e81eda1cbb9f54425aafc0908ac",
      "challenge": "2903a8eb967a1d990444cb23ea42f417",
      "key": "76fb59fbd83a4d9d816162c5156fc964"
    },
    "type": 1
  }
}

进行验证

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

附: 手动验证器及其源码

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

继续登录

`,31)),s("ul",null,[s("li",null,[n(e,{to:"/docs/login/login_action/SMS.html"},{default:l(()=>t[3]||(t[3]=[a("短信登录")])),_:1,__:[3]})]),s("li",null,[n(e,{to:"/docs/login/login_action/password.html"},{default:l(()=>t[4]||(t[4]=[a("密码登录")])),_:1,__:[4]})])])])}const b=d(i,[["render",u]]),m=JSON.parse('{"path":"/docs/login/login_action/","title":"登录操作","lang":"zh-CN","frontmatter":{},"git":{"updatedTime":1724238159000,"contributors":[{"name":"SocialSisterYi","username":"SocialSisterYi","email":"1440239038@qq.com","commits":2,"url":"https://github.com/SocialSisterYi"},{"name":"SessionHu","username":"SessionHu","email":"102411014+SessionHu@users.noreply.github.com","commits":1,"url":"https://github.com/SessionHu"}],"changelog":[{"hash":"60a0c5d1a2f44fe61335da04571305fa7727a968","time":1724238159000,"email":"102411014+SessionHu@users.noreply.github.com","author":"Session小胡","message":"feat: 各种接口补充与错误修正 (#1066)"},{"hash":"f6760f4be38d5b592d396b211e48c666286524de","time":1677124138000,"email":"1440239038@qq.com","author":"SocialSisterYi","message":"🔨remove header index"},{"hash":"7d89ece2ac46425810647c4ac92acf5f3721cb68","time":1676998806000,"email":"1440239038@qq.com","author":"SocialSisterYi","message":"🚀调整项目结构"}]},"filePathRelative":"docs/login/login_action/readme.md"}');export{b as comp,m as data};