python3+flask 开发web(一)
发表时间:2018-10-25
发布人:葵宇科技
浏览次数:66
1、环境准备
1)安装Python:https://www.python.org/
2)安装python ide,pycharm:https://www.jetbrains.com/pycharm/
3)安装flask:安装好了python,电脑就自动安装了pip,在cmd中执行命令:pip install flask
2、写代码:
1)helloword:
from flask import Flask
app = Flask(__name__) #创建一个wsgi应用
@app.route('/') #添加路由:根
def hello_world():
return 'Hello World!' #输出一个字符串
if __name__ == '__main__':
app.run(debug=True) #启动app的调试模式
?
执行后:
在浏览器的地址栏打开:http://127.0.0.1:50000/这个url,显示如下:
本例中app是Flask类的一个实例,在实例化过程中传递了一个参数name,Flask通过这个参数识别app是模块级别还是包级别的。实际上app符合相关接口,它是一个WSGI应用。
有了app对象以后,它就成为了一个中心节点,把所有的URL规则、视图函数、模板配置等连接起来,最终形成一个Web应用。
使用@app.route修饰函数创建一个URL规则,直接在被修饰的函数中写出处理该URL要做的事情。使用过PHP、ASP的童鞋可能刚开始不习惯这种URL命名规则,因为最早使用脚本开发Web应用的时候,一个文件就会对应一个URL。
2)字符串
?
from flask import Flask
app=Flask(__name__)
@app.route('/')
def hello_word():
return '<h1>Hello Word!</h1>'
if __name__=='__main__':
app.run(debug=True)
?
执行结果:
3)json
?
?
?
from flask import Flask
import json
app=Flask(__name__)
@app.route('/json')
def do_json():
hello = {"name":"stranger", "say":"hello"}
return json.dumps(hello)
if __name__=='__main__':
app.run(debug=True)
?
?
?
执行结果;
4)http状态码:
?
?
?
?
from flask import Flask
import json
app=Flask(__name__)
@app.route('/status_500')
def status_500():
return "hello", 500
if __name__=='__main__':
app.run(debug=True)
?
?
?
?
执行结果:
5)http头:
from flask import Flask
from flask import make_response
app=Flask(__name__)
@app.route('/set_header')
def set_header():
resp=make_response('<h1>This document has a modified header!</h1>')
resp.headers['X-Something']='A value'
resp.headers['Server']='My special http server'
return resp
if __name__=='__main__':
app.run(debug=True)
?
?
?
?
?
执行结果:
6)cookie:
什么是cookie:
什么是cookie?如果单单从数据结构的角度来说,它可以被理解成用来保存数据的一个dictionary,由一组组键值对组成.如果从作用上来说,我们知道Http协议是一种无状态的协议.什么叫无状态呢,就是本次的客户端请求不会保留上一次客户端请求的状态,简单点说就是这样会要求我们每次在浏览器中点开一个网站的链接都会输一次账户和密码.cookie就是用来解决这个问题的.
为了解决上述问题,我们第一次登录web服务器,服务端就会在它的响应中的Set-Cookie字段中发送一些键值对,这就包括一个Session ID以及其他一些信息(也包括我们自定义的cookie中的键值对),并告诉客户端在本地缓存这个cookie.然后客户端以后进行链接时每次都会发送这个Session ID,服务器一看是哪个Session ID就知道是哪个客户端发起的链接了,就不会要求我们再次输账户和密码验证了.
我们在flask中自定义cookie,实际上就是在响应Response的Set-Cookie字段中增加我们自定义的键值对.而获取cookie,就是通过请求Request中通过键获取其对应的值.
(1)设置cookie和获取cookie
from flask import Flask
from flask import make_response
import datetime
from flask import request
app=Flask(__name__)
@app.route('/set_cookie') #设置cookie
def set_cookie():
response=make_response('<h1>This document carries a cookie!</h1>')
outdate=datetime.datetime.today()+datetime.timedelta(days=30) #cookie的有效时长30天
response.set_cookie('username','evancss',expires=outdate)
return response
@app.route('/get_cookie') #获取cookie
def get_cookie():
name=request.cookies.get('username')
return name
if __name__=='__main__':
app.run(debug=True)
执行结果:
set_cookie
get_cookie
注意cookie的时效性:我们在浏览器上设置cookie的有效时长优先级要高于我们在代码中设置的
(2)删除cookie常用的方法:
1可以通过在浏览器中设置来清除cookie.
2使用Response的set_cookie进行清除
@app.route('/del_cookie')
def del_cookie():
response=make_response('delete cookie')
response.set_cookie('username','',expires=0)
return response
3使用Response的 delete_cookie方法.
def del_cookie2():
response=make_response('delete cookie2')
response.delete_cookie('username')
return response
7)重定向:
?
?
?
from flask import Flask
from flask import redirect
app=Flask(__name__)
@app.route('/redir')
def redir():
return redirect('https://www.baidu.com')
if __name__=='__main__':
app.run(debug=True)
?
?
?
?
执行结果:
用fiddler抓包看看:
8)abort:
?
?
?
from flask import Flask
from flask import abort
app=Flask(__name__)
@app.route('/user/<id>')
def get_user(id):
if int(id)>10:
abort(404)
return '<h1>Hello,%s</h1>'%id
if __name__=='__main__':
app.run(debug=True)
?
?
?
?
执行结果:
id=22
id=2
遇到的问题:新建项目的选择解释器和location的时候注意一下
参考博文:https://blog.csdn.net/langkew/article/details/51594880