如何解决Kentico 如何在自定义表单控件中读取 POST 值
我正在开发 Kentico 应用程序 V12(在将相同的代码部署到 12 到 7 的其他安装之后),我添加了一个新的表单控件。 在我的情况下,控件用于 Google Recaptcha V3 令牌(因此我不需要保存该值),所以这些是我的步骤:
实际上我能够在客户端管理所有流程,我现在的目标是在保存数据之前验证令牌,所以我在我的 ascx 文件中添加了此代码
public partial class CMSModules_ReCAPTCHA : FormEngineUserControl
{
private static string GOOGLE_RECAPTCHA_LIBRARY_URL = "https://www.google.com/recaptcha/api.js";
public override bool IsValid()
{
return this.Validate();
}
public override object Value
{
get
{
// How can I get the value?
}
set { }
}
private bool Validate()
{
// Here's the code to validate the token
}
}
如果我发送表单,我可以在检查器上看到令牌已发送,但是如果验证不成功,我如何在我的 ascx 文件中获取该值并收到错误消息?
我试过 CMS.Helpers.ValidationHelper.GetString(Form.GetFieldValue("reCAPTCHA"))
但它不起作用。
reCAPTCHA 它是字段的名称,该值作为 g-recaptcha-response 发送。
解决方法
因此,我们处理此问题的方法是在前端文件 (.ascx) 上添加一个 HiddenField 控件,该控件由您正在运行的 javascript 填充,以处理标准的 recaptcha 内容(如您所提到的)。然后在表单回发时,该 HiddenField 具有您的 Value 属性可以使用的令牌值。
在formcontrol的.ascx上
<asp:HiddenField runat="server" ID="recaptchaToken" ClientIDMode="Static" />
然后在表单控件的 .ascx.cs 文件上
public override object Value
{
get
{
return recaptchaToken.Value;
}
set
{
recaptchaToken.Value = (string)value;
}
}
这样它就应该出现在您拥有表单控件的表单的回发上。
请记住,您的 JavaScript 也需要填充该值。喜欢:
document.getElementById('recaptchaToken').value = token; //the one from Google
您可能还需要处理验证。为此,我们覆盖 IsValid 成员并使用令牌调用 Google 进行验证。向下和肮脏的版本看起来像:
public override bool IsValid()
{
if (Value == null || String.IsNullOrEmpty(Value.ToString()))
return false;
var tokenResponse = Value.ToString();
// Clear for next time around
Value = "";
return ReCaptchaCheckPassed(GoogleSecretKey,tokenResponse);
}
public static bool ReCaptchaCheckPassed(string GoogleSecretKey,string RecaptchaResponse)
{
HttpClient httpClient = new HttpClient();
var res = httpClient.GetAsync($"https://www.google.com/recaptcha/api/siteverify?secret={googleSecretKey}&response={RecaptchaResponse}").Result;
if (res.StatusCode != HttpStatusCode.OK)
return false;
string JSONres = res.Content.ReadAsStringAsync().Result;
dynamic JSONdata = JObject.Parse(JSONres);
if (JSONdata.success != "true")
return false;
return true;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。