Python全棧快餐教程(1) - 用Flask處理HTTP請求

Python全棧快餐教程(1) - 用Flask處理HTTP請求

初識Flask

Flask是最流行的Python web框架之一。

我們來寫個最小的web應用,只有一個路由先跑進來玩玩吧。

from flask import Flask

# 定義flask app對象
app = Flask(__name__)

# 處理路由
@app.route('/')
def index():
    return "<h1>It works!</h1>"

# 運行起來,這裏可以指定端口和調試屬性等
app.run(port=30000,debug=True)

處理url路徑中的數據

比如要處理http://localhost:30000/code/test,從中獲取test這個字符串,可以這樣寫:

@app.route('/code/<code>')
def complete(code):
    print('Received code:%s' % code)
    return 'Hello, %s' % code

處理post消息

axios出場

要處理post消息的話,首先需要發送post消息,我們選擇在前端來做這事兒吧。前端麼,自然是js語言了,我們配上axios庫。

我們在node.js裏寫一下:

const axios = require('axios');

const instance = axios.create({
  baseURL: 'http://127.0.0.1:30000',
  timeout: 1000});

instance.post('/complete', {code:'#include <iostream>試試中文行不行'})
.then(function (response) {
  console.log('complete: '+response.data);
})
.catch(function (error) {
  console.log(error);
});

處理post數據

其實非常簡單,只要把request的data讀出來就好了。因爲我們從js送過來的是一個字節編碼的json串,所以我們先解碼一下,然後轉成json格式,最後讀取一下相應字段就好了:

@app.route('/complete', methods=['POST'])
def code_complete():
    code = request.data.decode()
    code2 = json.loads(code)
    return 'Hello'+code2.get('code')

一些小trick

  • Windows機器的名字不要用中文,否則flask無法啓動
  • 不要用6666端口,否則Chrome不認
  • POST的消息要處理,否則會報keyError返回一個錯誤頁面
發佈了187 篇原創文章 · 獲贊 128 · 訪問量 34萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章