一、概念

1、传统网站存在问题

传统的页面交互是Servlet 调用业务逻辑层后将数据存储到域对象中,然后跳转指定jsp 页面,在页面使用 EL表达式 和JSTL 标签库进行数据展示。该模式存在以下问题

2、Ajax介绍
3、同步与异步
4、应用场景

二、Ajax使用

1、 XMLHttpRequest 对象
(1)介绍

所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象
XMLHttpRequest 用于后台服务器交换数据。它可以在不向服务提交整个页面的情况下,实现局部更新网页
XMLHttpRequest的对象用于客户端服务之间的异步通信
执行以下操作:

(2)创建 XMLHttpRequest 对象语法
var http=new XMLHttpRequest();
(3)XMLHttpRequest对象属性

XMLHttpRequest对象常见属性如下

属性 描述
onreadystatechange 存储函数(或函数名),每当readyState的属性改变时,就会调用函数
readyState 存有的XMLHttpRequest的状态从0到4发生变化。
0:请求初始化
1:服务器连接已建立
2:请求接收
3:请求处理
4:请求已完成,且响应已就绪
responseText 文本形式返回响应。
responseXML 以XML格式返回响应
status 将状态返回数字例如,“Not Found”为404,“OK”为200)
statusText 字符串形式返回状态(例如,“Not Found”或“OK”)
(4)XMLHttpRequest对象方法

XMLHttpRequest对象的重要方法如下

方法 描述
abort() 取消当前请求。
getAllResponseHeaders() 字符串形式返回完整的HTTP标头集。
getResponseHeader( headerName ) 返回指定HTTP标头的值。
void openmethod,URL) 打开指定获取或交的方法和URL的请求。
void openmethod,URL,async 与上面相同,但指定异步或不。
void openmethod,URL,asyncuserName,password 与上面相同,但指定用户名密码
void sendcontent 发送获取请求。
setRequestHeader( labelvalue 标签/值对添加到要发送的HTTP标头。
2、 AJAX XHR-请求
(1) AJAX 的工作原理

AJAX 使用的 XMLHttpRequest 的对象与服务器通信, AJAX 的工作原理如图
 在这里插入图片描述
ajax请求流程如下

  • 用户从 UI 发送请求,JavaScript 中调用 XMLHttpRequest 对象。
  • HTTP 请求由 XMLHttpRequest 对象发送到服务器。
  • 服务器使用 JSP,PHP,Servlet,ASP.net 等与数据库交互
  • 检索数据。
  • 服务器将 XML 数据或 JSON 数据发送到 XMLHttpRequest 回调函数
  • HTML 和 CSS 数据显示在浏览器上。
(2) 向服务器发送请求

当你的页面全部加载完毕后,客户端通过 XMLHttpRequest 对象向服务器请求数据,服务器端接受数据并处理后,向客户端反馈数据。如需将请求发送到服务器,我们使用 XMLHttpRequest 对象的open()和send()方法

 //创建Ajax对象
var http=new XMLHttpRequest();
//设置Ajax的请求地址与请求方式
 http.open("get","http://localhost:8080/GetUserInfoServlet");
//发送请求
http.send();
3、 AJAX XHR-响应

由于 HTTP 响应是由服务端发出的,并且服务器做出响应需要时间比如网速慢等原因),所以需要监听服务器响应的状态,然后才能进行处理

属性 描述
responseText 获得字符串形式的响应数据。
responseXML 获得 XML 形式的响应数据。
4、 AJAX – onreadystatechange 事件

当发送一个请求后,客户端需要确定这个请求什么时候会完成,因此,XMLHttpRequest对象提供了onreadystatechange事件机制捕获请求的状态,继而实现响应。
当请求被发送到服务器时,执行一些基于响应的任务,每当readyState改变时,就会触发onreadystatechange事件readyState属性存有 XMLHttpRequest 的状态信息

属性 描述
onreadystatechange 存储函数(或函数名),每当readyState属性改变时,就会调用该函数。
readyState

存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

  • 0: 请求未初始化,还没有调用 open()

  • 1: 请求已经建立,但是还没有发送,还没有调用 send()

  • 2: 请求已发送,正在处理中(通常现在可以从响应中获取内容头)

  • 3: 请求在处理中;通常响应中已有部分数据可用了,没有全部完成

  • 4: 响应已完成;可以获取并使用服务器的响应了

status 200: “OK”
404: 未找到页面

回调函数事件

		http.onreadystatechange=function () {
        //readyState 0=>初始化 1=>载入 2=>载入完成 3=>解析 4=>完成
        if(this.readyState==4&&this.status==200){
          var responseText=this.responseText
          console.log('返回结果:'+responseText)
        }
      }

三、Ajax实例

1、Ajax之get请求

(1)GetUserInfoServlet接口

@WebServlet("/GetUserInfoServlet")
public class GetUserInfoServlet extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doGet(req,resp);
    }

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.setContentType("text/html;charset=utf-8");

        String username=req.getParameter("username");
        String password=req.getParameter("password");

        User user = new User();
        user.setUsername(username);
        user.setPassword(password);

        String content= JSON.toJSONString(user);

        PrintWriter writer = resp.getWriter();
        writer.write(content);
    }
}

(2)ajax页面请求

    function getUserInfo() {
      var username = document.getElementById("username").value;
      var password = document.getElementById("password").value;
      //创建Ajax对象
      var http=new XMLHttpRequest();
      //设置Ajax的请求地址与请求方式
      var params='username='+username+'&password='+password;
      http.open("get","http://localhost:8080/GetUserInfoServlet?"+params);
      //发送请求
      http.send();
      //获取响应数据
      http.onreadystatechange=function () {
        //readyState 0=>初始化 1=>载入 2=>载入完成 3=>解析 4=>完成
        if(this.readyState==4&&this.status==200){
          var responseText=this.responseText
          console.log('返回结果:'+responseText)
          var result=JSON.parse(responseText);
          console.log('解析结果password:'+result.password+' username:'+result.username)
        }
      }
    }
2、Ajax之post请求

(1)GetUserInfoServlet接口

@WebServlet("/UserLoginServlet")
public class UserLoginServlet extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.setContentType("text/html;charset=utf-8");

        //解析参数
        InputStreamReader insr = new InputStreamReader(req.getInputStream(),"utf-8");
        String res = "";
        int respInt = insr.read();
        while(respInt!=-1) {
            res +=(char)respInt;
            respInt = insr.read();
        }
        User user=JSON.parseObject(res,User.class);
        //返回结果
        Result result = new Result();
        if(user.getUsername()==null||user.getUsername().isEmpty()){
            result.setSuccess(false);
            result.setErrorCode(-1);
            result.setErrorMsg("请输入用户名");
        }else if(user.getPassword()==null||user.getPassword().isEmpty()){
            result.setSuccess(false);
            result.setErrorCode(-1);
            result.setErrorMsg("请输入密码");
        }else if(!user.getUsername().equals("admin")||!user.getPassword().equals("admin")){
            result.setSuccess(false);
            result.setErrorCode(-1);
            result.setErrorMsg("用户名或者密码错误");
        }else {
            result.setSuccess(true);
        }
        PrintWriter writer = resp.getWriter();
        writer.write(JSON.toJSONString(result));
    }
}

(2)ajax页面请求

function login() {
      var username = document.getElementById("username").value;
      var password = document.getElementById("password").value;
      //创建Ajax对象
      var http=new XMLHttpRequest();
      //设置Ajax的请求地址与请求方式
      http.open("post","http://localhost:8080/UserLoginServlet");
      //设置请求的参数格式类型post请求必须要设置
      // http.setRequestHeader('Content-type','application/x-www-form-urlencoded') username=123&password=344
      http.setRequestHeader('Content-type','application/json')
      //发送请求
      http.send(JSON.stringify({
          username:username,
          password:password
      }));
      //获取响应数据
      http.onreadystatechange=function () {
        //readyState 0=>初始化 1=>载入 2=>载入完成 3=>解析 4=>完成
        if(this.readyState==4&&this.status==200){
          var responseText=this.responseText
          console.log('返回结果:'+responseText)
          var result=JSON.parse(responseText);
          if(result.success){
             alert('登录成功')
          }else {
             alert(result.errorMsg)
          }
        }
      }
    }

原文地址:https://blog.csdn.net/u010520146/article/details/127577646

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_41136.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注