Validating Form in ASP.NET MVC C#

本文关键字:MVC NET ASP Form in Validating | 更新日期: 2023-09-27 17:58:49

正如标题所说,我正在尽一切努力让RegEx等验证生效,但它根本不起作用。我在这里做错了什么?

你根本不需要在表格上键入任何数据,你仍然可以发送一封空邮件,我不想这样。。。

型号:

using System.ComponentModel.DataAnnotations;
namespace DK_Design.Models
{
    public class SendMail
    {
        [Required]
        public string Name { get; set; }
        [Required]
        public string Email { get; set; }
        public string Number { get; set; }
        [Required]
        public string Message { get; set; }
    }
}

视图:

@{
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<div class="container">
    <div class="row">
        <div class="box">
            <div class="col-lg-12">
                <hr>
                <h2 class="intro-text text-center">
                    Kontakta
                    <strong>Oss!</strong>
                </h2>
                <hr>
            </div>
            <div class="col-md-8">
            </div>
            <div class="col-md-4">
                <p>
                    Telefon:
                    <strong>123.456.7890</strong>
                </p>
                <p>
                    Email:
                    <strong><a href="mailto:*****@live.se">*****@live.se</a><!--I am obviously blurring the email on purpose here. The email function itself works.--> </strong>
                </p>
                <p>
                    Address:
                    <strong>
                        3481 Melrose Place
                        <br>Beverly Hills, CA 90210
                    </strong>
                </p>
            </div>
            <div class="clearfix"></div>
        </div>
    </div>
    <div class="row">
        <div class="box">
            <div class="col-lg-12">
                <hr>
                <h2 class="intro-text text-center">
                    Skicka
                    <strong>Ett Meddelande</strong>
                </h2>
                <hr>
                @if (ViewData["Message"] != null)
                {
                    <div class="alert alert-success">Ditt e-mail har skickats!</div>
                }
                @if (ViewData["Message"] == null)
                {
                    <div class="alert alert-danger">Ditt e-mail kan inte skickas!</div>
                }
                <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Fugiat, vitae, distinctio, possimus repudiandae cupiditate ipsum excepturi dicta neque eaque voluptates tempora veniam esse earum sapiente optio deleniti consequuntur eos voluptatem.</p>
                <form class="form-wrapper" id="contact-form" method="post" role="form" novalidate>
                    <div class="form-group">
                        <div class="row">
                            <div class="form-group col-lg-4">
                                <label for="name">
                                    Namn *
                                </label>
                                <input type="text" id="name" name="name" class="form-control" data-errmsg="Name is required."
                                       placeholder="Ditt Namn" required />
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="row">
                            <div class="form-group col-lg-4">
                                <label for="email">
                                    Email *
                                </label>
                                <input type="text" id="email" name="email" class="form-control" data-errmsg="Email is required."
                                       placeholder="Ditt Email" required />
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="row">
                            <div class="form-group col-lg-4">
                                <label for="number">
                                    Telefonnummer
                                </label>
                                <input type="text" id="number" name="number" class="form-control"
                                       placeholder="Ditt Telefonnummer" />
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="row">
                            <div class="form-group col-lg-8">
                                <label for="message">
                                    Meddelande *
                                </label>
                                <textarea id="message" name="message" class="form-control" data-errmsg="Message is required."
                                          placeholder="Ditt Meddelande" rows="3" required></textarea>
                            </div>
                        </div>
                    </div>
                    <div class="row">
                        <div class="col-md-2 col-sm-2 offset2">
                            <input style="font-size: 20px" type="submit" id="sendMail" value="Skicka" class="btn btn-primary" />
                        </div>
                    </div>
                </form>
            </div>
        </div>
    </div>
</div>

控制器:

using DK_Design.Models;
using System.Net.Mail;
using System.Web.Mvc;
namespace DK_Design.Controllers
{
    public class KontaktController : Controller
    {
        public ActionResult Index()
        {
            return View();
        }
        [HttpPost]
        public ActionResult Index(SendMail input)
        {
            var mail = new MailMessage("*****", "*****");
            var client = new SmtpClient("smtp-mail.outlook.com");
            client.Port = 587;
            client.DeliveryMethod = SmtpDeliveryMethod.Network;
            client.UseDefaultCredentials = false;
            var credentials = new System.Net.NetworkCredential("*****", "*****");
            client.EnableSsl = true;
            client.Credentials = credentials;
            mail.Body = input.Name + " " + input.Email + " " + input.Number + " " + input.Message;
            mail.Subject = "Paket 1";
            client.Send(mail);
            ViewData["Message"] = mail;
            return View(mail);
            //Blurring the email information here too ofcourse.
        }
    }
}

当发送电子邮件时,我会弹出成功消息,但不会反过来。

Validating Form in ASP.NET MVC C#

正如一些人所说,由于您使用的是数据注释(视图模型中的[Required]标记),所以好消息是您不必添加太多内容来解决问题。

为了防止它发送空白电子邮件,请将以下内容添加到您的控制器中:

if(!ModelState.IsValid)
{
    throw some kind of error here or do something else and return
}

只有当传入数据不为空时,ModelState才会有效,这将阻止访问代码的其余部分(并发送电子邮件)。这里有一个关于ModelState的教程,值得一读。本教程还讨论了添加自定义验证器,如果您需要在提供的MVC数据注释之外进行验证,您可能会发现它很有用。

我建议验证消息和检查,以便在用户输入信息时为他们提供反馈。这些可以像添加[必需]标签一样添加到您的模型中:

[Required]
[StringLength(8, ErrorMessage = "The input cannot be longer than 8 characters.")]
public string StringyThingie { get; set; }

您也可以在这里添加regex(因为您已经提到过使用它),以及一条验证消息:

[Required]
[RegularExpression(@"^'d{0,4}+.'d{0,8}$", ErrorMessage = "Entry must be in the form of a decimal with no more than eight places to the right of the period.")]
public Decimal DecimalThingie { get; set; }

顺便说一句,如果您想在使用regex之前检查它的有效性,VisualStudio有几个内置工具,您可以通过Nuget获取。

您可以在用户输入的表单组中直接将验证检查/消息添加到您的视图中:

 <div class="form-group">
    @Html.LabelFor(model => model.Field, htmlAttributes: new { @class = "control-label col-md-2"})
        <div class="col-md-10">
            @Html.EditorFor(model => model.Field, new { htmlAttributes = new { @class = "form-control"}}
            @Html.ValidationMessageFor(model => model.Field, "", new { @class = "text-danger"})
        </div>
  </div>

html助手ValidationMessageFor将查看您的模型,获取您列出的要验证的消息,并在用户尝试发布页面时显示该消息。与模型变量上的其他数据注释和ModelState检查一起,它将阻止用户继续前进,直到字段中的内容符合您的检查要求,并在null通过您的检查时阻止控制器方法的其余部分执行。

您还需要将以下内容添加到您的视图中,以提供验证失败的摘要(您应该自定义其中的参数):

@Html.ValidationSummary(true, "", new { @class = "text-danger"})

您不想在方法结束时返回View——您应该使用RedirectToAction方法:

return RedirectToAction("YourMethodHere", "YourControllerHere", "YourRouteDataHere");

RedirectToAction命令明确强制通过视图控制器执行。

数据注释非常灵活,使用它们将导致您编写的代码相对较少,而不是尝试自己对传入数据编写所有这些检查。该文档可以在MSDN文档中找到,并且内置在MVC系统中。

为了更好地控制它在MVC系统内部错误(而不是Html错误)的错误处理过程中所做的操作,您可以覆盖MVC方法OnException,但这会使您的编码过程相当复杂。关于如何以及为什么可以在这里找到一个很好的教程。

然而,在这个问题上,我给你的建议是利用Elmah包,而不是自己写。Elmah可以通过内置的Nuget包管理器使用以下命令获取:

PM> Install-Package Elmah.MVC

安装它将使错误日志记录和管理更加容易,并允许对该过程进行大量定制,而无需自己管理过滤器和路由。

视图模型使用Required数据注释进行装饰。因此,您可以使用内置的模型验证。

[HttpPost]
public ActionResult Index(SendMail input)
{
  if(!ModelState.IsValid)
      return View(input);     
   //Your existing code here which sends email 
}

确保您拥有在视图中显示vlation消息的相关代码。您可以根据需要使用ValidationSummary或/和ValidationFor辅助方法。您也可以使用html辅助方法来呈现输入字段。助手将生成显示验证错误消息所需的标记。

@model SendMail    
@using(Html.BeginForm())
{
      @Html.LabelFor(s=>s.Name)
      @Html.TextBoxFor(s=>s.Name)
      @Html.ValidationMessageFor(t => t.Name)
      @Html.LabelFor(s=>s.Email)
      @Html.TextBoxFor(s=>s.Email)
      @Html.ValidationMessageFor(t => t.Email)
      @Html.LabelFor(s=>s.Number)
      @Html.TextBoxFor(s=>s.Number)
      @Html.ValidationMessageFor(t => t.Number)
      @Html.LabelFor(s=>s.Message)
      @Html.TextAreaFor(s=>s.Message)
      @Html.ValidationMessageFor(t => t.Message)
      <input type="submit" />
 }

此外,我建议您遵循PRG模式(后重定向GET)。因此,您将重定向到另一个GET操作,而不是返回到同一个视图。

return RedirectToAction("EmailSent");

要使用客户端验证(jquery val),您应该考虑使用内置函数

@Html.TextBoxFor(m => m.Name)

以及类似地用于其它性质。

如果用户是空的,这将阻止用户提交表单

然后在服务器端,你想进行

if(!ModelState.IsValid)
      return View(input); 

如果无效,则停止服务器发送电子邮件