Ajax手写代码实现-用户验证

首先我们创建一个html页面:Login.html,里面编写相应的js函数

<script type="text/javascript">
        var xmlhttp;
        //根据不同的浏览器,创建xmlHttpRequest对象
        function createXmlHttpRequest() {
            if (window.XMLHttpRequest) {
                xmlhttp = new XMLHttpRequest();
            }
            else {
                xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
            }
        }

        //提交请求
        function doAjax() {
            createXmlHttpRequest(); //创建xmlHttpRequest对象
            //用户名和密码
            var name = document.getElementById("txtName").value;
            var pwd = document.getElementById("txtPwd").value;

            //请求路径
            var url = "Check.aspx?name=" + name + "&pwd=" + pwd + "";
            if (xmlhttp != null) {
                //true表示异步,若设置为false,在Firefox中不会执行
                xmlhttp.open("post", url, true);
                //指定回调函数
                xmlhttp.onreadystatechange = processRequest;
                xmlhttp.send();  //发送请求
            }
        }

        function processRequest() {
            //当请求完成4且服务器响应正常200
            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                if (xmlhttp.responseText == "ok") {
                    alert('XMLHttpRequest对象读取响应结束!');
                    window.location = 'Main.htm';
                }
                else
                    alert('用户名或密码错误,请重新输入!');
            }
        }
    </script>

 

在该页面<input type="button" value="登录" οnclick="doAjax()" />调用;

在aspx页面Check.aspx的Load事件中调用如下方法:

private void CheckUser()
    {
        if (Request.QueryString["name"] != null
            && Request.QueryString["pwd"] != null)
        {
            string name = Request.QueryString["name"];
            string pwd = Request.QueryString["pwd"];
            int rows = UserManager.CheckUser(name, pwd);//调用业务逻辑层的方法验证用户和密码
            if (rows > 0)
            {
                Response.Write("ok");             
            }
            else
            {
                Response.Write("no");
            }
        }
    }

这样就可以实现无刷新验证了。因为时间关系,暂时写到这里,希望能通过这个简单的案例,弄清楚Ajax手写代码的实现思路。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值