????????FlASK是一個輕量級的WSGI Web應用程序框架,Flask的核心包括Werkzeug工具箱和Jinja2模板引擎,它沒有默認使用的數據庫或窗體驗證工具,這意味著用戶可以根據自己的需求選擇不同的數據庫和驗證工具。Flask的設計理念是保持核心簡單,同時提供強大的擴展性,用戶可以通過添加各種擴展來增加功能,如郵件發送、用戶認證、數據庫集成等
????????然后需要囑咐的一個事情,一定要注意代碼格式,Tab制表符和空格一定要區分開
? ? ? ? pip升級命令:python -m pip install --upgrade pip
FlASK框架安裝:
1.軟件版本
Flask要求Python的版本在3.4以上
2.創建一個工作目錄
my_python_flask(使用makdir命令)
3.創建虛擬環境
python -m venv myenv
4.安裝flask框架
pip install flask其他包:
pip install flask-login
pip install flask-openid
pip install flask-mail :為Flask應用程序提供SMTP接口
pip install flask-sqlalchemy :將SQLAlchemy支持添加到Flask應用程序中
pip?install flask-mysqldb :?支持數據庫操作
pip install mysql-connector-python
pip install flask-whooshalchemy
pip install flask-wtf :添加了WTForms的渲染和驗證
pip install flask-babel
pip install guess_language
pip install flipflop
pip install Sijax :使AJAX易于在Web應用程序中使用Python/jQuery庫
?
5.運行.bat文件
????????
6.檢查安裝是否成功
pip freeze
相關依賴解釋:
依賴名稱 | 依賴作用 |
---|---|
Werkzeug | 用于實現WGGI,應用和服務之間的標準Python接口 |
Jinja | 用于渲染頁面的模板語言 |
MarkupSafe 與Jinja共用 | 在渲染頁面時用于避免不可信的輸入,防止注入攻擊 |
ItsDangerous | 保證數據完整性的安全標志數據,用于保護Flask的session cookie |
Click | 一個命令行應用的框架,用于提供flask命令,并允許添加自定義管理命令 |
FlASK框架使用:
1.代碼:
from flask import Flask
app = Flask(__name__)@app.route('/')
def hello_world():return 'Hello, World!'
2.FLASK_APP環境變量
set FLASK_APP=flaskone/main/index.py
3.啟動命令
python -m flask run
4.運行結果:
調試模式:
命令:
set FLASK_ENV=development
flask run --host=0.0.0.0
路由參數以及路由參數強制轉換
@app.route('/user/<username>')
轉換器類型 | 使用 |
---|---|
string字符串類型 | < string:name > |
int整數類型 | < int:name > |
float小數類型 | < float:name > |
path路徑類型 | < path:name > |
代碼:
from flask import Flask
app = Flask(__name__)@app.route('/hello_world/<int:age>')
def hello_world(age):return "獲取的年齡是:%s" % age
運行結果:
Flask URL構建 + 重定向
代碼:
from flask import Flask,redirect,url_for
app = Flask(__name__)
@app.route('/admin')
def hello_admin():return 'Hello Admin'
@app.route('/guest/<guest>')
def hello_guest(guest):return 'Hello %s as Guest' % guest
@app.route('/user/<name>')
def user(name):if name =='admin':return redirect(url_for('hello_admin'))else:return redirect(url_for('hello_guest',guest = name))
if __name__ == '__main__':app.run(debug = True)
輸出結果:
瀏覽器訪問地址:http://127.0.0.1:5000/user/admin
瀏覽器輸出地址:http://127.0.0.1:5000/admin
瀏覽器訪問地址:http://127.0.0.1:5000/user/home
瀏覽器輸出地址:http://127.0.0.1:5000/guest/home
結合代碼看,發現了問題所在沒有?
????????1.重定向的標準函數是:redirect
????????2.定義的函數user,這個函數很說明問題,以后的代碼延伸就是靠這個url_for方法來實現的,至于到底有什么用,相信有經驗的開發者已經看出了,這個方法可以作為一個中間件使用,這點非常重要,一定要重視
HTTP請求
????????在PHP、Golang、Python等等語言中,常用請求的方式無非有以下幾種,這個可以結合前面的url_for來實現Restful風格接口
編號 | 方法 | 描述 |
1 | GET | 將數據以未加密的形式發送到服務器,這最常用的方法。 |
2 | HEAD | 與GET相同,但沒有響應主體 |
3 | POST | 用于將HTML表單數據發送到服務器。通過POST方法接收的數據不會被服務器緩存。 |
4 | PUT | 用上傳的內容替換目標資源的所有當前表示。 |
5 | DELETE | 刪除由URL給出的所有目標資源的所有表示 |
使用方法,定義路由的時候可以定義HTTP請求方法
from flask import Flask,redirect,url_for
app = Flask(__name__)
@app.route('/test',methods=['GET','POST','HEAD','PUT','DELETE'])
def test():return 'echo test'
數據接收:
3.0及以上版本使用
data = request.form.to_dict()
name = data.get('name')
age = data.get('age')
3.0以下版本使用
age = request.agrs.get("age","21")
from flask import Flask, request
app = Flask(__name__)
@app.route("/agrs",methods=['POST'])
def agrs():data = request.form.to_dict()sex = data.get("sex")name = data.get("name")return f"姓名:{name} 性別:{sex}"
if __name__ == '__main__':app.run()
Flask 模板(模板引擎)
????????Jinja2通過render_template()函數渲染HTML文件, Web模板包含用于變量和表達式(這些情況下為Python表達式)的HTML語法散布占位符,這些變量和表達式在模板呈現時被替換為值,模板引擎使用以下分隔符來從HTML轉義
{% ... %} 用于多行語句
{{ ... }} 用于將表達式打印輸出到模板
{# ... #} 用于未包含在模板輸出中的注釋
# ... ## 用于單行語句
注意:路徑示例(.py文件夾和templates一定要在同一級)
from flask import Flask,render_template
app = Flask(__name__)
@app.route('/test')
def test():dic = {"firts":1,"second":2,"thired":3}return render_template('test.html',result=dic)
if __name__ == '__main__':app.run(debug = True)
<!DOCTYPE html>
<html>
<head><title>測試數據</title>
</head>
<body>{% for key, value in result.items() %}<div>keys:<span>{{key}}</span>values:<span>{{value}}</span></div>{% endfor %}
</body>
</html>
訪問地址:127.0.0.1:5000/test
會話處理:
????????所謂的會話,就是客戶端瀏覽器和服務端網站之間一次完整的交互過程。會話的開始是在用戶通過瀏覽器第一次訪問服務端網站開始。會話的結束時在用戶通過關閉瀏覽器以后,與服務端斷開。所謂的會話控制,就是在客戶端瀏覽器和服務端網站之間,進行多次http請求響應之間,記錄、跟蹤和識別用戶的信息而已。
????????在客戶端存儲信息使用Cookie,token[jwt,oauth]
????????在服務器端存儲信息使用Session
COOKIE
語法:response.set_cookie("變量名", "變量值", max_age="有效期幾秒")
from flask import Flask, make_response, request
app = Flask(__name__)@app.route('/set_cookie')
def set_cookie():response = make_response('set_cookie')response.set_cookie('name', 'pure')response.set_cookie('age', '18', max_age=3600)return response@app.route('/get_cookie')
def get_cookie():name = request.cookies.get('name')age = request.cookies.get('age')return "name={name}&age={age}"@app.route("/del_cookie")
def del_cookie():response = make_response("del cookie")response.set_cookie("name","",expires=0)return responseif __name__ == '__main__':app.run(debug = True)
SESSION?
SESSION使用session之前,必須先設置秘鑰
from flask import Flask, session
app = Flask(__name__)class Config(object):SECRET_KEY = "12345678987654321"app.config.from_object(Config)@app.route('/set_session')
def set_session():session["name"] = "pure"session["age"] = 18session["book_list"] = [{"title": "book_name"}, {"title": "book_name"}]return "set_session"@app.route('/get_session')
def get_session():name = session.get("name")age = session.get("age")book_list = session.get("book_list")return "name={name} & age={age} & book_list = {book_list}"@app.route('/del_session')
def del_session():if session.get("name"):del session["name"]return "ok"if __name__ == '__main__':app.run(debug = True)
數據庫
相關包:pip install pymysql
數據庫連接:?
from flask import Flask
import mysql.connectorapp = Flask(__name__)mydb = mysql.connector.connect(host="localhost",user="root",passwd="root",database="test"
)
mycursor = mydb.cursor()mycursor.execute("SELECT * FROM user")myresult = mycursor.fetchall() # fetchall() 獲取所有記錄for x in myresult:print(x)if __name__ == '__main__':app.run()
輸出結果:
使用SQLAlchemy鏈接數據庫
from flask import Flask
from flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)# 數據庫鏈接地址
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:root@127.0.0.1:3306/test'
# 動態追蹤修改設置,如未設置只會提示警告
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = Truedb = SQLAlchemy(app)
class User(db.Model):id = db.Column('id', db.Integer, primary_key = True)username = db.Column(db.String(100))sex = db.Column(db.String(100))age = db.Column(db.Integer)def __init__(self, username, sex, age):self.username = usernameself.sex = sexself.age = age@app.route("/query",methods=['POST','get'])
def query():data = User.query.all()for x in data:print(x)if __name__ == '__main__':app.run()
輸出結果:
????????講到這里,入門課程就已經講完了,剩下的部分需要自己實操去解決問題了,以后小編會繼續撰寫相關文章