Web交互的基本流程

    请求:客户端根据服务器地址把数据发送给服务器的过程叫请求。

    相应:服务器将请求的处理结果发送给浏览器的过程叫响应。

什么是HTTP?

概念:超文本传输协议。

HTTP有什么作用?

    作用:规范了浏览器和服务器的数据交互格式。

HTTP有什么特点?

特点:简单快捷,灵活,无连接,无状态。

HTTP1.1版本后支持可持续连接。

HTTP请求与服务器

客户端与服务器:

    CS与BS  软件使用方式上两种划分:

    客户端,服务器架构Client/Server:

  特点:在服务器当中就主要是一个数据库,把所有的业务逻辑以及界面都交给客户端完成

  优点:较为安全,用户界面丰富,用户体验好

  缺点:每次升级都要重新安装,针对于不同的操作系统开发,可移植性差

浏览器/服务器架构Browser/Server:

特点:基于浏览器访问的应用

把业务层交给服务器来完成,客户端仅仅做界面的渲染和数据的交换

优点:只开发服务器端,可以跨平台,移植性很强

缺点:安全性比较低,用户体验较差

Web资源

  什么是Web?

WEB网页,它用于表示网络主机上供外界访问的资源.

  Web资源分类

静态Web资源

指Web页面中供人们浏览的数据始终是不变.

动态Web资源

指Web页面中供人们浏览的数据是由程序产生的,不同时间点访问Web页面看到的内容各不相同.

Web资源存放在哪里

所有的Web资源都放在一个Web服务器当中

Web服务器就是可以供外界访问Web资源的一个软件

Web资源放到指定的目录当中,就可以通过对应的端口在浏览器当中访问到

URL地址

协议://主机地址:端口号/资源地址

http://www.it666.com:80/index.html

域名资源访问流程

    当我们在浏览器当中访问一个地址的时候,为什么就能看到一个页面

BS结构流程图

请求与响应

       请求:

              把客户端请求发送给服务器

       响应:

              服务器把你要的数据发送给客户端

请求与响应都要一定的格式:

约定好客户端以什么样的格式把数据给服务器

约定好服务器以什么样的格式把数据给客户端

这个约定使用的就是HTTP协议

客户端

  浏览器

    Android程序

    IOS程序

    微信小程序

服务器

    PHP服务器

    Tomcat服务器

    nodeJS服务器

发送http请求方式

  http协议

    什么是协议:

      约束双方规范的一个准测

  什么是HTTP协议

      HTTP 超文本传输协议(HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议

      所有的WWW文件都必须遵守这个标准

      设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法

      约束请求与响应的规则

HTTP组成部分

  请求

    响应

    请求与响应都是成对存在的

请求的发送方式

  1. 通过浏览器的地址栏
  2. 通过html当中的form表单
  3. 通过a链接的href
  4. src属性

http请求

请求行和请求头

  1.      请求行

    请求方式

    POST

    GET

请求的资源

/Myxq/login.html?username=myxq&pwd=1234

协议版本

HTTP/1.0,发送请求,创建一次连接,获得一个Web资源,连接断开.

HTTP/1.1,发送请求,创建一次连接,获得多个Web资源,保持连接.

  2.      请求头

    请求头是客户端发送给服务器端的一些信息

    使用键值对表示key : value

常见请求头

    Referer.浏览器通知服务器,当前请求来自何处。如果是直接访问,则不会有这个头。常用于:防盗链
    If-Modified-Since.浏览器通知服务器,本地缓存的最后变更时间
    Cookie.用于存放浏览器缓存的cookie信息
    User-Agent. 浏览器通知服务器,客户端浏览器与操作系统相关信忘
    Connection .保持连接状态, Keep-Alive连接中, close已关闭
    Host.请求的服务器主机名
    Content-Length.请求体的长展
    Content-Type.如果是POST请求,会有这个头,默认值为application/x-www-form-urlencoded,表示请求体内容使用url编码
    Accept.浏览器可支持的MIME类型,文件类型的一种描述方式。
    Accept-Encoding.浏览器通知服务器,浏览器支持的数据压缩格式.如: GZIP压缩 
    Accept-Language.浏览器通知服务器,浏览器支持的语

请求体

当请求方式是POST时,请求体会有请求的参数

如果请求方式为get,那么请求参数不会出现在请求体中,会拼接在url地址后面

http响应

响应行

状态码

200:请求成功

302:请求重定向

304:请求资源没有改变,访问本地缓存

404:请求资源不存在,通常是用户路径编写错误,也可能是服务器资源已删除.

500:服务器内部错误.通常程序抛异常.

其它状态码

              成功

              重定向

客户方错误

              服务器错误

响应头

服务器端将信息以键值对的形式返回给客户端

 

常见请求头

Location:

指定响应的路径,需要与状态码302配合使用,完成跳转

Content-Type:

响应正文的类型(MIME类型)

Content-Disposition:

通过浏览器以下载方式解析正文

Set-Cookie:

服务器向浏览器写入cookie

Content-Encoding:

服务器使用的压缩格式

Content-length:

响应正文的长度

Refresh:

定时刷新

Server:

服务器名称,默认值:Apache-Coyote/1.1.可以通过conf/server.xml配置进行修改

Last-Modified:

服务器通知浏览器,文件的最后修改时间.

 

响应体

响应体是服务器回写给客户端的页面正文

浏览器将正文加载到内存

然后解析渲染显示页面内容

请求方式

8种请求类型

  1. 1.      OPTIONS

      返回服务器针对特定资源所支持的HTTP请求方法,也可以利用向Web服务器发送’*’的请求来测试服务器的功能性

  1. 2.      HEAD

      请求指定的页面信息,并返回头部信息

  1. 3.      GET

      请求指定的页面信息,并返回实体主体

  1. 4.      POST

      向指定资源提交数据进行处理请求

  1. 5.      PUT

      向指定资源位置上传其最新内容

  1. 6.      DELETE

      请求服务器删除Request-URL所标识的资源

  1. 7.      TRACE

      回显服务器收到的请求,主要用于测试或诊断

  1. 8.      CONNECT

      HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器

常用两种请求

面试可能问的************************

  GET

    GET方法向页面请求发送参数

    地址和参数信息中间用?字符分隔http://www.it666.com/hello?key1 =value1&key2=value2

    查询宁符串会显示在地址栏的URL中,不安全,请不要使用GET请求提交敏感数据

    GET方法有大小限制:请求字符串中最多只能有1024个字符

    GET请求能够被缓存

    GET请求会保存在浏览器的浏览记录中

    可以添加书签

    编码类型为application/x-www-form-urlencoded

    只允许ASCII字符类型,不能用二进制流

    点击刷新时,不会有反应

    GET请求主要用以获取数据

  POST

    POST方法向页面请求发送参数

    使用POST方法时,查询字符串在POST信息中单独存在,和HTTP请求一起发送到服务器

    编码类型为:application/x-www-form-urlencoded or multipart/form-data.请为二进制数据使

    用multipart编码

    没有历史记录

    参数类型没有限制,可以是字符串也可以是二进制流

    数据不会显示在地址栏中,也不会缓存下来或保存在浏览记录中,所以

    看POST求情比GET请求安全,但也不是最安全的方式。如需要传送敏

    感数据,请使用加密方式传输

    查询字符串不会显示在地址栏中

    Post传输的数据量大,可以达到2M,而Get方法由于受到URL长度限制,只能传递大约1024字节。

    Post就是为了将数据传送到服务器段,Get就是为了从服务器段取得数据

最新文章

  1. swift初体验
  2. tyvj1102 单词的划分
  3. Yocto开发笔记之《错误记录》(QQ交流群:519230208)
  4. DIA
  5. windows2008r2环境双实例安装mysql5.6
  6. imageNamed、imageWithContentsOfFile、imageWithData
  7. [译]Java Thread wait, notify和notifyAll示例
  8. snowflake算法(java版)
  9. jquery 实现全选反选
  10. nuget 服务器崩溃
  11. Hibernate缓存和懒加载的坑你知道多少?这5个简单问题回答不上来就不敢说会用hibernate
  12. UML类图10分钟快速入门
  13. ThoughtWorks.QRCode 生成QR二维码时提示“索引超出了数组界限”的原因和解决方法
  14. gradle安装操作
  15. function "round" declared implicitly
  16. js 常用的工具函数
  17. Modbus库开发笔记之三:Modbus TCP Server开发
  18. Hadoop记录-hadoop介绍
  19. 高并发和大流量解决方案--CND加速
  20. 2019.01.21 bzoj2989: 数列(二进制分组+主席树)

热门文章

  1. css-动画,a标签下,文字加下划线,而且动画是由中间向两边扩展开
  2. k8s配置文件模板
  3. [深度学习] pytorch利用Datasets和DataLoader读取数据
  4. PHP教程-反序列化的方法
  5. CMS 与 框架
  6. pip安装源和虚拟环境的搭建
  7. JS框架_(Qrcode.js)将你的内容转换成二维码格式
  8. 如何将JS中object转换为字符串
  9. Spring boot之热部署
  10. 套接字之recvmsg系统调用