美文网首页
Ajax简单使用与Http协议

Ajax简单使用与Http协议

作者: 1CC4 | 来源:发表于2019-12-25 20:10 被阅读0次

允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax.

一、AJAX

1、介绍

  • JavaScript:更新局部的网页

  • XML:一般用于请求数据和响应数据的封装

  • XMLHttpRequest对象:发送请求到服务器并获得返回结果(AJAX核心)

  • CSS:美化页面样式

  • 异步:发送请求后不等返回结果,由回调函数处理结果

AJAX属于异步操作

2、好处:

  • 避免网页频繁刷新造成的不良用户体验。

  • 减少刷新将会减少服务器的执行压力。

  • 此种交互方式提高服务器程序的公用性。

3、异步刷新技术

二、HTTP协议(超文本传输协议)

HTTP是一个基于请求与响应模式的、无状态的、应用层的协议,常基于TCP的连接方式,绝大多数的Web开发,都是构建在HTTP协议之上的Web应用。

1、响应模式

2、主要特点

  • 1.支持客户/服务器模式。

  • 2.简单快速:客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、HEAD、POST。每种方法规定了客户与服务器联系的类型不同。由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度很快。

  • 3.灵活:HTTP允许传输任意类型的数据对象。正在传输的类型由Content-Type加以标记。

  • 4.无连接:无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间。

  • 5.无状态:HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

3、请求request

  • 1、HTTP请求包结构

    http请求由三部分组成,分别是:请求行、请求头部、请求包体(正文)

请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本,
格式:Method Request-URL HTTP-Version CRLF

Method:表示请求方法;
Request-URI:表示一个统一资源标识符;
HTTP-Version:表示请求的HTTP协议版本;
CRLF:表示回车和换行(除了作为结尾的CRLF外,不允许出现单独的CR或LF字符)。

  • 2、Http请求方式
    方法--------描述
    GET--------请求指定url的数据,请求体为空(例如打开网页)。
    POST-------请求指定url的数据,同时传递参数(在请求体中)。
    HEAD ------类似于get请求,只不过返回的响应体为空,用于获取响应头。
    PUT--------从客户端向服务器传送的数据取代指定的文档的内容。
    DELETE----请求服务器删除指定的页面。
    CONNECT---HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。
    OPTIONS---允许客户端查看服务器的性能。
    TRACE------回显服务器收到的请求,主要用于测试或诊断。
    常用只有Post与Get

4、响应response

  • 1、HTTP响应包结构

    HTTP响应也是由三个部分组成,分别是:状态行、消息报头、响应正文

格式:HTTP-Version Status-Code Reason-Phrase CRLF
HTTP-Version:表示服务器HTTP协议的版本;
Status-Code:表示服务器发回的响应状态代码;
Reason-Phrase:表示状态代码的文本描述。

  • 2、响应状态码

状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值:
1xx:指示信息--表示请求已接收,继续处理
2xx:成功--表示请求已被成功接收、理解、接受
3xx:重定向--要完成请求必须进行更进一步的操作
4xx:客户端错误--请求有语法错误或请求无法实现
5xx:服务器端错误--服务器未能实现合法的请求

常见状态代码 --状态描述--说明:

  • 200 OK //客户端请求成功
  • 400 Bad Request //客户端请求有语法错误,不能被服务器所理解
  • 401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
  • 403 Forbidden //服务器收到请求,但是拒绝提供服务
  • 404 Not Found //请求资源不存在,eg:输入了错误的URL
  • 405 //方法不被允许
  • 500 Internal Server Error //服务器发生不可预期的错误
  • 503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后,可能恢复正常

三、使用Ajax

1、XMLHttpRequest

XHR对象:是XMLHttpRequest对象的缩写,封装在window对象中,封装了发送AJAX请求、接收响应的属性以及方法。JavaScript对象XMLHttpRequest是整个Ajax技术的核心,它提供了异步发送请求的能力

1、XHR对象的创建:


如果XMLHttpRequest对象存在,则把 xhr 的值设为该对象的新实例。如果不存在,就去检测 ActiveObject 的实例是否存在,如果答案是肯定的,则把微软 XMLHTTP 的新实例赋给 xhr

2、常用方法


3、常用属性
  • setRequestHeader(header,value):设定响应头,响应头用于描述元数据。
    --header: 响应头的名字;
    如果用 POST 请求向服务器发送数据,需要将 “Content-type” 的首部设置为 “application/x-www-form-urlencoded”.它会告知服务器正在发送数据,并且数据已经符合URL编码了
    --value:响应头的值
    注意事项:该方法必须在open()之后才能调用
  • onreadystatechange:指定回调函数
  • readystate: XMLHttpRequest的状态信息
  • status:HTTP的状态码(200对应OK,404对应NotFount等)
  • statusText:HTTP状态码的相应文本(OK或NotFount等)
  • responseText:获得响应的文本内容,表示一个字符串
  • responseXML:获得响应的XML文档对象,可以解析为DOM对象

就绪状态是4而且状态码是200,才可以处理服务器数据

四、示例

 <h2>AJAX请求数据</h2>
    <div>
        <p id="title"></p>
        <i id="content"></i>
    </div>
   // 1、创建XMLHttpRequest对象
    const xhr = new window.XMLHttpRequest;
    //2、建立连接 open(请求方式,url地址,是否异步);
    xhr.open('GET', 'http://192.168.0.100:8089/api/list', true);
    // 3、发送请求 send()
    xhr.send();
    // 4、接收响应
    xhr.onreadystatechange = e => {
        // 判断ajax响应状态
        if (e.target.readyState == 4) {//readyState=4:响应的内容解析完毕,可以在客户端使用了--完成
            // 判断是否响应成功
            if (e.target.//xhr.status:获取当前服务器的响应状态  200=>成功
                status == 200) {
                const pElment = document.getElementById('title');
                pElment.innerHTML = e.target.responseText;
            } else {//请求出错将状态码显示出来
                const iEmlent = document.getElementById('content');
                iEmlent.innerHTML = e.target.status;
            }
        }
    }

得到服务器JSON对象:

五、封装调用

  • 封装js
let XMLHttpPromiseObj = (method, url, parmas) => {
    return new Promise((resovled, rejected) => {
        // 1、创建XMLHttpRequest对象
        const xhr = new window.XMLHttpRequest;
        //2、建立连接 open(请求方式,url地址,是否异步);        
        xhr.open(method, url, true);
        // 如果想要使用post提交数据,必须添加此行
        xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        // 3、发送请求 send()
        xhr.send(parmas);
        // 4、接收响应
        xhr.onreadystatechange = e => {
            // 判断ajax响应状态
            if (e.target.readyState == 4) {//readyState=4:响应的内容解析完毕,可以在客户端使用了--完成
                // 判断是否响应成功
                if (e.target.status == 200) {//xhr.status:获取当前服务器的响应状态  200=>成功
                    let data = e.target.responseText //返回成功的值
                    resovled(data);
                } else {
                    let err = e.target.status //返回失败的响应码
                    rejected(`请求错误:${err}`);
                }
            }
        }
    });
}
  • 使用js
<script src="./AjaxModel.js"></script>//引入js文件
<script>
    const contentElment = document.getElementById('content');
    const name = 'admin';
    const passwd = '123';
    const content = `username=${name}&password=${passwd}`;
    //直接使用js的方法
    const xmlObjPromise = XMLHttpPromiseObj('post', 'http://192.168.0.100:8089/api/login', content);
    xmlObjPromise.then(data => {
        contentElment.innerHTML = data;
    }).catch(err => {
        contentElment.innerHTML = err;
    })
</script>

六、工具推荐

  • JSONview :使在谷歌浏览器中访问URL地址返回的json数据按照json格式展现出来。
  • Postman:网页调试与发送网页HTTP请求的Chrome插件。(调试接口是否能正常使用)
  • Fiddler:网络传输发送与接受的数据包进行截获、重发、编辑、转存等操作。(抓包工具,可以查看请求和响应的内容信息等)

相关文章

  • Ajax简单使用与Http协议

    允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax. 一、AJAX 1、介绍 JavaScript:更...

  • Ajax与HTTP请求

    最近在学习Ajax相关的内容。谈到Ajax就不得不提HTTP协议,Ajax就是使用JavaScript来发送,一个...

  • 如何通过HTTPS页面请求不到HTTP Ajax请求

    如何通过HTTPS页面请求不到HTTP Ajax请求,只能同协议,http页面可以请求到https的 Ajax,

  • TCP/UDP http ajax websocket 的区别关

    TCP/UDP http websocket ajax 的区别关系以及使用场景 TCP/IP协议栈主要分为四层:应...

  • Ajax和http协议

    一、Ajax Ajax(Asynchronous Javascript And XML):意思是异步的javasc...

  • HTTP协议、存储、Ajax

    前后端数据交互与 HTTP 协议 1、前后端通信是什么(1)前端和后端交互的过程(2)浏览器和服务器之间数据交互的...

  • HTTP协议基础# Chapter2 简单HTTP协议

    Chapter2 简单HTTP协议 HTTP协议:::适用于客户端和服务器端之间的通信 使用HTTP协议通信的同一...

  • Ajax实践

    在了解ajax之前,我们先粗略的了解一下http协议 HTTP协议 http事务 一个完整的http请求是怎样的呢...

  • Cookie和Ajax

    了解http协议: 了解Ajax的概念: 掌握利用工具发送Ajax的方式: 掌握查看Ajax请求的方式: 掌握co...

  • jQuery中Ajax请求的使用和四个步骤示例

    ajax() 方法用于执行 AJAX(异步 HTTP)请求,所有的 jQuery AJAX 方法都使用 ajax(...

网友评论

      本文标题:Ajax简单使用与Http协议

      本文链接:https://www.haomeiwen.com/subject/lewcoctx.html