在MVC3里面——程序集 System.Web.Mvc.dll, v4.0.30319有这么一个Ajax.BeginForm异步登录验证的类型,我们在下面给出一个例子:
在登录页面Logion.cshtml。使用@using (Ajax.BeginForm("Login", "Home", new AjaxOptions { HttpMethod = "Post", OnSuccess = "tips", OnBegin = "return ValidateLog()" })){提交Form内容},HttpMethod="提交方式",OnBegin="return validateLog()"是开始提交前,对Form表单的js验证。我们直接在javascript里面写validateLog()的js验证函数就可以了。OnSuccess = "tips"是Form表单成功提交到这个控制器后,然后再根据页面上的javascript函数tips(data)和它的返回值data,判断控制器里面回传过来的JsonResult值,是"true"还是"flase"。

[HttpPost]

public JsonResult Login(FormCollection collection){

string userName = collection["UserName"];

string passWord = collection["passWord"];

//经过数据库判断用户是否存在

//该用户有何权限

//用户和权限保存Session等等处理

JsonResult  json = new JsonResult();

json.Data = new Json{result="true"};  //给JsonResult对象赋值,登录结果是否通过

return json  //返回json值

}

1、用户登录页面Logion.cshtml

@{
    ViewBag.Title = "登录";
    Layout = null;
}
<!DOCTYPE html>
<html>
<head>
    <link href="/Style/index.css" rel="stylesheet" type="text/css" />
    <title>登录</title>
    <script src="/Scripts/jquery-1.5.1.min.js" type="text/javascript"></script>
    <script src="/Scripts/PleatedEffects.js" type="text/javascript"></script>
    <script src="/Scripts/RenzoManage.js" type="text/javascript"></script>
    <script src="/Scripts/MicrosoftAjax.js" type="text/javascript"></script>
    <script src="/Scripts/MicrosoftMvcAjax.js" type="text/javascript"></script>
    <script src="/Scripts/jquery.unobtrusive-ajax.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        //登录验证
        function ValidateLog() {
            if (document.getElementById('userName').value == "" || document.getElementById('userName').value.length == 0) {
                alert('用户名不能为空');
                document.getElementById('userName').focus();
                return false;
            }
            if (document.getElementById('passWord').vaule == "" || document.getElementById('passWord').value.length == 0) {
                alert('密码不能为空');
                document.getElementById('passWord').focus();
                return false;
            }
        }

//登录回调函数
        function tips(data) {
            try {
                if (data.result == "false") {
                    alert("用户名和密码错误");
                }
                else {
                    location.href = '/Home/Index';
                }
            } catch (e) {
                alert('异常错误');
            }
        }
    </script>
</head>
<body>
    <div id="top">
        <div class="topbg">
            <div class="main_logo_wrap">
                <a href="#" class="logo" target="_blank" title="易乐国际">易乐国际</a></div>
            <div class="nav">
                <div class="floatright">
                    <a href="#" class="font01 marginright45 btn_time_a">@(DateTime.Now.GetDateTimeFormats('D')[1].ToString())</a>
                </div>
            </div>
        </div>
    </div>
    <div id="content" class="c">
        <div class="rightcontents">
            <div class="righttopbg right_wrap">
                <div class="righttopword">
                    您所在的位置: <a href="#">用户登录</a>
                </div>
            </div>
            <div class="righttable">
                @using (Ajax.BeginForm("Login", "Home", new AjaxOptions { HttpMethod = "Post", OnSuccess = "tips", OnBegin = "return ValidateLog()" }))             
                {
                    <table border="0" cellpadding="0" cellspacing="0" class="chaxunbiaoge search_wh">
                        <tr>
                            <td height="55px" width="80px" align="right">
                                用户名:
                            </td>
                            <td width="175px">
                                <input type="text" name="userName" id="userName" class=" biaogechaxunkuang"  tabindex="1"/>
                            </td>
                            <td>
                                <span class="colore6080d marginleft10">*</span> <span class="spanUserName"></span>
                            </td>
                        </tr>
                        <tr>
                            <td height="55px" align="right">
                                密码:
                            </td>
                            <td>
                                <input type="password" name="passWord" id="passWord" class=" biaogechaxunkuang" tabindex="2"/>
                            </td>
                            <td>
                                <span class="colore6080d marginleft10">*</span><span class="spanPassWord"></span>
                            </td>
                        </tr>
                        <tr>
                            <td height="55px" align="right">
                                &nbsp;
                            </td>
                            <td>
                                <input name="btnlogin" type="submit" class="marginleft10 btn_dl" value="登录" tabindex="3" style="margin-top: 14px;" />&nbsp;
                            </td>
                            <td>
                                &nbsp;
                            </td>
                        </tr>
                    </table>
                }
            </div>
        </div>
    </div>
    <div class=" clearfloat">
    </div>
    <div id="bottom">
        <div class="bottomwenzi">
            <span class="floatright">后台管理系统</span></div>
    </div>
</body>
</html>

2、用户登录控制器

///<summary>
         ///用户登陆
         ///</summary>
         ///<param name="collection"></param>
         ///<returns></returns>
        [HttpPost]
        public JsonResult Login(FormCollection collection)
        {
            string userName = collection["userName"];
            string passWord = collection["passWord"];
            JsonResult json = new JsonResult();
            try
            {
                Users user = UserManage.GetUser(userName, passWord);
                if (user != null)
                {
                    Session["LoginUser"] = user;
                    Roles role = AuthorityManage.GetRoleById(Convert.ToInt32(user.RoleID));
                    Session["AllowAuthority"] = role.AllowAuthority;
                    //Session["AllowMenu"] = role.AllowMenu;  //2013116
                    Session["RolesInfo"] = role;
                    int i = LogRecordsManage.Insert(new LogRecords() { LogMessage = role.Name + user.Username + "于" + DateTime.Now.ToString() + "登录", OperateID = user.ID, OperateTime = DateTime.Now, OperateType = 8 });
                    //json.Data = new { result = "true" };
                    json.Data = new { result = "false" };
                }
                else
                {
                    json.Data = new { result = "false" };
                }
            }
            catch (Exception ex)
            {
                Logs.AppLogs log = new Logs.AppLogs("Casino", "Login", userName, 2, ex.Message);
                log.Insert();
                CasinoWeb.Helper.LogMessage.SaveError(ex);
            }
            return json;
        }

Ajax.BeginForm返回方法OnSuccess的更多相关文章

  1. ajax的使用:(ajaxReturn[ajax的返回方法]),(eval返回字符串);分页;第三方类(page.class.php)如何载入;自动加载函数库(functions);session如何防止跳过登录访问(构造函数说明)

    一.ajax例子:ajaxReturn("ok","eval")->thinkphp中ajax的返回值的方法,返回参数为ok,返回类型为eval(字符串) ...

  2. Ajax.BeginForm 不执行OnSuccess

    今天用MVC做了一个表单提交,使用Ajax.BeginForm ,但是碰到一个奇怪的问题OnSuccess回调函数不执行.后来经过多次尝试才发现要引用两个东西 1.<script src=&qu ...

  3. MVC4中Ajax.BeginForm OnSuccess 不执行以及控制器返回JsonResult 提示下载的原因

    这几天学习MVC的过程中,在学习Ajax.BeginForm时,一直遇到2个问题: 一. Ajax.BeginForm OnSuccess事件不执行 二.提交表单后,浏览器不识别json字符串,提示下 ...

  4. Ajax.BeginForm方法 参数

    感谢博主 http://www.cnblogs.com/zzgblog/p/5454019.html toyoung 在Asp.Net的MVC中的语法,在Razor页面中使用,替代JQuery的Aja ...

  5. MVC验证09-使用MVC的Ajax.BeginForm方法实现异步验证

    原文:MVC验证09-使用MVC的Ajax.BeginForm方法实现异步验证 MVC中,关于往后台提交的方法有: 1.Html.BeginForm():同步 2.Ajax.BeginForm():异 ...

  6. Ajax.BeginForm提示不支持live属性或方法的错误

    解决: 在nuget下载最新版本的jquery.unobtrusive-ajax.min.js文件 Ajax异步请求: 引用JS: <script type="text/javascr ...

  7. 取代Ajax.BeginForm的ajax使用方法

    原文:取代Ajax.BeginForm的ajax使用方法 一.前提概要 Asp.net core中已经取消了Ajax.BeginForm,也不会计划出ajax tag helper,所以得利用插件jq ...

  8. 在使用Ajax请求返回json数据的时候IE浏览器弹出下载保存对话框的解决方法

    在使用Ajax请求返回json数据的时候IE浏览器弹出下载保存对话框的解决方法 最近在做一个小东西,使用kindeditor上传图片的时候,自己写了一个上传的方法,按照协议规则通过ajax返回json ...

  9. MVC Ajax.BeginForm重复提交解决方法

    mvc使用MVC Ajax.BeginForm提交的时候有重复提交结果的时候检查相关js文件引用情况, 其中mvc4注意 1 2 3 4 @Scripts.Render("~/bundles ...

随机推荐

  1. .NET学习笔记(2) — IIS服务器环境搭建

    目录 一:开启Windows系统自带的IIS服务器方法 二:备注 三:常见问题     一:开启Windows系统自带的IIS服务器方法   第一步:安装IIS,控制面板->程序和功能-> ...

  2. http协议与内容压缩

    为了加快网络上的传输的速度,可以将服务器传输的内容进行压缩,服务器的压缩方式有gzip压缩 deflate压缩 compress压缩 content-length:压缩后的长度 如何启动压缩功能 1, ...

  3. asp.net 下OnClientClick的妙用

    一. OnClick是button的服务器端事件 OnClientClick是button的客户端事件 onlick时发生postback,执行后台代码.onclientclick,就是执行javas ...

  4. TCP/IP 学习博客

    原作者地址:http://blog.csdn.net/goodboy1881/article/category/204448

  5. ###Git使用问题

    #@date: 2014-05-04 #@author: gerui #@email: forgerui@gmail.com 一.git reset的使用 今天修改了代码,就git add ./,添加 ...

  6. 隐藏NavigationBar 带来的坑

    一.场景介绍 现在大多数APP 都有一个需求,就是隐藏某一个页面的NavigationBar.很多开发者直接   [self.navigationController setNavigationBar ...

  7. OC中 block 的用法

    block 常用于反向传值 声明 返回值类型 (^block)(参数列表) 调用 闭包的名字=^(参数列表){}: 闭包的名字(): 如: void(^aaaaa)(int num,NSString ...

  8. 让C# Excel导入导出,支持不同版本的Office

    问题:最近在项目中遇到,不同客户机安装不同Office版本,在导出Excel时,发生错误. 找不到Excel Com组件,错误信息如下. 未能加载文件或程序集“Microsoft.Office.Int ...

  9. Java实战之04JavaWeb-05事务和连接池

    一.事务部分 1.事务的简介 做一件事情,这个一件事情中有多个组成单元,这个多个组成单元要不同时成功,要不同时失败.A账户转给B账户钱,将A账户转出钱的操作与B账户转入钱的操作绑定到一个事务中,要不这 ...

  10. [GeekBand] C++学习笔记(1)——以复数类为例

    本篇笔记以复数类(不含指针的类)为例进行面向对象的学习 ========================================================= 复数类的声明: class ...