濮阳杆衣贸易有限公司

主頁 > 知識庫 > ASP.NET MVC5驗證系列之服務(wù)端驗證

ASP.NET MVC5驗證系列之服務(wù)端驗證

熱門標(biāo)簽:電話機(jī)器人鑰匙扣 電銷外呼系統(tǒng)是違法的嗎 旅游地圖標(biāo)注線路 廣西房產(chǎn)智能外呼系統(tǒng)推薦 400電話唐山辦理 地圖標(biāo)注位置怎么弄圖 威力最大的電銷機(jī)器人 漯河外呼調(diào)研線路 電銷專用外呼線路

 這篇文章,我將會說到,使用數(shù)據(jù)注解API來進(jìn)行服務(wù)端驗證。ASP.NET MVC 框架在執(zhí)行的時候,驗證所有傳遞到控制器的數(shù)據(jù),如果驗證失敗就把錯誤消息,填充到ModelState對象中,并且把這個對象傳遞給控制器,然后控制器中的方法,根據(jù)Modelstate的狀態(tài)來判斷,是否驗證失敗還是驗證通過。

在這里,我將會使用兩種方法來驗證數(shù)據(jù)的合法性,一個是手動添加錯誤消息到ModelState對象中,另外一個方法是使用數(shù)據(jù)注解【Data Annotation】 API,來做。

先來看看使用手動驗證的方式吧: 

我們新建一個空白的MVC項目:添加一個Student實體: 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace Server_Side_Validation_IN_MVC.Models
{
 public class Student
 {
  public string Name { get; set; }

  public string Email { get; set; }

 }
}

然后添加一個Student控制器: 

using Server_Side_Validation_IN_MVC.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
using System.Web;
using System.Web.Mvc;

namespace Server_Side_Validation_IN_MVC.Controllers
{
 public class StudentController : Controller
 {
  // GET: Student
  public ActionResult Index()
  {
   return View();
  }

  [HttpPost]
  public ActionResult Index(Student model)
  {

   //服務(wù)端驗證,方法一,手動添加錯誤消息到ModelState對象中
   
   //如果Name是空的
   if (string.IsNullOrEmpty(model.Name))
   {
    ModelState.AddModelError("Name", "Name is required");
   }

   //如果Email是空的
   if (string.IsNullOrEmpty(model.Email))
   {
    ModelState.AddModelError("Email", "Email is required");
   }
   else
   {
    string emailRegex = @"^([a-zA-Z0-9_\-\.]+)@((\[[0-9]{1,3}" +
           @"\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([a-zA-Z0-9\-]+\" +
            @".)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$";
    Regex re = new Regex(emailRegex);
    //Email不為空的時候,但格式不合法
    if (!re.IsMatch(model.Email))
    {
     ModelState.AddModelError("Email", "Email is not valid");
    }
   }
   //實體驗證通過
   if (ModelState.IsValid)
   {
    ViewBag.Name = model.Name;
    ViewBag.Email = model.Email;
   }
   return View(model);
  }
 }
}

創(chuàng)建Index視圖: 

@model Server_Side_Validation_IN_MVC.Models.Student
@{
 Layout = null;
}

!DOCTYPE html>

html>
head>
 meta name="viewport" content="width=device-width" />
 title>Index/title>
/head>
body>
 div> 
  @using (Html.BeginForm())
  { 
  //使用ViewData.ModelState.IsValid來判斷ModelState的狀態(tài)
   if (ViewData.ModelState.IsValid)
   {
    if (ViewBag.Name != null)
    { 
    b>
     Name:@ViewBag.Namebr/>
     Email:@ViewBag.Email
    /b>
    }
   }
   
   fieldset>
    legend>Student/legend>
    div>
     @*生成label標(biāo)簽*@
     @Html.LabelFor(model=>model.Name)
    /div>
    div>
     @*生成文本框*@
     @Html.EditorFor(model=>model.Name)
     @*不合法*@
     //// @if (!ViewData.ModelState.IsValid)//這樣寫有問題正確的寫法: @if (!ViewData.ModelState.IsValid ViewData.ModelState["Email"].Errors.Count>0)
     { 
    //從字典中獲取錯誤消息:@ViewData.ModelState["Name"].Errors[0].ErrorMessage
     span style="color:red">@ViewData.ModelState["Name"].Errors[0].ErrorMessage/span>
     }

    /div>
    div>
     @Html.LabelFor(model=>model.Email)
    /div>
    div>
     @Html.EditorFor(model=>model.Email)
     /////@if (!ViewData.ModelState.IsValid) 這樣寫有問題:      // 正確的寫法在下面     @if (!ViewData.ModelState.IsValid ViewData.ModelState["Email"].Errors.Count>0)
     {
      //從字典中獲取錯誤消息:@ViewData.ModelState["Email"].Errors[0].ErrorMessage
      span style="color:red">@ViewData.ModelState["Email"].Errors[0].ErrorMessage/span>
     }
    /div>
    p>
     input type="submit" value="Create"/>
    /p>
   /fieldset>
   
  }
 /div>
/body>
/html>



然后,修改一下默認(rèn)的路由: 

public static void RegisterRoutes(RouteCollection routes)
  {
   routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

   routes.MapRoute(
    name: "Default",
    url: "{controller}/{action}/{id}",
    defaults: new { controller = "Student", action = "Index", id = UrlParameter.Optional }
   );
  }

運行之后,報錯。查找了一下原因,修改了一下視圖代碼:

運行之后,

接著驗證一下,Name不為空,Email輸入非法格式的數(shù)據(jù):

最后驗證一下,輸入合法的數(shù)據(jù):

 好了,現(xiàn)在看看第二種方式,使用數(shù)據(jù)注解來進(jìn)行服務(wù)端驗證:
 新建一個類:避免混淆, 

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Web;

namespace Server_Side_Validation_IN_MVC.Models
{
 public class StudentServer
 {
  [Required(ErrorMessage="Name為必填項")]
  public string Name { get; set; }

  [Required(ErrorMessage="電子郵件必須")]
  [EmailAddress(ErrorMessage="電子郵件格式不對")]
  public string Email { get; set; }
 }
}

在控制器中新建兩個方法: 

 public ActionResult SeverSideIndex()
  {
   return View();
  }

  [HttpPost]
  public ActionResult SeverSideIndex(StudentServer model)
  {
   if (ModelState.IsValid)
   {
    ViewBag.Name = model.Name;
    ViewBag.Email = model.Email;
   }
   return View();

  }

對應(yīng)的視圖: 

@model Server_Side_Validation_IN_MVC.Models.StudentServer
@{
 Layout = null;
}
@if (ViewData.ModelState.IsValid)
{
 if (ViewBag.Name != null)
 { 
 b>
  Name:@ViewBag.Namebr />
  Email:@ViewBag.Email
 /b>
 }
}

!DOCTYPE html>

html>
head>
 meta name="viewport" content="width=device-width" />
 title>SeverSideIndex/title>
/head>
body>
 div> 
  @using (Html.BeginForm())
  { 
  @Html.ValidationSummary(true)
   fieldset>
    legend>Student/legend>
    div>
     @Html.LabelFor(model=>model.Name)
    /div>
    div>
     @Html.EditorFor(model=>model.Name)
     @Html.ValidationMessageFor(model=>model.Name)
    /div>
    div>
     @Html.LabelFor(model => model.Email)
    /div>
    div>
     @Html.EditorFor(model => model.Email)
     @Html.ValidationMessageFor(model => model.Email)
    /div>
    p>
     input type="submit" value="Create"/>
    /p>
   /fieldset>
   
  }
 /div>
/body>
/html>


首先驗證,都為空的情況:

Name不為空,Email為空

Name不為空,Email輸入非法格式數(shù)據(jù)

兩個都輸入合法的數(shù)據(jù):

好了,以上就是MVC中服務(wù)端驗證了,我們一般是使用第二種,來進(jìn)行驗證。也就是數(shù)據(jù)注解。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • ASP.NET MVC5添加驗證(4)
  • ASP.NET MVC5驗證系列之Remote Validation
  • ASP.NET MVC 數(shù)據(jù)驗證及相關(guān)內(nèi)容
  • ASP.NET MVC5驗證系列之客戶端驗證
  • ASP.NET全棧開發(fā)教程之在MVC中使用服務(wù)端驗證的方法

標(biāo)簽:無錫 綏化 湖北 銅陵 焦作 試駕邀約 湘西 欽州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET MVC5驗證系列之服務(wù)端驗證》,本文關(guān)鍵詞  ASP.NET,MVC5,驗證,系列,之,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET MVC5驗證系列之服務(wù)端驗證》相關(guān)的同類信息!
  • 本頁收集關(guān)于ASP.NET MVC5驗證系列之服務(wù)端驗證的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    田东县| 临汾市| 库尔勒市| 临漳县| 长阳| 合作市| 崇阳县| 日照市| 梓潼县| 巴里| 西和县| 东城区| 广饶县| 福海县| 湟中县| 六枝特区| 呈贡县| 定南县| 小金县| 辽中县| 修文县| 泰宁县| 辉县市| 横峰县| 博湖县| 博兴县| 喀喇| 哈尔滨市| 云梦县| 迁西县| 会同县| 汨罗市| 乌鲁木齐县| 崇仁县| 新源县| 临汾市| 沁源县| 永州市| 昔阳县| 奈曼旗| 越西县|