是否可以使用“die”标记链接到错误网站,而不是默认显示的文本?
require_once('recaptchalib.php');
$privatekey = "*******";
$resp = recaptcha_check_answer ($privatekey,
$_SERVER["REMOTE_ADDR"],
$_POST["recaptcha_challenge_field"],
$_POST["recaptcha_response_field"]);
if (!$resp->is_valid) {
die ("The reCAPTCHA wasn't entered correctly. Go back and try it again." .
"(reCAPTCHA said: " . $resp->error . ")");
}
像:
die ('error.php');
当然这不起作用。但我无法弄清楚如何使用模具标签。
答案 0 :(得分:0)
die()
无法执行任何操作,但是您的代码已经具有执行所需操作的结构:
if (!$resp->is_valid) {
header('Location: http://example.com');
die ("The reCAPTCHA wasn't entered correctly. Go back and try it again." .
"(reCAPTCHA said: " . $resp->error . ")");
}
请注意,如果您在此代码之前输出任何内容,则必须使用其他方法进行重定向,因为header()
在发送标头后(通过启动输出)将无效。
值得注意的是,如果验证码不匹配而不是重定向和停止执行,那么改变程序流程可能会更好。如果您重定向(按原样),则会丢失与当前请求关联的所有数据,而如果您设置$captcha_error = true
之类的内容并继续执行该程序(根据$captcha_error
更改流程),则最终会由于验证码错误,因此您没有重置整个表单,因此用户体验更好。