python3+flask 开发web(一)

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

  • 9
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值