在PHP中使用Google reCAPTCHA进行验证

WBOY
WBOY 原创
2023-06-19 17:40:01 871浏览

在现代网络世界中,网站的安全性以及用户隐私的保护越来越成为重要话题。其中,人机验证这一技术方法已经成为防范恶意攻击行为的不可或缺的方式之一。Google reCAPTCHA,是一个被广泛应用于人机验证的工具,其概念已经深入人心,甚至在我们每天使用的许多网站上都能够看到其存在的身影。在本文中,我们将探讨如何在PHP中使用Google reCAPTCHA进行验证。

Google reCAPTCHA 的工作原理

Google reCAPTCHA最初是由Carnegie Mellon大学的研究团队开发的人类反机器人计算机程序,后被Google收购并改进。

它的工作原理是通过向用户展示一个包含文字、图像或音频等复杂的问题,并要求用户回答这个问题,从而识别出正在访问网站的是人而非机器人。此外,Google reCAPTCHA还可以根据用户的行为模式和浏览器指纹等因素,将访问者分为低风险、中风险和高风险三个等级,从而提高了验证的准确性并防止恶意攻击。

在PHP中使用Google reCAPTCHA进行验证

在使用Google reCAPTCHA进行验证之前,我们需要先从Google reCAPTCHA的官网(https://www.google.com/recaptcha/about)申请一个reCAPTCHA的Site Key和Secret Key。Site Key用于在用户端展示验证信息,Secret Key用于在后台校验用户的提交信息。这些信息是使用reCAPTCHA需要必须的,我们需要将他们妥善保存。

接下来,我们将重点讨论如何在PHP中使用Google reCAPTCHA进行验证。我们以一个简单的注册表单为例,该表单需要用户输入用户名、密码和验证码才能进行注册。具体步骤如下:

  1. 在HTML中嵌入Google reCAPTCHA的JavaScript代码
<head>
    <script src="https://www.google.com/recaptcha/api.js" async defer></script>
</head>
<body>
    <form>
        <!--其他表单元素-->
        <div class="g-recaptcha" data-sitekey="在这里填入你的Site Key"></div>
        <button type="submit" name="submit">注册</button>
    </form>
</body>

上述代码中引入了Google reCAPTCHA的JavaScript文件,并在表单中添加了一个 class 为“g-recaptcha”、data-sitekey属性值为我们在reCAPTCHA官网上申请到的Site Key的div元素。我们将这个元素嵌入表单中,这样当用户点击“注册”按钮时,就会触发Google reCAPTCHA的验证功能,完成用户是否为人类的判断。

  1. 验证验证码是否正确
<?php
if(isset($_POST['submit'])){//当用户按下注册按钮
    $username = $_POST['username'];
    $password = $_POST['password'];
    $captcha = $_POST['g-recaptcha-response'];
    
    $url = "https://www.google.com/recaptcha/api/siteverify";//Google reCAPTCHA的工作URL
    $data = array(
        'secret' => '在这里填入你的Secret Key',
        'response' => $captcha
    );
    $options = array(
        'http' => array(
            'header' => "Content-type: application/x-www-form-urlencoded
",
            'method' => 'POST',
            'content' => http_build_query($data)
        )
    );
    $context = stream_context_create($options);
    $result = file_get_contents($url, false, $context);//向Google服务器发送POST请求

    $response = json_decode($result);//解码JSON响应
    if($response->success){//如果验证码正确
        //将用户信息插入数据库
    }
    else{
        echo "验证码出错,请检查输入";
    }
}
?>

以上代码中,我们在注册的PHP处理脚本中,首先获取用户输入的用户名、密码、reCAPTCHA验证码(即$_POST['username']$_POST['password']$_POST['g-recaptcha-response']),然后构造POST请求到Google reCAPTCHA的URL中,其中请求数据中包含了我们申请到的Secret Key和用户提交的验证码。

接下来,我们使用file_get_contents()函数向Google reCAPTCHA服务器发送POST请求,并解码响应。响应的返回值是一个JSON格式对象,其中success字段表示用户的验证码是否正确。如果验证码正确,就将用户信息插入到数据库中;否则,将输出一段错误信息。

结语

Google reCAPTCHA可以简单、快速地为网站提供安全性保障,我们在代码中实现Google reCAPTCHA时只需要几行代码,就可以为我们的网站添加强大的验证机制!

以上就是在PHP中使用Google reCAPTCHA进行验证的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。