当前位置:首页 > 行业动态 > 正文

HTML:HTML 难以捉摸的 reCAPTCHA Bug. 复制代码总是失败

reCAPTCHA 是一个用于防止反面机器人和垃圾邮件的验证码服务,它通过让用户进行简单的验证来确保网站的访问者是人类,有时候在使用 HTML 代码时,你可能会遇到一些问题,导致 reCAPTCHA 无法正常工作,在这篇文章中,我们将讨论一些常见的问题以及如何解决它们。

HTML:HTML 难以捉摸的 reCAPTCHA Bug. 复制代码总是失败  第1张

1、确保正确安装 reCAPTCHA

你需要确保你已经正确地在你的网站上安装了 reCAPTCHA,你可以从 Google reCAPTCHA 官网(https://www.google.com/recaptcha/intro/v3.html)获取相关的 JavaScript 和 HTML 代码,将这段代码添加到你的 HTML 文件中,然后按照官方文档中的说明进行配置。

2、确保正确引用了 reCAPTCHA 的库文件

在使用 reCAPTCHA 之前,你需要确保你的网页已经正确地引用了 Google reCAPTCHA 的库文件,你可以通过以下方式引入:

<script src="https://www.google.com/recaptcha/api.js" async defer></script>

确保将这段代码添加到 <head> 标签内,或者在页面底部的 </body> 标签之前,这样可以确保在加载页面时,reCAPTCHA 的库文件已经被正确加载。

3、确保正确调用了 reCAPTCHA 的 API

在使用 reCAPTCHA 时,你需要确保已经正确地调用了它的 API,这通常涉及到在表单提交时触发一个事件,然后在事件处理函数中调用 reCAPTCHA 的 API,以下是一个简单的示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF8">
    <meta name="viewport" content="width=devicewidth, initialscale=1.0">
    <title>reCAPTCHA Example</title>
    <script src="https://www.google.com/recaptcha/api.js" async defer></script>
</head>
<body>
    <form action="submit.php" method="post">
        <!Your form fields go here >
        <div  datasitekey="your_site_key"></div>
        <button type="submit">Submit</button>
    </form>
    <script>
        document.querySelector('form').addEventListener('submit', function(event) {
            grecaptcha.ready(function() {
                grecaptcha.execute('your_site_key', {action: 'submit'}).then(function(token) {
                    // Add the token to your form data and submit the form
                    event.preventDefault();
                    var formData = new FormData(event.target);
                    formData.append('grecaptcharesponse', token);
                    fetch('submit.php', {method: 'POST', body: formData});
                });
            });
        });
    </script>
</body>
</html>

在这个示例中,我们首先在表单中添加了一个名为 grecaptcha 的 div,并为其分配了一个名为 your_site_key 的站点密钥,我们为表单添加了一个提交事件监听器,当表单提交时,会触发这个监听器,在监听器的回调函数中,我们首先检查 reCAPTCHA 是否已经准备好,然后调用其 API 来执行验证,如果验证成功,我们将收到一个 token,将其添加到表单数据中,并将表单数据发送到服务器进行处理。

4、确保服务器端验证了 reCAPTCHA 的响应

你需要确保你的服务器端代码能够正确地验证从客户端发送过来的 reCAPTCHA 响应,这通常涉及到使用 Google reCAPTCHA API 提供的验证接口,以下是一个简单的 PHP 示例:

<?php
$secretKey = "your_secret_key";
$ip = $_SERVER["REMOTE_ADDR"];
$response = file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret=$secretKey&response=$_POST['grecaptcharesponse']&remoteip=$ip");
$responseKeys = json_decode($response, true);
if (intval($responseKeys["success"]) !== 1) {
    // The reCAPTCHA validation failed, handle it accordingly (e.g. show an error message)
} else {
    // The reCAPTCHA validation succeeded, continue with your form submission process
}
?>

在这个示例中,我们首先从请求中获取客户端 IP 地址、reCAPTCHA 响应和站点密钥,我们使用这些信息调用 Google reCAPTCHA API 的验证接口,API 返回一个 JSON 对象,其中包含一个名为 success 的字段,表示验证是否成功,如果验证失败,我们可以显示一个错误消息;否则,我们可以继续处理表单提交过程。

0