大白话说Python+Flask入门(一)

发布时间 2023-11-16 21:55:23作者: 久曲健

写在前面

技术这东西就得用,不用就会忘,之前写博客感觉就是给自己记笔记用,还有大部分,估计睡在语雀里都落灰了,哈哈!

在Python领域,我觉得我还是算个小白吧,会写讲不明白,所以我决定想做一件事,先搞下flask这部分教程,看看能给大家说明白吗,真的感觉和Java有很大区别,废话不多说了,开整!

安装依赖

pip install flask

Flask基础入门

1、第一个例子

from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello_world():
    return 'Hello World'

if __name__ == '__main__':
    app.run()

知识点:

app.route(rule, options)

  • rule 参数表示与该函数绑定的URL。
  • options 是要转发给底层Rule对象的参数列表。

app.run(host, port, debug, options)

  • host 监听的主机名。默认为127.0.0.1(localhost)。 设置为'0.0.0.0'使服务器在外部可用
  • port 监听端口号,默认为:5000
  • debug 默认为:false。 如果设置为:true,则提供调试信息
  • options 被转发到底层的Werkzeug服务器。

2、开启调试模式

就和我们说的热部署一样,不用每次你改完后,还需要重新启动服务才能生效

示例代码如下:

app = Flask(__name__)
# 开启调试,修改后就不用每次都重启应用了,相当于我们常见的热部署
# app.debug = True
if __name__ == '__main__':
    app.run('0.0.0.0', '8888',debug=True)

3、路由的设置

两种方式,一种是默认,一种是通过add_url_rule()URL与函数绑定,示例代码如下:

# @app.route('/')
def hello_world():
    return 'hello world'

# 通过add_url_rule()将URL与函数绑定
app.add_url_rule('/hello_world', 'hello_world', hello_world)

通过访问URL :http://localhost:8888/hello_world,就会调用hello_world()函数,这个函数中的执行的结果输出将在浏览器中呈现。

效果如下:

4、参数传递的使用

示例代码:

@app.route('/hello/<name>')
def hello(name):
    return 'hello,' + name


@app.route('/number/<int:postID>')
def show_blog(postID):
    return 'Number %d' % postID


@app.route('/float/<float:revNo>')
def revision(revNo):
    return 'float %f' % revNo

通过访问http://127.0.0.1:8888/float/11.11,在浏览器中可以看到效果

知识点:

  • route('/hello'): route里面放跳转的路径
  • 要传递的参数

5、重定向的使用

示例代码如下:

# -*- coding: utf-8 -*-
# @Time    : 2023/11/16 20:02
# @Author  : longrong.lang
# @FileName: flask_demo.py
# @Software: PyCharm
# @Cnblogs :https://www.cnblogs.com/longronglang
# @Motto:你只管努力,剩下的交给天意.
from flask import Flask, url_for, redirect

app = Flask(__name__)


@app.route('/admin')
def admin():
    return 'hello, admin page'


@app.route('/guest')
def guest():
    return 'hello, guest'


@app.route('/user')
def user():
    return 'hello, user'


@app.route('/hello/<name>')
def hello(name):
    if name == 'admin':
        return redirect(url_for('admin'))
    elif name == 'user':
        return redirect(url_for('user'))
    else:
        return redirect(url_for('guest'))


if __name__ == '__main__':
    app.run(host='0.0.0.0', port=8888, debug=False)

知识点:

url_for('方法名'): 括号里放我们定义的方法,使用url_for后就变成跳转的url

Redirect(url_for('方法名')): 重定向,实现我们页面跳转用的

6、HTTP请求的使用

先搞一个简单的登录,模版页面,示例代码如下:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>login demo</title>
  </head>
  <body>
    <form action="http://localhost:8888/login" method="post">
      username:<input type="text" name="username"><br>
      password:<input type="password" name="password"><br>
      <input type="submit" value="login"><br>
    </form>

  </body>
</html>

逻辑部分,示例代码如下:

# -*- coding: utf-8 -*-
# @Time    : 2023/11/16 20:22
# @Author  : longrong.lang
# @FileName: login_demo.py
# @Software: PyCharm
# @Cnblogs :https://www.cnblogs.com/longronglang
# @Motto:你只管努力,剩下的交给天意.
from flask import Flask, url_for, redirect, request, render_template

app = Flask(__name__)


@app.route('/')
def index():
    return render_template('login.html')


@app.route('/welcome/<name>')
def welcome(name):
    return 'hello, ' + name


@app.route('/error')
def error():
    return 'login fail'


@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        username = request.form['username']
        password = request.form['password']
        if username == 'admin' and password == '1':
            return redirect(url_for('welcome', name=username))
        else:
            return redirect(url_for('error'))


if __name__ == '__main__':
    app.run(host='0.0.0.0', port=8888, debug=False)

效果:

知识点:

render_template('login.html'): render_template它渲染了一个登录页面,就那个很丑的表单啦!

methods=['GET', 'POST']: 就是说这个接口既支持GET 支持POST请求

login.html位置: 必须扔到执行文件的templates文件夹下,要不找不到就报错了

写在最后

个人觉得还是Python代码量少而且方便,要是用Java技术栈的Spring Boot,路由部分还得求助Vue Router中的router-linkrouter push搞定,"前后端分离了",好像更费劲了。

有的同学说了,六哥,你不会用Jsp吗?

现在还有人用Jsp还有吗?评论区见分晓!