Python編程在flask中模擬進(jìn)行Restful的CRUD操作
這篇文章中我們將通過對(duì)HelloWorld的message進(jìn)行操作,介紹一下如何使用flask進(jìn)行Restful的CRUD。
概要信息

事前準(zhǔn)備:flask
liumiaocn:flask liumiao$ which flask /usr/local/bin/flask liumiaocn:flask liumiao$ flask --version Flask 1.0.2 Python 2.7.10 (default, Jul 15 2017, 17:16:57) [GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.31)] liumiaocn:flask liumiao$
代碼示例:HTTP謂詞(GET)
就像angular的插值表達(dá)式在模版中的作用一樣,在flask中也可以一樣使用,如果不熟悉angular的插值表達(dá)式的話也不要緊,看完下面的例子,基本上就會(huì)有一個(gè)大致的印象。
代碼示例
liumiaocn:flask liumiao$ cat flask_4.py
#!/usr/bin/python
from flask import Flask
from flask import render_template
app = Flask(__name__)
greeting_messages=["Hello World", "Hello Python"]
@app.route("/api/messages",methods=['GET'])
def get_messages():
return render_template("resttest.html",messages=greeting_messages)
if __name__ == "__main__":
app.debug=True
app.run(host='0.0.0.0',port=7000)
liumiaocn:flask liumiao$
模版文件
liumiaocn:flask liumiao$ cat templates/resttest.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello Restful</title>
</head>
<body>
{% for message in messages %}
<h1>{{ message }}</h1>
{% endfor %}
</body>
</html>
liumiaocn:flask liumiao$
代碼解析:app.route中指定了HTTP謂詞GET,缺省GET可以省略,如果一個(gè)方法對(duì)應(yīng)多個(gè)謂詞動(dòng)作,通過request.method來分離時(shí),可以寫成methods=[‘GET','POST']的形式
執(zhí)行&確認(rèn)
liumiaocn:flask liumiao$ ./flask_4.py * Serving Flask app "flask_4" (lazy loading) * Environment: production WARNING: Do not use the development server in a production environment. Use a production WSGI server instead. * Debug mode: on * Running on http://0.0.0.0:7000/ (Press CTRL+C to quit) * Restarting with stat * Debugger is active! * Debugger PIN: 131-533-062
頁面確認(rèn)

代碼示例:HTTP謂詞(DELETE|PUT|POST)
liumiaocn:flask liumiao$ cat flask_4.py
#!/usr/bin/python
from flask import Flask
from flask import render_template
from flask import request
import json
app = Flask(__name__)
greeting_messages=["Hello World", "Hello Python"]
#HTTP: GET: Retrieve operation
@app.route("/api/messages",methods=['GET'])
def get_messages():
return render_template("resttest.html",messages=greeting_messages)
#HTTP: DELETE: Delete operation
@app.route("/api/messages/<messageid>",methods=['DELETE'])
def delete_message(messageid):
global greeting_messages
del greeting_messages[int(messageid)]
return render_template("resttest.html",messages=greeting_messages)
#HTTP: PUT: Update operation
#HTTP: POST: Create operation
@app.route("/api/messages/<messageid>",methods=['PUT','POST'])
def update_message(messageid):
global greeting_message
msg_info=json.loads(request.get_data(True,True,False))
#msg_info=request.args.get('message_info')
#msg_info=request.form.get('message_info','default value')
#msg_info=request.values.get('message_info','hello...')
greeting_messages.append("Hello " + msg_info["message_info"])
return render_template("resttest.html",messages=greeting_messages)
if __name__ == "__main__":
app.debug=True
app.run(host='0.0.0.0',port=7000)
liumiaocn:flask liumiao$
執(zhí)行&結(jié)果確認(rèn)
執(zhí)行日志
liumiaocn:flask liumiao$ ./flask_4.py * Serving Flask app "flask_4" (lazy loading) * Environment: production WARNING: Do not use the development server in a production environment. Use a production WSGI server instead. * Debug mode: on * Running on http://0.0.0.0:7000/ (Press CTRL+C to quit) * Restarting with stat * Debugger is active! * Debugger PIN: 131-533-062
結(jié)果確認(rèn):Delete
liumiaocn:flask liumiao$ curl -X DELETE http://localhost:7000/api/messages/1 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Hello Restful</title> </head> <body> <h1>Hello World</h1> </body> </html>liumiaocn:flask liumiao$
可以看到執(zhí)行一次DELETE之后,兩條消息現(xiàn)在只剩下一條消息了,接下來使用POST添加再添加一條
liumiaocn:flask liumiao$ curl -X POST -d '{"message_info":"LiuMiaoPost"}' http://localhost:7000/api/messages/3
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello Restful</title>
</head>
<body>
<h1>Hello World</h1>
<h1>Hello LiuMiaoPost</h1>
</body>
</html>liumiaocn:flask liumiao$
再執(zhí)行一次PUT操作
liumiaocn:flask liumiao$ curl -X PUT -d '{"message_info":"LiuMiaoPut"}' http://localhost:7000/api/messages/4
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello Restful</title>
</head>
<body>
<h1>Hello World</h1>
<h1>Hello LiuMiaoPost</h1>
<h1>Hello LiuMiaoPut</h1>
</body>
</html>liumiaocn:flask liumiao$
小結(jié)
這篇文章中,使用最簡(jiǎn)單的方式在flask中模擬了一下如何進(jìn)行Restful的CRUD操作,當(dāng)然,實(shí)際的做法有很多種,在接下來的文章中還會(huì)介紹另外一種非常常見的輪子flask-restful.
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- python使用 request 發(fā)送表單數(shù)據(jù)操作示例
- Python mutiprocessing多線程池pool操作示例
- python3+requests接口自動(dòng)化session操作方法
- Python讀取properties配置文件操作示例
- Python中用psycopg2模塊操作PostgreSQL方法
- 使用Python對(duì)Access讀寫操作
- Python操作Access數(shù)據(jù)庫基本步驟分析
- python進(jìn)程類subprocess的一些操作方法例子
- Python使用PyGreSQL操作PostgreSQL數(shù)據(jù)庫教程
- 基于python操作ES實(shí)例詳解
相關(guān)文章
Python中l(wèi)ogging日志記錄到文件及自動(dòng)分割的操作代碼
這篇文章主要介紹了Python中l(wèi)ogging日志記錄到文件及自動(dòng)分割,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
python requests抓取one推送文字和圖片代碼實(shí)例
這篇文章主要介紹了python requests抓取one推送文字和圖片代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
python神經(jīng)網(wǎng)絡(luò)slim常用函數(shù)訓(xùn)練保存模型
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)使用slim函數(shù)進(jìn)行模型的訓(xùn)練及保存模型示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
python發(fā)送多人郵件沒有展示收件人問題的解決方法
這篇文章主要為大家詳細(xì)介紹了python發(fā)送多人郵件沒有展示收件人問題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
Python正則表達(dá)式re.findall()幾種方法示例
這篇文章主要介紹了Python正則表達(dá)式re.findall()幾種方法示例,文中介紹了如何使用正則表達(dá)式在字符串中查找匹配的字符,并將它們返回為一個(gè)列表,示例展示了如何匹配數(shù)字并處理沒有匹配到的情況,需要的朋友可以參考下2024-12-12
Python中的數(shù)據(jù)標(biāo)準(zhǔn)化與反標(biāo)準(zhǔn)化全面指南
在數(shù)據(jù)處理和機(jī)器學(xué)習(xí)中,數(shù)據(jù)標(biāo)準(zhǔn)化是一項(xiàng)至關(guān)重要的預(yù)處理步驟,標(biāo)準(zhǔn)化能夠?qū)⒉煌叨群头秶臄?shù)據(jù)轉(zhuǎn)換為相同的標(biāo)準(zhǔn),有助于提高模型的性能和穩(wěn)定性,Python提供了多種庫和函數(shù)來執(zhí)行數(shù)據(jù)標(biāo)準(zhǔn)化和反標(biāo)準(zhǔn)化,如Scikit-learn和TensorFlow2024-01-01

