JavaWeb-Servlet实现ajax

    xiaoxiao2021-03-25  87

    检查XMLHttpRequest的整体状态并且保证它已经完成(readyStatus==4),即数据已经发送完毕。 然后根据服务器的设定询问请求状态,如果已经就绪(status==200),那么就执行下面的操作。 对于XmlHttpRequest的两个方法:open和send,其中open方法指定了下面这些内容: 1.向服务器提交数据的类型,即是post还是get; 2.请求的url地址和传递的参数; 3.传输方式,false为同步,true为异步。默认为true。 如果是异步通信方式,客户机就不等待服务器的响应;如果是同步方式,客户机就要等到服务器返回消息后才会去执行其他操作。 Send用来发送请求。

    前端请求代码:

    var xmlhttp; function verify() {//这个方法使用XMLHttpRequest对象来进行Ajax异步交互数据 //1.使用dom的方式获取文本框的内容 var userName = document.getElementById("userName").value; //2.创建XMLHTTPRequest对象 if (window.XMLHttpRequest) { xmlhttp = new XMLHttpRequest(); } else if (window.ActiveXObject) { //针对ie6以下版本 var activexName = [ "MSXML2.XMLHTTP", "Microsoft.XMLHTTP" ]; //两个可以用来创建XMLHTTPRequest对象的控件,进行尝试创建 for (var i = 0; i < activexName.length; i++) { try { xmlhttp = new ActiveXObject(activexName[i]); break; } catch (e) { } } } //最后 确认xmlhttprequest对象创建成功 if (!xmlhttp) { alert("请更换更新版本的浏览器"); return; } else { //2.注册回调函数,只需要函数名不需要加括号 xmlhttp.onreadystatechange = callback; //3.设置连接信息 xmlhttp.open("GET", "check.jsp?name=" + userName, true); //4.发送数据,开始和服务器端进行交互 xmlhttp.send(null); } } //回调函数 function callback() { //判断对象交互完成 if (xmlhttp.readyState == 4) { //判断http交互是否成功 if (xmlhttp.status == 200) { //获取服务器的数据 //获取纯文本的数据 var responseText = xmlhttp.responseText; document.getElementById("div1").innerHTML = responseText; } } }

    后端处理数据:

    request.setCharacterEncoding("UTF-8"); response.setContentType("text/html;charset=UTF-8"); String name = request.getParameter("name"); name = new String(name.getBytes("ISO-8859-1"), "UTF-8"); PrintWriter outt = response.getWriter(); if (name.equals("bird")) { outt.println("用户名" + name + "已经存在"); } else { outt.println("用户名不存在,可以使用"); }
    转载请注明原文地址: https://ju.6miu.com/read-6897.html

    最新回复(0)