我希望能快速回答一个简单的问题。
我正试图在一个网站上使用ReCaptcha,该表格目前正在提交给salesforce.com。
在ReCaptcha指令中,它告诉我verify.php应该运行,然后提交,如果它通过的话。
具体如下:
<?php
require_once('recaptchalib.php');
$privatekey = "your_private_key";
$resp = recaptcha_check_answer ($privatekey,
$_SERVER["REMOTE_ADDR"],
$_POST["recaptcha_challenge_field"],
$_POST["recaptcha_response_field"]);
if (!$resp->is_valid) {
// What happens when the CAPTCHA was entered incorrectly
die ("The reCAPTCHA wasn't entered correctly. Go back and try it again." .
"(reCAPTCHA said: " . $resp->error . ")");
} else {
// Your code here to handle a successful verification
}
?>
如果原始表格要像以下那样提交:
action="https://www.salesforce.com/servlet/servlet.WebToLead?encoding=UTF-8" method="POST"
我将如何在上面的php脚本中处理这个问题?感谢您的帮助!
简单回答:你不能。
长话短说:行动不是由你控制的,而是由销售人员控制的。您也许可以将该操作作为验证脚本,然后为用户发布变量,但这很可能会破坏他们在salesforce的会话。真的没有任何实际的方法来解决这个问题。(我的意思是,你可以尝试为用户反向工程/重建会话,但要想把它做好可能需要做很多工作,然后他们可能会改变导致它崩溃的东西)
你最好的办法是有一个使用ReCaptcha的单独登录,然后把你的原始表单放在登录后面。
请参阅此线程:利用Salesforce Web重新获取信息以领导
将web引导表单设置为发布到Captcha联系人表单确认页面。
<form action="/contactFormConfirm.php" method="POST" >
然后配置确认页面以验证Captcha。如果经过验证,将所有字段从您的网站映射到潜在客户表单,并设置为发布到Salesforce.com。
在帖子中,他们分享了一个Captcha联系人表单确认页面的示例。