1.web服务本质
import socket sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM) sock.bind(("127.0.0.1",8800)) sock.listen(5) while 1: print("waiting........") conn,addr=sock.accept() data=conn.recv(1024) print("data",data.decode("utf8")) with open("index.html","r") as f: response=f.read() #可以吧html放在一个文档里面读出来 conn.send(("HTTP/1.1 201 OK\r\n\r\n%s"%response).encode("utf8"))
2.html是什么?
3.html结构
4.HTTP协议(超文本传输协议)
规定了浏览器与服务端之间消息传输的数据格式
四大特性:
1.基于请求响应
2.基于TCP/IP之上的作用于应用层的协议
3.无状态(服务端无法保存用户的状态)
4.无连接(请求一次我相应一次 之后立刻断开连接 两者之间没有任何联系了)
websocket 相当于是HTTP协议的一个大的补丁 它支持长连接
请求数据格式
请求首行(标识HTTP协议版本,当前请求方式)
请求头(一大堆k,v键值对)
\r\n
请求体(携带的是一些敏感信息比如 密码 ,身份证号....)
响应数据格式
响应首行(标识HTTP协议版本,,响应状态码)
响应头(一大堆k,v键值对)
\r\n
响应体(返回给浏览器页面的数据 通常响应体都是html页面)
响应状态码
用一串简单的数字来表示一些复杂的状态或者提示信息
1XX:服务端已经成功接收了你的数据正在处理,你可以继续提交额外的数据
2XX:服务端成功响应 你想要的数据(请求成功200)
3XX:重定向(当你在访问一个需要登录之后才能访问的页面,你会发现窗口会自动跳到登录页面 301,302)
4XX:请求错误(请求资源不存在404,请求不合法不符合内部规定会权限不够403)
5XX:服务器内部错误(500)
请求方式
1.get请求
朝服务端要资源(比如浏览器窗口输入www.baidu.com)
2.post提交
朝服务端提交数据(比如用户登录,,提交用户名和密码)
URL:统一资源定位符(就是网址)
原文:https://www.cnblogs.com/s686zhou/p/11454639.html