Asp.net MVC2学习笔记8-数据验证(前后台统一验证)

2024-02-29 02:58

本文主要是介绍Asp.net MVC2学习笔记8-数据验证(前后台统一验证),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

验证用户的输入在web系统中是肯定要经常用到的,比如说输入不能为空或者输入的字符要在一定的范围内等等。。
 
大多数时候我们使用前台的 Javascript 来验证用户的输入,前面有篇文章已经给大家介绍了前台 javascript验证是不可靠的,所以大部分人在后台insert或者update的之前做了验证,这是比较好的,但是 Asp.net MVC 给我们提供了很多数据验证方法,今天就来介绍一个Model数据验证的方法,使用的命名空间是:System.ComponentModel.DataAnnotations,这个空间给我们提供了很多关于数据验证的方法。。。。。
 
本文的主题是:Asp.net MVC Model数据验证这里给大家推荐一篇文章,这里讲的比较详细,大家看着他的文章相信就能很快明白了: 点击查看
由于这篇文章是英文的,所以我把大概意思给大家描述一下:
 
首先文章的开头教大家如何自己手工写一个Model,并设置验证规则:新建一个 Person类
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
 
在Person 这个Model 中 加入验证规则:Required、Stringlength、Range、RegularExpression等常用的规则,具体含义大家应该都明白
 
Required:必须输入,不能为空
StringLength:字符串的长度不能大于设置的长度
Range:数字的可输入范围
RegularExpression:正则表达式匹配
 
 
 
Model建好了以后,下面就是建Controller和View,这里就举了一个Create 的例子,并添加了一个强类型的View
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
 
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
 
到此为止这就在 服务器端验证了我们设置的规则,下面是客户端 javascript 的验证,也是比较简单的,加上2个js引用一行代码就可以了:
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
 
 
此时客户端验证和服务器端验证都已经生效了,大家运行试验一下就可以看到效果。。。
 
接下来是保存到数据库中,这里我们使用了ASP.NET EF来创建Model,我们可以根据上面写Person规则的方式在已经生成好的Model代码中添加规则,
但是EF产生的.cs文件在修改.edmx 文件后再保存的时候就会被重新创建,所以我们之前绑定的规则会全部消失,所以我们采用连接的方式来把验证规则写在另外一个类中,
通过 MetadataType 来连接。。。。
 
步骤1、将我们之前创建的Person类修改名称为Person_Validation 
步骤2、在EF生产的 cs文件中Person类前加上 MetadataType连接
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
步骤3、修改Controller中的Create方法将验证通过的数据保存进数据库
Asp.net MVC2学习笔记8-数据验证(前后台统一验证) - 郁郁 - 郁郁的博客
 
此时已经全部完成数据验证功能。。。。
 
 
 
下面简单的说一下自定义验证:
ASP.NET MVC2 自定义数据验证我们可以通过继承 ValidationAttribute这个基类来实现我们自己的验证规则,也可以继承现有的规则如:StringLength,RegularExpression等。。
 
我们使用Stringlength的时候,可能我们不仅需要验证字符串最大长度而且需要验证最小长度,这时我们可以来自己实现一个验证最小长度的规则,实现方式也很简单,代码如下:
 
 
public class StringMinLength:ValidationAttribute
    {
        private int _minLength = 0;
        public StringMinLength(int minLength)
        { 
            _minLength = minLength;
        }

        public override bool IsValid(object value)
        {
            if (value.ToString().Length < _minLength)
            {
                return false;
            }

            return true;
        }
    }
 
 
使用的时候就可以和其他一样,给字段加上这个属性就可以了
 
 [StringMinLength(5,ErrorMessage="最小5个字符!!")]
        public string FirstName
        {
            get;
            set;
        }
 
 
 
 

这篇关于Asp.net MVC2学习笔记8-数据验证(前后台统一验证)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757376

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数