web应用程序+HTTP协议

标签(空格分隔): Djangopython


web应用程序案例:

若是咱们想经过本身电脑访问京东,就是一个网络编程(由于京东的服务部署在京东,经过本身的电脑浏览器传输到京东服务就是网络编程);只要涉及到网络编程就要用到socket;
以下咱们模拟一个访问,就会用到socket网络编程,以下咱们在本身的本地模拟个服务器
pycharm代码编写:web

import socket
sock=socket.socket()
#以下是本机访问地址
sock.bind(("127.0.0.1",8800))
sock.listen(5)
#等待用户链接
while 1:
#conn客户端套节字对象,
    conn,addr=sock.accept()
    data=conn.recv(1024)
    print(data)
    conn.send(b"HTTP/1.1 200 OK\r\n\r\n<helllowearesutdying")
    conn.close()

2.编写完成了,开启服务器:
3.客户端浏览器查看:127.0.0.1:8800编程

image.png-49.4kB
说明并无按照响应的格式给到服务器,没法解析,这时候浏览器傻眼了,他不知道:helllowearesutdying这个是干吗用的;
以下代码就能够正常的解析了:浏览器

import socket
sock=socket.socket()
sock.bind(("127.0.0.1",8800))
sock.listen(5)

while 1:
    print("server waiting.......")
    conn,addr =sock.accept()
    data=conn.recv(1024)
    print(data)
    conn.send(b"HTTP/1.1 200 OK\r\n\r\n helllowearesutdy")
    conn.close()

image.png-31.6kB
如图就正常请求成功了;缓存

import socket
sock=socket.socket()
sock.bind(("127.0.0.1",8800))
sock.listen(5)

while 1:
    print("server waiting.......")
    conn,addr =sock.accept()
    data=conn.recv(1024)
    print(data)
    conn.send(b"HTTP/1.1 200 OK\r\n\r\n<h1>helllowearesutdy<h1>")
    conn.close()

这个时候浏览器里面打开127.0.0.1:8800,就能够看到浏览器解析了HTML语言;
以上就是一个web应用请求;安全

HTTP协议:

HTTP协议简介:

HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于万维网(WWW:World Wide Web )服务器与本地浏览器之间传输超文本的传送协议。服务器

HTTP是一个属于应用层的面向对象的协议,因为其简捷、快速的方式,适用于分布式超媒体信息系统。它于1990年提出,通过几年的使用与发展,获得不断地完善和扩展。网络

HTTP协议工做于客户端-服务端架构为上。浏览器做为HTTP客户端经过URL向HTTP服务端即WEB服务器发送全部请求。Web服务器根据接收到的请求后,向客户端发送响应信息。架构

HTTP协议的特色:

基于TCP/IP:

计算机与网络设备要相互通讯,双方就必须基于相同的方法。好比,如何探测到通讯目标、由哪一边先发起通讯、使用哪一种语言进行通 信、怎样结束通讯等规则都须要事先肯定。不一样的硬件、操做系统之间 的通讯,全部的这一切都须要一种规则。而咱们就把这种规则称为协议(protocol)。协议中存在各式各样的内容。从电缆的规格到IP地址的选定方法、 寻找异地用户的方法、双方创建通讯的顺序,以及Web页面显示须要 处理的步骤,等等。像这样把与互联网相关联的协议集合起来总称为TCP/IP。而http协议是基于TCP/IP协议之上的应用层协议。less

基于-响应模式:

HTTP协议规定,请求从客户端发出,最后服务器端响应该请求并 返回。换句话说,确定是先从客户端开始创建通讯的,服务器端在没有 接收到请求以前不会发送响应。
image.png-105kB

无状态保存的:

HTTP是一种不保存状态,即无状态(stateless)协议。HTTP协议 自身不对请求和响应之间的通讯状态进行保存。也就是说在HTTP这个 级别,协议对于发送过的请求或响应都不作持久化处理。
image.png-117kB
使用HTTP协议,每当有新的请求发送时,就会有对应的新响应产 生。协议自己并不保留以前一切的请求或响应报文的信息。这是为了更快地处理大量事务,确保协议的可伸缩性,而特地把HTTP协议设计成 如此简单的。但是,随着Web的不断发展,因无状态而致使业务处理变得棘手 的状况增多了。好比,用户登陆到一家购物网站,即便他跳转到该站的 其余页面后,也须要能继续保持登陆状态。针对这个实例,网站为了能 够掌握是谁送出的请求,须要保存用户的状态。HTTP/1.1虽然是无状态协议,但为了实现指望的保持状态功能, 因而引入了Cookie技术。有了Cookie再用HTTP协议通讯,就能够管 理状态了。有关Cookie的详细内容稍后讲解。

无链接:

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

http请求协议与响应协议

http协议包含由浏览器发送数据到服务器须要遵循的请求协议与服务器发送数据到浏览器须要遵循的请求协议。用于HTTP协议交互的信被为HTTP报文。请求端(客户端)的HTTP报文 作请求报文,响应端(服务器端)的 作响应报文。HTTP报文自己是由多行数据构成的文本。

image.png-125.7kB

请求协议:

请求格式:

image.png-91.7kB

请求方式:get和post请求:

  • GET提交的数据会放在URL以后,以?分割URL和传输数据,参数之间以&相连,如EditBook?name=test1&id=123456. POST方法是把提交的数据放在HTTP包的Body中.
  • GET提交的数据大小有限制(由于浏览器对URL的长度有限制),而POST方法提交的数据没有限制.
  • GET与POST请求在服务端获取请求数据方式不一样。
  • GET方式提交数据,会带来安全问题,好比一个登陆页面,经过GET方式提交数据时,用户名和密码将出如今URL上,若是页面能够被缓存或者其余人能够访问这台机器,就能够从历史记录得到该用户的帐号和密码.

响应协议:

image.png-97.9kB

响应状态吗:

状态码的职 是当客户端向服务器端发送请求时, 返回的请求 结果。借助状态码,用户能够知道服务器端是正常 理了请求,仍是出 现了 。
image.png-160.1kB
image.png-120.3kB

相关文章
相关标签/搜索