1.web引用程序

  web(world wide web)也叫万维网,是一种基于超文本和HTTP的、全球性的、动态交互的、跨平台的分布式图形信息系统。是建立在Internet上的一种网络服务,为浏览者在Internet上查找和浏览信息提供了图形化的、易于访问的直观界面

  一种可以通过web访问的应用程序,一般是B/S模式

  关于各种协议链接,点击这里

  HTTP协议笔试面试只是链接:点击这里

1.1http协议

  Hyper Text Transfer Protocol,超文本传输协议,用于万维网服务器与本地浏览器之间传输文本的传送协议

1.2http协议特性

  基于TCP/IP协议之上的应用层协议

  基于请求-响应模式(一次握手)

  HTTP协议自身不对请求和响应之间的通信状态进行保存

  服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间

1.3http请求协议与相应协议

关于请求协议格式

注:get与post请求区别

GET一般用于获取/查询 资源信息,而POST一般用于更新 资源信息(比如提交表单的内容)

get,post协议都是在http上运行的

GET - 从指定的服务器中获取数据
POST - 提交数据给指定的服务器处理

示例代码

GET请求

GET /books/?sex=man&name=Professional HTTP/1.1
Host: www.wrox.com
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.6)
Gecko/20050225 Firefox/1.0.1
Connection: Keep-Alive 注意最后一行是空行
POST请求 POST / HTTP/1.1
Host: www.wrox.com
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.6)
Gecko/20050225 Firefox/1.0.1
Content-Type: application/x-www-form-urlencoded
Content-Length: 40
Connection: Keep-Alive name=Professional%20Ajax&publisher=Wiley

  get请求,数据附在URL之后(请求首行),以?分割URL和传输数据,多个参数用&连接

  get提交的数据会在地址栏中显示出来,而post提交地址栏不会改变

  get提交的数据大小有限制(因为浏览器对URL长度有限制),而post么有

关于请求协议格式

http协议与https协议区别:

  1.https 协议需要到 ca 申请证书,一般免费证书很少,需要交费

  2.http 是超文本传输协议,信息是明文传输,https 则是具有安全性的 ssl 加密传输协议

  3.http 和 https 使用的是完全不同的连接方式,用的端口也不一样,前者是 80,后者是 443

  4.http 的连接很简单,是无状态的;HTTPS 协议是由 SSL+HTTP 协议构建的可进行加密传输、身份认证的网络协议,比 http 协议安全

http响应状态码

  客户端享服务端发送请求时,返回的请求结果。通过状态码可以知道服务端是否正常处理请求

状态代码有三位数字组成,第一个数字定义了响应的类别,共分五种类别:
1xx:指示信息--表示请求已接收,继续处理
2xx:成功--表示请求已被成功接收、理解、接受
3xx:重定向--要完成请求必须进行更进一步的操作
4xx:客户端错误--请求有语法错误或请求无法实现
5xx:服务器端错误--服务器未能实现合法的请求 常见状态码: 200 OK //客户端请求成功
400 Bad Request //客户端请求有语法错误,不能被服务器所理解
401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
403 Forbidden //服务器收到请求,但是拒绝提供服务
404 Not Found //请求资源不存在,eg:输入了错误的URL
500 Internal Server Error //服务器发生不可预期的错误
503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后可能恢复正常

相关补充

200 OK 客户端请求成功
301 Moved Permanently 请求永久重定向
302 Moved Temporarily 请求临时重定向
304 Not Modified 文件未修改,可以直接使用缓存的文件。
400 Bad Request 由于客户端请求有语法错误,不能被服务器所理解。
401 Unauthorized 请求未经授权。这个状态代码必须和WWW-Authenticate报头域一起使用
403 Forbidden 服务器收到请求,但是拒绝提供服务。服务器通常会在响应正文中给出不提供服务的原因
404 Not Found 请求的资源不存在,例如,输入了错误的URL
500 Internal Server Error 服务器发生不可预期的错误,导致无法完成客户端的请求。
503 Service Unavailable 服务器当前不能够处理客户端的请求,在一段时间之后,服务器可能会恢复正常。

#301和302说明:
  都表示重定向,浏览器在拿到服务器返回的这个状态码后会自动跳转到一个新的URL地址   

  301比较常用的场景是使用域名跳转。比如,我们访问 http://www.baidu.com 会跳转到 https://www.baidu.com
  

  表示旧地址A的资源已经被永久地移除了
  

  302用来做临时跳转,比如未登陆的用户访问用户中心重定向到登录页面。表示旧地址A的资源还在(仍然可以访问),这个重定向只是临时地从旧地址A跳转到地址B

1.4相关名词介绍

协议族各层作用:
应用层:决定了向用户提供应用服务时通信的活动

传输层:提供处于网络连接中的两台计算机之间的数据传输
(传输层有两个性质不同的协议:TCP,UDP)

网络层:处理在网络上流动的数据包
(网络层的作用就是在众多的选项中选择一条传输路线)

数据链路层:处理连接网络的硬件部分

DNS服务:
是和HTTP协议一样位于应用层的协议
DNS协议提供通过域名查找IP地址,或逆向从IP地址反查域名的服务,又称域名解析协议

URL:统一资源标识符

http协议:
用于客户端和服务端之间的通信
请求访问文本或图像等资源的一端称为客户端,
而提供资源响应的一端称为服务器端。

1.5 浏览器模拟socket客户端与Python服务端实现交互

  浏览器其实就是封装了socket的客户端,在Python里通过模拟服务端去响应浏览器客户端

import socket
ser = socket.socket()
port = ('127.0.0.1',8800)
ser.bind(port)
ser.listen()
while True:
print('server waitting')
conn,addr = ser.accept()
msg = conn.recv(1024)
print("data",msg) # 读取HTML文件
with open("day2.html", "rb") as f:
data = f.read()
# 固定语法格式,基于1.1版本的http协议
conn.send(b'HTTP:\\1.1 200 OK\r\n\r\n %s'% data)
conn.close()

day2.html

<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>登录界面</title>
</head>
<body>
<style>
p{
color: gray;
background-color: yellow;
}
</style>
<form>
<textarea name="留白" rows="" cols="">
</textarea>
</form>
<fieldset>
<div align="center">
<h2>账号登录 | 扫码登录</h2>
<input type="username" placeholder="邮箱/手机账号/小米ID"><br><br>
<input type="password" placeholder="密码"><br><br> <a href="">登录</a>
</fieldset> </div>
</body>
</html>

先运行服务端,此时打开浏览器,上方输入127.0.0.1:8800即能响应来自服务端的消息,打印服务端的信息

web之HTTP协议的更多相关文章

  1. JavaWeb:Web与HTTP协议简介

    JavaWeb:Web与HTTP协议简介 Web的概念 什么是Web: Web是网络上使用最广泛的分布式应用架构. 旨在共享分布在网络上的各个Web服务器中的所有互相连接的信息. 三个特征: 用HTM ...

  2. Web(click and script) 与 Web(HTTP/HTML)协议区别

    先从最简单的说明上来看, Web(HTTP/HTML):       Emulation of     communication between a    browser and Web Serve ...

  3. 使用 EWS(Exchange Web Service)协议读取邮件、发送邮件

    问题: 公司之前可以通过POP3协议收发邮件,因而在SoapUI中用JavaMail可以读取邮件,后来配置了Office 365,POP3协议端口不再开放,邮件全部读取失败,报login timeou ...

  4. ​Web(click and script) 与 Web(HTTP/HTML)协议区别

    Web(click and script) 与 Web(HTTP/HTML)协议区别 webjavascriptvbscript浏览器脚本login 先从最简单的说明上来看, Web(HTTP/HTM ...

  5. 使用LoadRunner的Web(HTTP/HTML)协议录制手机app脚本

    一.打开HP Virtual User Generator,创建虚拟用户脚本,选择Web(HTTP/HTML)协议:

  6. 小白日记27:kali渗透测试之Web渗透-Http协议基础,WEB

    Http协议基础 Web技术发展[http://www.cnblogs.com/ProgrammerGE/articles/1824657.html] 静态WEB[网页] 动态WEB 属于一种应用程序 ...

  7. Web开发——Http协议剖析

    Http,即超文本传输协议,是建立在TCP/IP协议的基础上.在Web开发的过程中,Http协议是十分重要的,浏览器与服务器之间的交互就是基于Http协议的.Http协议如果展开全面讲解会有很多内容, ...

  8. Web 应用 WEB框架 HTTP协议 初识Django

    ----------------------------财富存在于人的思想里,你没找到路,不等于没有路,你想知道将来要得到什么,你必须知道现在应该先做什么和先放弃什么! [web 应用] web应用 ...

  9. Web版微信协议分析—版本2

    微信web协议分析(微信网页版 wx2.qq.com) 1.打开首页,分配一个随机uuid,2.根据该uuid获取二维码图片.3.微信客户端扫描该图片,在客户端确认登录.4.浏览器不停的调用一个接口, ...

  10. python 全栈开发,Day66(web应用,http协议简介,web框架)

    一.web应用 web应用程序是一种可以通过Web访问的应用程序,程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件.应用程序有两种模式C/S.B/S.C/S是客户端 ...

随机推荐

  1. Oracle基础篇--01数据库控制语言DCL

    数据库控制语言,是用户对数据的权限控制语言. 通过GRANT语句进行赋权,通过REVOKE撤回权限.数据库的权限包括2种,一种是数据库系统权限,一种是数据库对象权限.在控制语言里面,存在2个概念, 1 ...

  2. httpUrlConnection连接网络的用法(用到了handle传递消息,在主线程中更新UI)

    由于httpclient在Android5.0以后已经过时,所以官方推荐使用httpUrlConnection来连接网络,现将该连接的基本方法展示,如下 注意:记得加入<uses-permiss ...

  3. (转)企业级NFS网络文件共享服务

    企业级NFS网络文件共享服务 原文:http://www.cnblogs.com/chensiqiqi/archive/2017/03/10/6530859.html --本教学笔记是本人学习和工作生 ...

  4. 配置python环境使用tushare股票数据

    最近在做一个项目,主要是基于股票市场来验证一些model,看看能否做量化交易.那么如何获取数据呢?因为客户这边前期是不想花钱买数据的,只能自己想办法了,从sina和yahoo财经频道爬到一些数据,但是 ...

  5. 服务间调用--feign跟ribbon

    微服务一般来说当然是多服务多实例的,那么这些服务之间如何相互调用呢?spring cloud之前我们用dubbo,把服务开放出来,在xml配好后就可以像调用本地service一样调用其它模块的服务了: ...

  6. 工作空间造成的javaweb项目无法新建

    出现问题: 当我打开myeclipse开发工具将原有的已经存在的一个名为jeecms的项目删除的时候,出现了删除不了,因此我采取了强制的删除的方法,最终项目删除了.接下来新建同名的javaweb就出现 ...

  7. checkbox判断选中的三种方法

    方法一: if ($("#checkbox-id")get(0).checked) {     // do something } 方法二: if($('#checkbox-id' ...

  8. css内容整理1

    1.css引入的四种方式1.行内2.内嵌3.链接 <link href="1.css" rel="stylesheet">4.导入@import u ...

  9. 处理IIS 255错误,和相关信息

    不知不觉已经注册博客一年多了,当初看见博客园的大神,自己也想像他们一样多写一些有用的,结果,,,不言而喻.在这里又感慨了一下,进入正题了.. 最近在公司服务器接触的比较多, 遇到了一个255 的问题 ...

  10. canvas剪辑区域