当前位置: 首页 > news >正文

中山做网站排名推广文章

中山做网站排名,推广文章,代运营诈骗怎么定性的,快速建站实例演示完整版本节内容: 1、http协议 2、web框架的概念 3、Django简介(初识引入)一、http协议 Hypertext Transfer Protocol,超文本传输协议所谓协议,就是指双方遵循的规范。http协议, 就是浏览器和服务器之间进行“沟通…

本节内容:

1、http协议
2、web框架的概念
3、Django简介(初识引入)

一、http协议

Hypertext Transfer Protocol,超文本传输协议所谓协议,就是指双方遵循的规范。http协议,
就是浏览器和服务器之间进行“沟通”的一种规范。http是属于“应用层的协议”,而且是基于TCP/IP协议的。
解释:首先是基于TCP/ip协议,然后在此基础上还有应用层的协议

1、http连接的时限

那么我们在给服务端发送请求时,得到响应后,是否还保持的跟服务端的连接:
解释:
1、在最初的http协议,得到响应结果后,连接是断开的,
此时考虑的是释放给其他人连接,不让你长久占用连接,服务器端立即关闭连接、释放资源。2、现在的http协议,会在你拿到响应结果后,保持一小段时间连接(大概几秒钟),
这样在你又点击时,不用开辟新的连接,从而提高资源利用。

2、http协议是无状态,(不会保存之前的记录)

也就是“服务器不知道你客户端干了啥”,其实很大程度上是基于性能考虑的。
后来有些业务需要查询之前的记录,只是coockie缓存就登场了,
后面详细介绍

3、请求协议格式:浏览器丢给服务器的(重点)

一般我们不怎么考虑这个格式,因为浏览器会帮我们弄好这一套协议一个完整的http请求消息,包含一个请求行,若干个消息头(请求头),换行,实体内容请求方式:1、get的话是将路径拼接在域名后,数据也是,大小有限制,
2、post这是写在实体内容里,不会显示在URL中,数据大小不限,但还是有安全问题
请求行:描述客户端的请求方式、请求资源的名称、http协议的版本号。 例如: GET/BOOK/JAVA.HTML HTTP/1.1请求头(消息头)包含(客户机请求的服务器主机名,客户机的环境信息等):
Accept:用于告诉服务器,客户机支持的数据类型  (例如:Accept:text/html,image/*)
Accept-Charset:用于告诉服务器,客户机采用的编码格式
Accept-Encoding:用于告诉服务器,客户机支持的数据压缩格式
Accept-Language:客户机语言环境
Host:客户机通过这个服务器,想访问的主机名
If-Modified-Since:客户机通过这个头告诉服务器,资源的缓存时间
Referer:客户机通过这个头告诉服务器,它(客户端)是从哪个资源来访问服务器的(防盗链)
User-Agent:客户机通过这个头告诉服务器,客户机的软件环境(操作系统,浏览器版本等)
Cookie:客户机通过这个头,将Coockie信息带给服务器
Connection:告诉服务器,请求完成后,是否保持连接
Date:告诉服务器,当前请求的时间(换行)
实体内容:
就是指浏览器端通过http协议发送给服务器的实体数据。例如:name=dylan&id=110
(get请求时,通过url传给服务器的值。post请求时,通过表单发送给服务器的值)

4、http响应协议格式:服务器返回给浏览器的(重点)

一个状态行,若干个消息头,以及实体内容
响应头(消息头)包含:
Location:这个头配合302状态吗,用于告诉客户端找谁
Server:服务器通过这个头,告诉浏览器服务器的类型
Content-Encoding:告诉浏览器,服务器的数据压缩格式
Content-Length:告诉浏览器,回送数据的长度
Content-Type:告诉浏览器,回送数据的类型
Last-Modified:告诉浏览器当前资源缓存时间
Refresh:告诉浏览器,隔多长时间刷新
Content-Disposition:告诉浏览器以下载的方式打开数据。例如: context.Response.AddHeader("Content-Disposition","attachment:filename=aa.jpg");                                        context.Response.WriteFile("aa.jpg");
Transfer-Encoding:告诉浏览器,传送数据的编码格式
ETag:缓存相关的头(可以做到实时更新)
Expries:告诉浏览器回送的资源缓存多长时间。如果是-1或者0,表示不缓存
Cache-Control:控制浏览器不要缓存数据   no-cache
Pragma:控制浏览器不要缓存数据          no-cacheConnection:响应完成后,是否断开连接。  close/Keep-Alive
Date:告诉浏览器,服务器响应时间状态行:  例如:  HTTP/1.1  200 OK   (协议的版本号是1.1  响应状态码为200  响应结果为 OK)实体内容(实体头):响应包含浏览器能够解析的静态内容,例如:html,纯文本,图片等等信息关于http协议的更多具体细节,可以参照http RFC文档。

第一部分:状态行,由HTTP协议版本号, 状态码, 状态消息 三部分组成。
第一行为状态行,(HTTP/1.1)表明HTTP版本为1.1版本,状态码为200,状态消息为(ok)第二部分:消息报头,用来说明客户端要使用的一些附加信息
第二行和第三行为消息报头,
Date:生成响应的日期和时间;Content-Type:指定了MIME类型的HTML(text/html),编码类型是UTF-8第三部分:空行,消息报头后面的空行是必须的
第四部分:响应正文,服务器返回给客户端的文本信息。
空行后面的html部分为响应正文。

1、响应状态码

详解

状态代码有三位数字组成,第一个数字定义了响应的类别,共分五种类别:
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        //服务器当前不能处理客户端的请求,一段时间后可能恢复正常

二、web应用与web框架

对于所有的Web应用,本质上其实就是一个socket服务端,
用户的浏览器其实就是一个socket客户端。

1、web应用的本质

最简单的Web应用就是先把HTML用文件保存好,用一个现成的HTTP服务器软件,
接收用户请求,从文件中读取HTML,返回。

代码示例

import socketsock=socket.socket() sock.bind(("127.0.0.1",8800)) sock.listen(5) while 1: conn,addr=sock.accept() recv_data=conn.recv(1024) print("recv_data:",recv_data) #conn.send(b"HTTP/1.1 200 ok\r\ncontent-length:12\r\n\r\nHello World!") with open("login.html","rb") as f: data=f.read() conn.send(b"HTTP/1.1 200 ok\r\n\r\n"+data) conn.close(). 
Python
Copy

2、基于wsgiref模块的自定义的web,详细示例

 正确的做法是底层代码由专门的服务器软件实现,我们用Python专注于生成HTML文档。因为我们不希望接触到TCP连接、HTTP原始请求和响应格式,所以,需要一个统一的接口,让我们专心用Python编写Web业务。这个接口就是WSGI:Web Server Gateway Interface。示例看一遍,知道过程就行了,为得是为后面知道Django的各个文件的作用重点是Django

初步示例1

from wsgiref.simple_server import make_serverdef application(environ, start_response): #print("environ",environ) start_response('200 OK', [('Content-Type', 'text/html')]) # 获取当前请求路径 print("PATH_INFO",environ.get("PATH_INFO")) path=environ.get("PATH_INFO") # 分支 if path == "/login": with open("login.html","rb") as f: data=f.read() return [data] elif path == "/index": with open("home.html", "rb") as f: data = f.read() return [data] else: return [b"<h1>404!</h1>"] httpd = make_server('', 8080, application) # 开始监听HTTP请求: httpd.serve_forever() 
Python
Copy

初步示例2

from wsgiref.simple_server import make_server
# 视图函数 def home(): with open("home.html", "rb") as f: data = f.read() return data def login(): with open("login.html", "rb") as f: data = f.read() return data def application(environ, start_response): #print("environ",environ) start_response('200 OK', [('Content-Type', 'text/html')]) # 获取当前请求路径 print("PATH_INFO",environ.get("PATH_INFO")) path=environ.get("PATH_INFO") # 分支 if path == "/login": ret=login() elif path == "/index": ret=home() else: ret=b"<h1>404!</h1>" return [ret] httpd = make_server('', 8080, application) # 开始监听HTTP请求: httpd.serve_forever() 
Python
Copy

初步示例3

from wsgiref.simple_server import make_server
# 视图函数 def home(): with open("home.html", "rb") as f: data = f.read() return data def login(): with open("login.html", "rb") as f: data = f.read() return data def notFound(): return b"<h1>404!!!</h1>" def application(environ, start_response): #print("environ",environ) start_response('200 OK', [('Content-Type', 'text/html')]) # 获取当前请求路径 print("PATH_INFO",environ.get("PATH_INFO")) path=environ.get("PATH_INFO") # 分支 urlpatterns=[ ("/login",login), ("/index",home), ] func=None for item in urlpatterns: if path == item[0]: func=item[1] break if not func: ret=notFound() else: ret=func() return [ret] httpd = make_server('', 8080, application) # 开始监听HTTP请求: httpd.serve_forever() 
Python
Copy

3、DIY一个自己的web框架

manage.py

from wsgiref.simple_server import make_server
from views import * from urls import urlpatterns def application(environ, start_response): #print("environ",environ) start_response('200 OK', [('Content-Type', 'text/html')]) # 获取当前请求路径 print("PATH_INFO",environ.get("PATH_INFO")) path=environ.get("PATH_INFO") # 分支 func=None for item in urlpatterns: if path == item[0]: func=item[1] break if not func: ret=notFound(environ) else: ret=func(environ) return [ret] httpd = make_server('', 8080, application) # 开始监听HTTP请求: httpd.serve_forever() 
Python
Copy

urls.py

from views import *urlpatterns = [ ("/timer",timer) ] 
Python
Copy

views.py

# 视图函数
def timer(environ): import datetime now=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") return now.encode("utf8") def notFound(environ): return b"<h1>404...</h1>" 
Python
Copy

三、Django介绍

1、mvc模型(最典型的MVC就是jsp+servlet+javabean模式)

MVC的全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写

2、mtv模型(Django)

Django的MTV分别代表:Model(模型):和数据库相关的,负责业务对象与数据库的对象(ORM)Template(模板):放所有的html文件模板语法:目的是将白变量(数据库的内容)如何巧妙的嵌入到html页面中View(视图):负责业务逻辑,并在适当的时候调用Model和Template此外,Django还有一个URL分发器。
它的作用是将一个个URL的页面请求分别发给不同的Views处理,Views再调用相应的Model和Template。


2、Django的基本命令

1、下载Django

在cmd窗口下,pip install django==2.1.1   (2.1.1是版本号)

2、创建一个Django对象

django-admin.py  startproject   项目名称
django-admin.py  startproject    mysite

3、创建一个应用

python3 manage.py startapp blog(应用名称)

4、启动Django项目

python manage.py runserver  8080(不写就是默认8000端口)

5、创建表命令

python3 manage.py makemigrationspython3 manage.py migrate

转载于:https://www.cnblogs.com/yipianshuying/p/10193002.html

http://www.lbrq.cn/news/2729611.html

相关文章:

  • 建网站 西安交换友情链接平台
  • 怎么做响应式网站网站推广营销运营方式
  • 一朋友做色情网站被抓了可以直接进入网站的正能量
  • 电子政务政府门户网站建设怎么创建公司网站
  • 乐清外贸网站建设b2b平台排名
  • 如何快速创建一个网站百度首页排名代发
  • 音乐外链生成网站怎么做搜索引擎优化工作
  • 建立网站需要什么手续软文推广页面
  • 义乌做网站公司东莞关键词排名seo
  • 网站开发远程服务器如何设置软件开发公司联系方式
  • 网站主体负责人不是法人什么是关键词举例说明
  • 南昌做网站装修的企业刷推广链接
  • 做网站美工未来规划哪里做网站便宜
  • 网站开发代理商廊坊网站
  • 西宁市网站建设高端在线葡京在线葡京
  • wordpress 飘窗郑州网站seo推广
  • 太原网站建设信息推荐网络科技公司经营范围
  • 东莞南城外贸网站建设石家庄百度快速排名优化
  • html5素材网站链接交换平台
  • 主流建站公司企业seo如何优化
  • 怎么让网站被百度收录seo网上培训
  • wp建站网络营销的定义是什么
  • 收藏网站的链接怎么做多少关键词排名优化软件
  • 辽宁建设工程信息网场内业绩什么意思南京百度关键字优化价格
  • p2p网上贷款网站建设方案.docx深圳互联网公司50强
  • 网站开发包含的项目和分工今日头条搜索优化怎么做
  • 门户网站微信服务号建设方案怎么让百度收录
  • 新乡建设公司网站做个公司网站一般需要多少钱
  • 佛山市建设局网站公司网络营销推广软件
  • 成都 网站设计百度seo怎么优化
  • Spring AMQP如何通过配置文件避免硬编码实现解耦
  • ubuntu 24.04 通过部署ollama提供大模型api接口
  • 剧本杀小程序系统开发:重构推理娱乐生态
  • 解锁AI大模型:Prompt工程全面解析
  • Java使用Apache POI读取Excel文件
  • 考研408《计算机组成原理》复习笔记,第五章(3)——CPU的【数据通路】