ASP.NET MVC实践系列3-服务器端数据验证

简介:

我们这里主要讲解ASP.NET MVC中服务器端得数据验证,至于客户端验证我们会在以后的系列中讲到。

在Controller中有一个ModelState属性,这是一个类型为ModelStateDictionary的ModelState类型的字典集合。在进行数据验证的时候这个属性是比较有用的。在使用Html.ValidationMessage()的时候,就是从ModelState中检测是否有指定的KEY,如果存在,就提示错误信息。

1、基本实例

在View中添加如下文件

复制代码
Code
<%= Html.ValidationSummary("Edit was unsuccessful. Please correct the errors and try again."%>

    
<% using (Html.BeginForm()) {%>

        
<fieldset>
            
<legend>Fields</legend>
            
<p>
                
<label for="id">id:</label>
                
<%= Html.TextBox("id", Model.id) %>
                
<%= Html.ValidationMessage("id""*"%>
            
</p>
            
<p>
                
<label for="Title">Title:</label>
                
<%= Html.TextBox("Title", Model.Title) %>
                
<%= Html.ValidationMessage("Title""*"%>
            
</p>
             
<p>
                
<input type="submit" value="Save" />
            
</p>
        
</fieldset>

    
<% } %>
复制代码

在相应的Controller中添加如下代码

复制代码
Code
public ActionResult NewsEdit(int id)
        {
            NewsDataDataContext dc 
= new NewsDataDataContext();
            
return View(dc.News.First(n => n.id == id));
        }
        [AcceptVerbs(HttpVerbs.Post)]
        
public ActionResult NewsEdit(int id, FormCollection formValues)
        {
            News news 
= new News();
            UpdateModel(news);
            
if (String.IsNullOrEmpty(news.Title))
            {
                ModelState.AddModelError(
"Title""Title不能为空");
            }
            
else
            {
                
//进行更新
            }
            
return View(news);
        }
复制代码

View中使用Html.ValidationMessage(string modelName)来对指定的属性进行验证:这里仍然使用的是mvc中默认的约定,modelName的内容如果和ModelState中的key值一样是就显示。

其中ValidationSummary()是用于显示全部的验证信息的。跟ASP.NET里面的ValidationSummary验证控件差不多。

运行程序得到的结果为:

Html.ValidationMessage()方法会为出错的属性的输入框添加一个名为"input-validation-error"的CSS类,同时后面的提示信息的CSS类名为"field-validation-error":

Code
 <input class="input-validation-error" id="Title" name="Title" type="text" value="" />
                
<span class="field-validation-error">*</span>

CSS类的样式是可以由我们自己自由定义的

2、应用

这里我们为之前的News实例添加服务器端验证,首先我们需要一个传递错误信息的类

复制代码
Code
 public class RuleViolation
    {
        
public string ErrorMessage { getprivate set; }
        
public string PropertyName { getprivate set; }
        
public RuleViolation(string errorMessage)
        {
            ErrorMessage 
= errorMessage;
        }
        
public RuleViolation(string errorMessage, string propertyName)
        {
            ErrorMessage 
= errorMessage;
            PropertyName 
= propertyName;
        }
    }
复制代码

然后为dbml中的News类添加一个partial类,来用于验证属性

复制代码
Code
public partial class News
    {
        
public bool IsValid
        {
            
get { return (GetRuleViolations().Count() == 0); }
        }

        
partial void OnValidate(ChangeAction action)
        {
            
if (!IsValid)
                
throw new ApplicationException("Rule violations prevent saving");
        }
        
public IEnumerable<RuleViolation> GetRuleViolations()
        {
            
if (String.IsNullOrEmpty(Title))
                
yield return new RuleViolation("必须要输入标题""Title");
            
if (String.IsNullOrEmpty(Author))
                
yield return new RuleViolation("必须要输入作者""Author");

            
yield break;
        }
    }
复制代码

Controller中填入如下代码

复制代码
Code
[AcceptVerbs(HttpVerbs.Post)]
        
public ActionResult NewsEdit(int id, FormCollection formValues)
        {
            NewsDataDataContext dc 
= new NewsDataDataContext();
            News news 
= dc.News.First(n => n.id == id);
            
try
            {
                UpdateModel(news);
                dc.SubmitChanges();
                
return RedirectToAction("Details"new { id = id });
            }
            
catch (Exception)
            {
                
foreach (var issue in news.GetRuleViolations())
                {
                    ModelState.AddModelError(issue.PropertyName, issue.ErrorMessage);
                }
                
return View(news);
            }
        }
复制代码

注:当对DataDataContext执行SubmitChanges方法时会触发OnValidate分布方法。

3、源码

4、参考:

http://www.cnblogs.com/QLeelulu/archive/2008/10/08/1305962.html

《Professional ASP.NET MVC 1.0》

本文转自 你听海是不是在笑 博客园博客,原文链接:http://www.cnblogs.com/nuaalfm/archive/2009/10/27/1590532.html   ,如需转载请自行联系原作者

目录
打赏
0
0
0
0
95
分享
相关文章
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
115 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
98 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
Quartz.Net整合NetCore3.1,部署到IIS服务器上后台定时Job不被调度的解决方案
解决Quartz.NET在.NET Core 3.1应用中部署到IIS服务器上不被调度的问题,通常需要综合考虑应用配置、IIS设置、日志分析等多个方面。采用上述策略,结合细致的测试和监控,可以有效地提高定时任务的稳定性和可靠性。在实施任何更改后,务必进行充分的测试,以验证问题是否得到解决,并监控生产环境的表现,确保长期稳定性。
332 1
一个.NET开源、快速、低延迟的异步套接字服务器和客户端库
一个.NET开源、快速、低延迟的异步套接字服务器和客户端库
152 4
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
122 7
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
147 0
下一篇
oss创建bucket