Ich habe gerade reCaptcha auf meiner Website installiert und setzen Sie die Kontrolle auf meine Kommentar-Post, soweit so gut.Verwenden von reCaptcha mit BlogEngine.net
Nun zu validieren reCaptcha sagt es einfach tun Page.IsValid.
Allerdings verwendet BlogEngine Ajax und einige JS, um seine addComment-Funktion zu veröffentlichen, und wenn ich das teste, erhalte ich nur Fehler auf der Seite in der Statusleiste. Hier
ist die bloengine Post-Funktion -
/// <summary>
/// Processes a callback event that targets a control.
/// </summary>
/// <param name="eventArgument">A string that represents an event argument to pass to the event handler.</param>
public void RaiseCallbackEvent(string eventArgument)
{
if (!BlogSettings.Instance.IsCommentsEnabled)
return;
string[] args = eventArgument.Split(new string[] { "-|-" }, StringSplitOptions.None);
string author = args[0];
string email = args[1];
string website = args[2];
string country = args[3];
string content = args[4];
bool notify = bool.Parse(args[5]);
bool isPreview = bool.Parse(args[6]);
string sentCaptcha = args[7];
//If there is no "reply to" comment, args[8] is empty
Guid replyToCommentID = String.IsNullOrEmpty(args[8]) ? Guid.Empty : new Guid(args[8]);
string storedCaptcha = hfCaptcha.Value;
Comment comment = new Comment();
comment.Id = Guid.NewGuid();
comment.ParentId = replyToCommentID;
comment.Author = Server.HtmlEncode(author);
comment.Email = email;
comment.Content = Server.HtmlEncode(content);
comment.IP = Request.UserHostAddress;
comment.Country = country;
comment.DateCreated = DateTime.Now;
comment.Parent = Post;
comment.IsApproved = !BlogSettings.Instance.EnableCommentsModeration;
if (Page.User.Identity.IsAuthenticated)
comment.IsApproved = true;
if (website.Trim().Length > 0)
{
if (!website.ToLowerInvariant().Contains("://"))
website = "http://" + website;
Uri url;
if (Uri.TryCreate(website, UriKind.Absolute, out url))
comment.Website = url;
}
if (notify && !Post.NotificationEmails.Contains(email))
Post.NotificationEmails.Add(email);
else if (!notify && Post.NotificationEmails.Contains(email))
Post.NotificationEmails.Remove(email);
if (!isPreview)
{
Post.AddComment(comment);
SetCookie(author, email, website, country);
}
string path = Utils.RelativeWebRoot + "themes/" + BlogSettings.Instance.Theme + "/CommentView.ascx";
CommentViewBase control = (CommentViewBase)LoadControl(path);
control.Comment = comment;
control.Post = Post;
using (StringWriter sw = new StringWriter())
{
control.RenderControl(new HtmlTextWriter(sw));
_Callback = sw.ToString();
}
}
Ich versuchte nur darum, wenn Rückkehr (Page.IsValid!); aber das hat nie funktioniert.
Können Sie bitte die ASPX und jede aspx.cs Code schreiben, die das Captcha angeboten wird verwandt ? Ich bin ziemlich vertraut mit DNBE, da ich meinen persönlichen Blog verwende und einige Erweiterungen dafür geschrieben habe. –