文档

图形认证服务端集成

更新时间:

本文介绍如何通过调用接口使用图形认证功能。

使用须知

请根据需要先下载以下Demo包,然后阅读README.md文件,运行Demo并启动项目。

接入流程示例代码

当用户在客户端界面通过验证码后,客户端将生产验证码相关参数,用户业务请求带上这些参数,后端业务接口再将这些参数上传到二次校验接口,确认用户本次验证的有效性。

def post(self):
    # 1.初始化验证参数信息
    captcha_id = '647f5ed2ed8acb4be36784e01556****'
    captcha_key = 'b09a7aafbfd83f73b35a9b530d03****'
    api_server = 'https://captcha-api.dypns.com'
      
    # 2.获取用户验证后前端传过来的验证参数
    lot_number = self.get_argument('lot_number', '')
    captcha_output = self.get_argument('captcha_output', '')
    pass_token = self.get_argument('pass_token', '')
    gen_time = self.get_argument('gen_time', '')
      
    # 3.生成签名
    # 生成签名使⽤标准的hmac算法,使用用户当前完成验证的流水号lot_number作为原始消息mess
    # 采用sha256散列算法将message和key进行单向散列生成最终的签名
    lotnumber_bytes = lot_number.encode()
    prikey_bytes = captcha_key.encode()
    sign_token = hmac.new(prikey_bytes, lotnumber_bytes, digestmod='SHA256').hex
    
    # 4.上传校验参数到验证服务⼆次验证接口, 校验用户验证状态
    query = {
          "lot_number": lot_number,
          "captcha_output": captcha_output,
          "pass_token": pass_token,
          "gen_time": gen_time,
          "sign_token": sign_token,
           }
    # captcha_id参数建议放在url后面, 方便请求异常时可以在日志中根据id快速定位到异常请
    url = api_server + '/validate' + '?captcha_id={}'.format(captcha_id)
    # 注意处理接口异常情况,当请求⼆次验证接口异常或响应状态非200时做出相应异常处理
    # 保证不会因为接口请求超时或服务未响应而阻碍业务流程
    try:
       res = requests.post(url, query)
       assert res.status_code == 200
       gt_msg = json.loads(res.text)
    except Exception as e:
       gt_msg = {'result': 'success', 'reason': 'request api fail'}

    # 5.根据⼆次验证接口返回的用户验证状态, 网站主进行自己的业务逻辑
    if gt_msg['result'] == 'success':
       self.write({'login': 'success', 'reason': gt_msg['reason']})
    else:
        self.write({'login':'fail','reason': gt_msg['reason']'})

二次校验接口

接口信息

说明

接口地址

https://captcha.alicaptcha.com/validate

协议⽀持

HTTP/HTTPS

请求方法

GET/POST

请求格式

application/x-www-form-urlencoded

返回类型

JSON

请求参数

请求参数

类型

说明

lot_number

String

验证流水号。

captcha_output

String

验证输出信息。

pass_token

String

验证通过标识。

gen_time

String

验证通过时间戳。

captcha_id

String

验证ID。

sign_token

String

验证签名。

返回示例

校验成功返回示例

{
    "status": "success", // 请求状态
    "result": "success", // ⼆次校验结果
    "reason": "", // 校验结果说明
    "captcha_args": { // 验证输出参数
        "used_type": "icon",
        "user_ip": "127.0.0.1",
        "lot_number": "4dc3cfc2cdff448cad8d13107198d473",
        "scene": "反爬虫",
        "referer": "http://127.0.0.1:8077/"
        // ...
    }
}

校验失败返回示例

{
    "status": "success", // 请求状态
    "result": "fail", // ⼆次校验结果
    "reason": "pass_token expire", // 校验结果说明
    "captcha_args": { // 验证输出参数
        "used_type": "icon",
        "user_ip": "127.0.0.1",
        "lot_number": "4dc3cfc2cdff448cad8d13107198d473",
        "scene": "反爬虫",
        "referer": "http://127.0.0.1:8077/"
        // ...
    }
}

请求结果异常返回示例

{
    "status": "error", // 请求状态
    "code": "-50005", // 错误码
    "msg": "illegal gen_time", // 错误信息
    "desc": { // 错误描述
        "type": "defined error"
    }
}
  • 本页导读 (1)
文档反馈