原生Ajax基本原理

button的点击事件:
function login() {
//使用ajax往servlet发送数据
//1.获取表单数据
var username = document.getElementById(‘username’).value;
var password = document.getElementById(‘password’).value;

        //2.拼接表单数据
        var params = 'username=' + username + '&password=' + password;
        console.log(params);

        //3.url
        var url = '${pageContext.request.contextPath}/login?' + params;
        console.log(url);

        //4.使用ajax发送get请求
        //4.1创建一个请求对象
        var request = new XMLHttpRequest();

        //4.2调用get请求的方法
        // 调用open方法的时候,都用异步,true
        request.open('get', url, true);
        request.send(); //把?后面的数据传入到后台 send(str)里面也可以传参数
        // 如:send("user=tom");      

        //4.3接收服务器的响应
        request.onreadystatechange = function () {
            console.log('准备状态码-' + request.readyState + ' :响应状态码-' + request.status);
            if (request.readyState == 4 && request.status==200) {
                //接收服务器响应的数据
                var resp =request.responseText;
                console.log(resp);
            }
        };

    }

form表单:

用户名:<input type="text" name="username" id="username"><br>
密码:<input type="password" name="password" id="password"><br>
<input type="button" value="提交" onclick="login()"><br>

服务器处理数据:
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String username = req.getParameter(“username”);
String password = req.getParameter(“password”);

    System.out.println(username + " true " + password);

    if ("hsc".equalsIgnoreCase(username) && "123".equalsIgnoreCase(password)) {
        resp.getWriter().write("success");
    } else {
        resp.getWriter().write("failure");
    }
}

结果:
状态码说明:
request.readyState:
0:请求未初始化
1:服务器连接已建立
2:请求已接收
3:请求处理中
4:请求已完成,且响应已就绪

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值