url详解:
URL是Uniform Resource Locator的简写,统一资源定位符。
一个URL由以下几部分组成:
scheme://host:port/path/?query-string=xxx#anchor
- scheme:代表的是访问的协议,一般为http或者https以及ftp等。
- host:主机名,域名,比如www.baidu.com。
- port:端口号。当你访问一个网站的时候,浏览器默认使用80端口。
- path:查找路径。比如:www.jianshu.com/trending/now,后面的trending/now就是path。
- query-string:查询字符串,比如:www.baidu.com/s?wd=python,后面的wd=python就是查询字符串。
- anchor:锚点,后台一般不用管,前端用来做页面定位的。比如:https://baike.baidu.com/
web服务器和应用服务器以及web应用框架:
web服务器:
负责处理http请求,响应静态文件,常见的有Apache,Nginx以及微软的IIS.
应用服务器:
负责处理逻辑的服务器。比如php、python的代码,是不能直接通过nginx这种web服务器来处理的,只能通过应用服务器来处理,常见的应用服务器有uwsgi、tomcat等。
web应用框架:
一般使用某种语言,封装了常用的web功能的框架就是web应用框架,flask、Django以及Java中的SSH(Structs2+Spring3+Hibernate3)框架都是web应用框架。

DEBUG模式:
为什么需要开启DEBUG模式:
- 如果开启了DEBUG模式,那么在代码中如果抛出了异常,在浏览器的页面中可以看到具体的错误信息,以及具体的错误代码位置。方便开发者调试。
- 如果开启了DEBUG模式,那么以后在
Python
代码中修改了任何代码,只要按ctrl+s
,flask
就会自动的重新记载整个网站。不需要手动点击重新运行。
配置DEBUG模式的四种方式:
- 在
app.run()
中传递一个参数debug=True
就可以开启DEBUG
模式。 - 给
app.deubg=True
也可以开启debug
模式。 - 通过配置参数的形式设置DEBUG模式:
app.config.update(DEBUG=True)
。 - 通过配置文件的形式设置DEBUG模式:
app.config.from_object(config)
。 - 通过配置文件的形式设置DEBUG模式:
app.config.from_pyfile('config.py')
。
经过测试,以上方法不管用,这是因为在flask的执行文件里,没有打开debug模式,打开了配置文件的debug模式,不通过上面5种方法一样可以进入debug,打开方式如下:

PIN码:
如果想要在网页上调试代码,那么应该输入PIN
码。
config笔记:
使用app.config.from_object
的方式加载配置文件:
- 导入
import config
。 - 使用
app.config.from_object(config)
。
使用app.config.from_pyfile
的方式加载配置文件:
这种方式不需要import
,直接使用app.config.from_pyfile('config.py')
就可以了。
注意这个地方,必须要写文件的全名,后缀名不能少。
- 这种方式,加载配置文件,不局限于只能使用
py
文件,普通的txt
文件同样也适合。 - 这种方式,可以传递
silent=True
,那么这个静态文件没有找到的时候,不会抛出异常。
URL必会的小细节知识点:
在局域网中让其他电脑访问我的网站:
如果想在同一个局域网下的其他电脑访问自己电脑上的Flask网站,
那么可以设置host='0.0.0.0'
才能访问得到。
指定端口号:
Flask项目,默认使用5000
端口。如果想更换端口,那么可以设置port=9000
。
url唯一:
在定义url的时候,一定要记得在最后加一个斜杠。
- 如果不加斜杠,那么在浏览器中访问这个url的时候,如果最后加了斜杠,那么就访问不到。这样用户体验不太好。
- 搜索引擎会将不加斜杠的和加斜杠的视为两个不同的url。而其实加和不加斜杠的都是同一个url,那么就会给搜索引擎造成一个误解。加了斜杠,就不会出现没有斜杠的情况。
GET
请求和POST
请求:
在网络请求中有许多请求方式,比如:GET、POST、DELETE、PUT请求等。那么最常用的就是GET
和POST
请求了。
-
GET
请求:只会在服务器上获取资源,不会更改服务器的状态。这种请求方式推荐使用GET
请求。 -
POST
请求:会给服务器提交一些数据或者文件。一般POST请求是会对服务器的状态产生影响,那么这种请求推荐使用POST请求。 -
关于参数传递:
-
GET
请求:把参数放到url
中,通过?xx=xxx
的形式传递的。因为会把参数放到url中,所以如果视力好,一眼就能看到你传递给服务器的参数。这样不太安全。 -
POST
请求:把参数放到Form Data
中。会把参数放到Form Data
中,避免了被偷瞄的风险,但是如果别人想要偷看你的密码,那么其实可以通过抓包的形式。因为POST请求可以提交一些数据给服务器,比如可以发送文件,那么这就增加了很大的风险。所以POST请求,对于那些有经验的黑客来讲,其实是更不安全的。
-
-
在
Flask
中,route
方法,默认将只能使用GET
的方式请求这个url,如果想要设置自己的请求方式,那么应该传递一个methods
参数。
url_for笔记:
url_for
的基本使用:
url_for
第一个参数,应该是视图函数的名字的字符串。后面的参数就是传递给url
。
如果传递的参数之前在url
中已经定义了,那么这个参数就会被当成path
的形式给
url
。如果这个参数之前没有在url
中定义,那么将变成查询字符串的形式放到url
中。
@app.route('/post/list/<page>/')
def my_list(page):
return 'my list'
print(url_for('my_list',page=1,count=2))
# 构建出来的url:/my_list/1/?count=2
为什么需要url_for
:
- 将来如果修改了
URL
,但没有修改该URL对应的函数名,就不用到处去替换URL了。 -
url_for
会自动的处理那些特殊的字符,不需要手动去处理。url = url_for('login',next='/') # 会自动的将/编码,不需要手动去处理。 # url=/login/?next=%2F
强烈建议以后在使用url的时候,使用url_for
来反转url。
自定义URL转换器:
自定义URL转换器的方式:
- 实现一个类,继承自
BaseConverter
。 - 在自定义的类中,重写
regex
,也就是这个变量的正则表达式。 - 将自定义的类,映射到
app.url_map.converters
上。比如:app.url_map.converters['tel'] = TelephoneConverter
to_python
的作用:
这个方法的返回值,将会传递到view函数中作为参数。
to_url
的作用:
这个方法的返回值,将会在调用url_for函数的时候生成符合要求的URL形式。
网友评论