原生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:请求已完成,且响应已就绪

这里写图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章