我希望快速回答一个简单的问题。
我正在尝试在网站上使用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脚本中处理这个? 任何帮助表示赞赏!
答案 0 :(得分:2)
简短的回答:你做不到。
答案很长:行动不是由你控制的,而是由salesforce控制的。您可以将操作作为验证脚本,然后为用户发布变量,但这很可能会破坏他们在salesforce上的会话。实际上并没有任何实际的方法。 (我的意思是你可以尝试为用户进行逆向工程/重建会话,但要做到这一点可能需要做很多工作,然后才能改变导致它破坏的东西)
您最好的选择是使用ReCaptcha进行单独登录,然后将原始表单放在登录后面。
答案 1 :(得分:0)
看到这个帖子: Recaptcha with Salesforce Web-To-Lead
将网络设置为潜在客户表单以发布到Captcha联系表单确认页面。
<form action="/contactFormConfirm.php" method="POST" >
然后配置确认页面以验证验证码。如果经过验证,则将您网站上的所有字段映射到潜在客户表单,并设置为发布到Salesforce.com。
在线程中,他们共享了Captcha联系表单确认页面的示例。