我正在使用 PHP 开发一个网站,我想在其中一个会话中进行人工验证。对于开发,我最初在本地运行系统,当它准备好时,我将把它放在某个域上。
在reCAPTCHA 网站上,据说该插件只能在给定的域(和子域)上工作。
有没有办法在本地主机上使用 reCAPTCHA 插件?
我正在使用 PHP 开发一个网站,我想在其中一个会话中进行人工验证。对于开发,我最初在本地运行系统,当它准备好时,我将把它放在某个域上。
在reCAPTCHA 网站上,据说该插件只能在给定的域(和子域)上工作。
有没有办法在本地主机上使用 reCAPTCHA 插件?
原来的答案不再正确。开发人员指南现在指出:
“如果您想使用“localhost”进行开发,则必须将其添加到域列表中。”
这仅在您使用127.0.0.1/...
而不是访问 localhost 时才有效localhost/...
。
原始答案保留在下面。
“默认情况下不再支持 localhost 域。如果您希望继续支持它们进行开发,您可以将它们添加到您的站点密钥的支持域列表中。转到管理控制台以更新您的支持域列表。我们建议使用单独的密钥进行开发和生产,并且不允许 localhost 在您的生产站点密钥上。”
换句话说,只需使用相同的密钥。
这对我有用:
从reCAPTCHA 文档中提取:
使用以下测试密钥,您将始终获得 No CAPTCHA,并且所有验证请求都将通过。
站点密钥:
6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI
密钥:
6LeIxAcTAAAAAGG-vFI1TnRWxMZNFuojJ4WifJWe
reCAPTCHA 小部件将显示一条警告消息,声称它仅用于测试目的。请不要将这些密钥用于您的生产流量。
请注意,截至 2016 年,reCAPTCHA 不再天真地支持 localhost。从常见问题解答:
默认情况下不再支持 localhost 域。如果您希望继续支持它们进行开发,您可以将它们添加到您的站点密钥的支持域列表中。转到管理控制台以更新您支持的域列表。我们建议使用单独的密钥进行开发和生产,并且不允许在您的生产站点密钥上使用 localhost。
只需将其添加localhost
到您网站的域列表中,您就可以了。
它是如此容易:
localhost
&添加127.0.0.1
到新站点的域中,如下图所示。更新:
如果您的问题是如何在 Google 网站上设置 reCAPTCHA 以便在 localhost 中使用它,那么它就像我在上面写的那样,但是如果您很好奇如何在两者 localhost
上使用 reCAPTCHA并在控制器中website host
使用最少的代码并防止像其中的一些代码ConfigurationManager.AppSettings["ReCaptcha:SiteKey"]
,然后我会在我的答案中为您提供这些额外的描述和代码。
你喜欢下面的 GET 和 POST 操作吗?
下面的代码支持 reCAPTCHA,不需要任何其他代码来处理 reCAPTCHA。
[HttpGet]
[Recaptcha]
public ActionResult Register()
{
// Your code in the GET action
}
[HttpPost]
[Recaptcha]
[ValidateAntiForgeryToken]
public ActionResult Register(RegisterViewModel model, string reCaptcha_SecretKey){
// Your code in the POST action
if (!ModelState.IsValid || !ReCaptcha.Validate(reCaptcha_SecretKey))
{
// Your code
}
// Your code
}
在视图中:(参考)
@ReCaptcha.GetHtml(@ViewBag.publicKey)
@if (ViewBag.RecaptchaLastErrors != null)
{
<div>Oops! Invalid reCAPTCHA =(</div>
}
使用它
A)将以下内容添加ActionFilter
到您的 Web 项目中:
public class RecaptchaAttribute : FilterAttribute, IActionFilter
{
public void OnActionExecuting(ActionExecutingContext filterContext)
{
var setting_Key = filterContext.HttpContext.Request.IsLocal ? "ReCaptcha_Local" : "ReCaptcha";
filterContext.ActionParameters["ReCaptcha_SecretKey"] = ConfigurationManager.AppSettings[$"{setting_Key}:SecretKey"];
}
public void OnActionExecuted(ActionExecutedContext filterContext)
{
var setting_Key = filterContext.HttpContext.Request.IsLocal ? "ReCaptcha_Local" : "ReCaptcha";
filterContext.Controller.ViewBag.Recaptcha = ReCaptcha.GetHtml(publicKey: ConfigurationManager.AppSettings[$"{setting_Key}:SiteKey"]);
filterContext.Controller.ViewBag.publicKey = ConfigurationManager.AppSettings[$"{setting_Key}:SiteKey"];
}
}
B)在您的文件中添加两者的 reCAPTCHA 设置键,localhost
如下所示:website
webconfig
<appSettings>
<!-- RECAPTCHA SETTING KEYS FOR LOCALHOST -->
<add key="ReCaptcha_Local:SiteKey" value="[Localhost SiteKey]" />
<add key="ReCaptcha_Local:SecretKey" value="[Localhost SecretKey]" />
<!-- RECAPTCHA SETTING KEYS FOR WEBSITE -->
<!--<add key="ReCaptcha:SiteKey" value="[Webite SiteKey]" />
<add key="ReCaptcha:SecretKey" value="[Webite SecretKey]" />-->
<!-- OTHER SETTING KEYS OF YOUR PROJECT -->
</appSettings>
注意:通过这种方式,您无需在操作和视图中手动设置post 操作reCaptcha_SecretKey
中的参数或任何用于 reCaptcha 的参数。所有这些都将在运行时自动填充适当的值,具体取决于您是否在 localhost 或网站上运行了项目。ViewBag
当您在 Google reCAPTCHA 中添加域时:
添加新域:
本地主机,而不是本地主机
“L”是大写字母。
截至 2021 年 1 月 2 日,谷歌在本文中发布了这两个密钥进行测试。
我想用 reCAPTCHA 运行自动化测试。我应该怎么办?对于 reCAPTCHA v3,为测试环境创建一个单独的密钥。分数可能不准确,因为 reCAPTCHA v3 依赖于查看真实流量。
对于 reCAPTCHA v2,请使用以下测试密钥。您将永远不会收到验证码,并且所有验证请求都会通过。
Site key: 6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI
Secret key: 6LeIxAcTAAAAAGG-vFI1TnRWxMZNFuojJ4WifJWe
reCAPTCHA 小部件将显示一条警告消息,以确保它不用于生产流量。
在我第一次使用密钥时,生成的电子邮件进入了垃圾邮件。
删除当前的 reCAPTCHA 密钥,注册新密钥,并使用以下域设置您的密钥设置:
127.0.0.1
localhost
谷歌最近已停止默认允许 localhost (正如@Artur Cesar De Melo 所触及的那样)。这是在他们的常见问题解答下:
我收到一条错误消息“本地主机不在支持的域列表中”。以前是这样的,我该怎么办?
默认情况下不再支持 localhost 域。如果您希望继续支持它们进行开发,您可以将它们添加到您的站点密钥的支持域列表中。转到管理控制台以更新您支持的域列表。我们建议使用单独的密钥进行开发和生产,并且不允许在您的生产站点密钥上使用 localhost。
1:为您的开发环境创建一个单独的密钥
2:将 127.0.0.1 添加到允许域列表中
3:保存更改并等待最多 30 分钟以使更改生效
reCAPTCHA 将无法在localhost/
.
使用127.0.0.1/
而不是localhost/
.
添加 JavaScript 插件
添加 Google 提供的课程和您的站点密钥
默认情况下不再支持 localhost 域。如果您希望继续支持它们进行开发,您可以将它们添加到您的站点密钥的支持域列表中。转到管理控制台以更新您支持的域列表。我们建议使用单独的密钥进行开发和生产,并且不允许在生产站点密钥上使用 localhost
在您的 Google reCAPTCHA 网站 ( https://www.google.com/recaptcha/admin/site/{siteid}/settings )的域列表中,添加LOCALHOST
.
如果上述方法不起作用,请尝试添加127.0.0.1
。
localhost现在可以工作了。但是,请记住,将localhost添加到域名列表后,最多需要 30 分钟才能生效(根据针对域名列表显示的帮助提示)。
我最近正在创建一个涉及 reCAPTCHA v2 的网站,我需要在我的本地主机上进行测试自动化。我没有在 reCAPTCHA 管理门户中添加任何 IP 地址或localhost 。
请按照以下步骤操作
登录到 reCAPTCHA 管理站点。截屏
定位键设置
点击高级设置
在域名验证下,取消选中验证 reCAPTCHA 解决方案的来源复选框。此选项用于验证来自上述域之一的请求。
请注意,如果禁用,您需要在验证解决方案时检查服务器上的主机名。
我创建了一个新密钥,禁用它,并使用这个密钥在 localhost 中进行测试。
这是一个为评论实现 reCAPTCHA的示例页面。
可以写“localhost”或“127.0.0.1”,但URL必须相同。
示例:Google Domains 添加 -> localhost URL => localhost/login.php
示例:Google Domains 添加 -> 127.0.0.1 URL => 127.0.0.1/login.php
如果您有旧密钥,则应重新创建 API 密钥。还要注意代理。
截至 2021 年的今天,Google reCAPTCHA Enterprise 版控制台包含一项验证检查,不允许将其添加localhost
到允许的域列表中。为了解决这个问题(显然仅用于开发/测试目的)为我做以下工作:
在您的主机文件中创建一个条目,将您的域解析为您的本地主机
127.0.0.1 whatever-your-domain-will-be.com
不要通过导航到 localhost 来测试您的应用程序,而是通过导航到您的域来测试您的应用程序。
我的本地服务器/应用程序通常会在 http://localhost:4000 运行,因此导航到http://whatever-your-domain-will-be.com:4000就可以了。
一旦部署或测试完成,就很容易删除主机文件条目,并且在 reCAPTCHA 允许的域列表中没有挥之不去的垃圾。
对我有用的方法是使用我的外部 IP 地址。
如果您不知道它是什么,只需谷歌“我的 IP 是什么”
然后使用您的 IP 地址并在您的域中为验证码设置它,它应该开始正常工作。
出于测试目的,如果您想在localhost上测试包含 reCAPTCHA 的网页,请通过管理控制台2在域列表中添加localhost :https : //www.google.com/recaptcha/admin。*建议为 localhost 创建一个单独的站点密钥。
如果您使用的是 Laravel,那么您应该重新启动服务器并运行以下两个命令:
php artisan config:clear
php artisan cache:clear
这可能有助于所有在本地主机上遇到 reCAPTCHA 问题的用户。谷歌确实说“默认情况下,所有密钥都在 'localhost'(或 '127.0.0.1')上工作”,但实际上在 localhost 上使用 reCAPTCHA 可能会导致问题。就我而言,我使用安全令牌解决了它。
我在Laravel网站上收到与 reCAPTCHA 相关的错误。我通过使用一些命令和一个 env 文件解决了它,以前的答案也将有助于解决这个问题。
首先,检查 Google reCAPTCHA 密钥的 env 文件(在您的情况下是具有 Google reCAPTCHA 密钥的文件)。
其次,运行这些命令:
php artisan config:clear
php artisan cache:clear
composer dump-autoload
php artisan view:clear
php artisan route:clear
它会解决你的问题。