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
    评论
Python3 Flask MySQL项目源码通常包含以下几个部分: 1. Flask的主要模块文件:一般为`app.py`或`main.py`,其中包括了对Flask框架的初始化,路由设置、模板渲染、请求处理等相关代码。 2. 数据库配置文件:通常是`config.py`,其中包括了数据库连接信息和一些其他的相关配置参数。 3. 数据库操作模块:一般为`models.py`,其中包括了针对不同表的增删改查等数据库操作函数。 4. 模板文件夹:一般为`templates`,其中包括了Flask应用中使用的HTML网页模板。 5. 静态文件夹:一般为`static`,其中包括了一些静态文件,如CSS、JS脚本和图片等。 6. 其他辅助模块:如`utils.py`,其中包括了一些辅助函数和工具类,如处理日期格式、上传文件等。 在这些模块中,对于Flask应用开发者而言,最重要的部分就是具体的业务逻辑。在开发过程中,需要根据具体的需求,编写路由处理函数、数据库操作函数、辅助函数等。例如,可以编写一个注册新用户的路由处理函数,具体代码如下: ```python from flask import request, jsonify from app import app, db from models import User @app.route('/register', methods=['POST']) def register(): username = request.form.get('username') password = request.form.get('password') email = request.form.get('email') if not all([username, password, email]): return jsonify({'code': 400, 'msg': '缺少必要参数'}) if User.query.filter_by(username=username).first(): return jsonify({'code': 401, 'msg': '用户名已存在'}) user = User(username=username, password=password, email=email) db.session.add(user) db.session.commit() return jsonify({'code': 200, 'msg': '注册成功'}) ``` 上述代码中,首先通过`request`对象获取用户通过表单提交的用户名、密码和邮箱等信息。然后,判断这些参数是否齐全,如果不齐全,则返回一个错误信息。接下来,通过查询数据库判断用户名是否已经存在,如果已经存在,则也返回一个错误信息。最后,创建一个新的用户实例,并将其添加到数据库中,最后返回一个成功的消息。当然,在这个示例中,还有一些安全性和异常处理等问题需要处理,但绝大部分Flask项目也都是由这样的简单的代码块组成的。 总之,Python3 Flask MySQL项目源码是一个很好的学习Flask框架和MySQL数据库的实践资料。借助这个源码,你可以了解一个完整的Web应用的构建过程,并通过实践掌握相关的技能和知识。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值