ASP.NET MVC3中远程验证的问题

postcha 2012-03-07 12:09:39
1:首先有个User模型,

/// <summary>
/// 用户的Email地址
/// </summary>
[Required(ErrorMessage = "Email必填")]
[Display(Name = "Email")]
[DataType(DataType.EmailAddress, ErrorMessage = "你的邮箱格式不对。\n正确的邮箱格式为'85167538@qq.com'")]
[Remote("CheckEmailExists", "Account", ErrorMessage = "此邮箱己存在")]
public string Email { get; set; }



2:验证的代码:

/// <summary>
/// 验证邮箱的唯一性
/// </summary>
/// <param name="email"></param>
/// <returns></returns>
public JsonResult CheckEmailExists(string email)
{
BlogEnt db = new BlogEnt();
var result = from e in db.Users
where e.Email == email.ToLower().Trim()
select e;
return Json(result.ToList().Count == 0, JsonRequestBehavior.AllowGet);
}

,,,,这样,就实现了远程验证,确保数据的唯一性。

因为我的前提是一旦用户注册了这个邮箱,那它以后就一直用这个邮箱不能再修改了。

所以现在碰到一个问题,在就是用户在修改用户资料时,还是会验证这个Email,报错”此邮箱己存在“。


修改用户资料的Controller:

public ActionResult EditUserInfo(int id)
{
User user = db.Users.Find(id);
if (user == null ||Convert.ToInt32(Session["userid"])!=id)
{
return RedirectToAction("Index");
}
else
{
ViewBag.skinid = db.Skins.OrderBy(a => a.SkinID).ToList();
return View(user);
}
}

[HttpPost]
public ActionResult EditUserInfo(User user )
{
try
{
var u = db.Users.Find(user.UserID);
UpdateModel(u);
db.SaveChanges();
return RedirectToAction("Index");
}
catch
{
ModelState.AddModelError("", "修改失败,请查看详细错误信息。");
}
return View(user);
}


前台View是用的强类型。

所以在修改用户资料这个action要怎么跳过这个验证方法?
...全文
543 点赞 收藏 14
写回复
14 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
yz247 2013-06-27
个人认为修改下验证方法: CheckEmailExists(string email,int id) where e.Email == email.ToLower().Trim() and e.id!=id
回复
yz247 2013-06-27
个人认为修改下验证方法: where e.Email == email.ToLower().Trim() and e.id!=email.id
回复
xiaot8823 2013-01-07
高手,我也有类似问题,你解决了吗?
回复
stszd604 2012-07-17
修改的时候 应该是反向验证 不存在的话 不能修改 呵呵
回复
上财商学院 2012-04-15
ModelState.Romove("email");
回复
postcha 2012-03-20
有没有人解答一下啊
回复
postcha 2012-03-08
请高手帮忙解决一下
回复
postcha 2012-03-08
model中,这些要的,因为在注册时要使用的。
回复
MSDNXGH 2012-03-08
不要那些附加属性就行了
回复
postcha 2012-03-07
不显示也没有用啊。不显示的话直接报catch中的错误了。

如果显示或藏的话是报“此邮箱己存在”

回复
骑猪看海 2012-03-07
不能修改那EDIT时就不显示这个字段
回复
postcha 2012-03-07
[Quote=引用 3 楼 ldc121xy716 的回复:]

给个标志处理吧
public JsonResult CheckEmailExists(string email ,int state) //state=1为增加 2为修改
{
if(state==1){
BlogEnt db = new BlogEnt();
var result = from e ……
[/Quote]

能帮忙写完整一点么?新手,有难度啊。
回复
chen_ya_ping 2012-03-07
要不然还是手写验证吧。不需要用这样子的验证了。
回复
大雷神 2012-03-07
给个标志处理吧
public JsonResult CheckEmailExists(string email ,int state) //state=1为增加 2为修改
{
if(state==1){
BlogEnt db = new BlogEnt();
var result = from e in db.Users
where e.Email == email.ToLower().Trim()
select e;

return Json(result.ToList().Count == 0, JsonRequestBehavior.AllowGet);
}
}
回复
相关推荐
发帖
.NET技术社区
创建于2007-09-28

5.8w+

社区成员

.NET技术交流专区
申请成为版主
帖子事件
创建了帖子
2012-03-07 12:09
社区公告
暂无公告