recaptcha v2未获得;“成功”;
我在执行recaptcha v2 chekbox时遇到问题。我首先在我的表单中实现,它只在本地服务器中工作。在多次尝试失败后,我搜索了一些代码,并使用教程中的原始代码,不断出现错误。 网址: 希望有人能帮忙。谢谢 HTMLrecaptcha v2未获得;“成功”;,recaptcha,Recaptcha,我在执行recaptcha v2 chekbox时遇到问题。我首先在我的表单中实现,它只在本地服务器中工作。在多次尝试失败后,我搜索了一些代码,并使用教程中的原始代码,不断出现错误。 网址: 希望有人能帮忙。谢谢 HTML Ajax联系人表单 Ajax联系人表单 您的邮件已成功发送 PHP 在我的表单中尝试实现复选框recaptcha v2之后,我尝试实现不可见的recaptcha v2,这一个非常有效。我不知道这怎么会发生!你可以在函数中看到 我不知道这是否与我的ssl证书有关(来自let
Ajax联系人表单
Ajax联系人表单
您的邮件已成功发送
PHP
在我的表单中尝试实现复选框recaptcha v2之后,我尝试实现不可见的recaptcha v2,这一个非常有效。我不知道这怎么会发生!你可以在函数中看到
我不知道这是否与我的ssl证书有关(来自let's encrypt)
这对我帮助很大
谢谢你的评论 我遇到了完全相同的问题,我在下面发布了我的解决方案
我的测试解决方案是:
$google_url = "https://www.google.com/recaptcha/api/siteverify";
$secret_key = 'YOUR_SECRET_KEY';
$response = $_POST['g-recaptcha-response'];
$message = 'Google reCaptcha Test';
if(!empty($response))
{
$url = $google_url."?secret=".$secret_key."&response=".$response;
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($curl, CURLOPT_TIMEOUT, 15);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, TRUE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, TRUE);
$curlData = curl_exec($curl);
curl_close($curl);
$res = json_decode($curlData, TRUE);
if($res['success'] == 'true')
$message = "Success!";
else
$message = "Enter captcha again!";
}
您遇到了什么错误?我没有得到“成功”的响应,因此我得到了“请检查验证码格式2”,而不是使用带有“请检查验证码格式2”的警报,只是console.log($response)
来调试抱歉,没有起作用:(这只会将消息错误替换为nothing。问题是,当发送recaptcha时,google的响应是success==false。你知道如何调试web吗?使用开发工具?控制台和网络(如果你知道网络调用的样子)是有用的谢谢!!我会试试看
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
// access
$secretKey = 'my secret key here';
$captcha = $_POST['g-recaptcha-response'];
if(!$captcha){
echo '<p class="alert alert-warning">Please check the the captcha form1.</p>';
exit;
}
# FIX: Replace this email with recipient email
$mail_to = "demo@gmail.com";
# Sender Data
$subject = trim($_POST["subject"]);
$name = str_replace(array("\r","\n"),array(" "," ") , strip_tags(trim($_POST["name"])));
$email = filter_var(trim($_POST["email"]), FILTER_SANITIZE_EMAIL);
$phone = trim($_POST["phone"]);
$message = trim($_POST["message"]);
if ( empty($name) OR !filter_var($email, FILTER_VALIDATE_EMAIL) OR empty($phone) OR empty($subject) OR empty($message)) {
# Set a 400 (bad request) response code and exit.
http_response_code(400);
echo '<p class="alert alert-warning">Please complete the form and try again.</p>';
exit;
}
$ip = $_SERVER['REMOTE_ADDR'];
$response=file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret=$secretKey&response=$captcha&remoteip=$ip");
$responseKeys = json_decode($response,true);
if(intval($responseKeys["success"]) !== 1) {
echo '<p class="alert alert-warning">Please check the the captcha form2.</p>';
} else {
# Mail Content
$content = "Name: $name\n";
$content .= "Email: $email\n\n";
$content .= "Phone: $phone\n";
$content .= "Message:\n$message\n";
# email headers.
$headers = "From: $name <$email>";
# Send the email.
$success = mail($mail_to, $subject, $content, $headers);
if ($success) {
# Set a 200 (okay) response code.
http_response_code(200);
echo '<p class="alert alert-success">Thank You! Your message has been sent.</p>';
} else {
# Set a 500 (internal server error) response code.
http_response_code(500);
echo '<p class="alert alert-warning">Oops! Something went wrong, we couldnt send your message.</p>';
}
}
} else {
# Not a POST request, set a 403 (forbidden) response code.
http_response_code(403);
echo '<p class="alert alert-warning">There was a problem with your submission, please try again.</p>';
}
$google_url = "https://www.google.com/recaptcha/api/siteverify";
$secret_key = 'YOUR_SECRET_KEY';
$response = $_POST['g-recaptcha-response'];
$message = 'Google reCaptcha Test';
if(!empty($response))
{
$url = $google_url."?secret=".$secret_key."&response=".$response;
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($curl, CURLOPT_TIMEOUT, 15);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, TRUE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, TRUE);
$curlData = curl_exec($curl);
curl_close($curl);
$res = json_decode($curlData, TRUE);
if($res['success'] == 'true')
$message = "Success!";
else
$message = "Enter captcha again!";
}