您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

reCAPTCHA-错误代码:在验证用户的响应时(缺少关于POST的详细信息),“缺少输入响应”,“缺少输入秘密”

reCAPTCHA-错误代码:在验证用户的响应时(缺少关于POST的详细信息),“缺少输入响应”,“缺少输入秘密”

reCaptcha Google论坛上进行了一些研究和挖掘,看来该端点仅接受认的内容类型;application/x-www- form-urlencoded

这意味着你应该 使用JSON发送您的响应令牌与本站关键。而是按照application/x-www-form- urlencoded定义的方式发送值:

使用此内容类型提交的表单必须按以下方式编码:

1. 控件名称和值被转义。用[+]替换空格字符,然后按[RFC1738]第2.2节中的描述转义保留的字符:非字母数字字符替换为’%HH’,一个百分号和两个十六进制数字,分别表示该字符的ASCII码。字符。换行符表示为“ CR LF”对(即’%0D%0A’)。 2. 控件名称/值以它们在文档中出现的顺序列出。名称与值之间用’=’分隔,名称/值对之间由’&’分隔。

因此,您有两种方法可以执行此操作,一种是通过URL(查询字符串)传递POST参数,然后将其作为POST请求发送:

https://www.google.com/recaptcha/api/siteverify?secret=${SECRET_KEY}&response=${req.body['g-recaptcha-response']}

或手动将数据附加到主体,如下所示:

verify(req, res, next) {
  const VERIFY_URL = "https://www.google.com/recaptcha/api/siteverify";

  return fetch(VERIFY_URL, {
    method: "POST",
    headers: { "Content-Type": "application/x-www-form-urlencoded" },
    body: `secret=${SECRET_KEY}&response=${req.body['g-recaptcha-response']}`,
  })
  .then(response => response.json())
  .then(data => {
    res.locals.recaptcha = data;
    return next();
  });
}
其他 2022/1/1 18:18:51 有609人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶