大白話說Python+Flask入門(一)

寫在前面

技術這東西就得用,不用就會忘,之前寫博客感覺就是給自己記筆記用,還有大部分,估計睡在語雀裏都落灰了,哈哈!

在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還有嗎?評論區見分曉!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章