天天看點

Python全棧快餐教程(1) - 用Flask處理HTTP請求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傳回一個錯誤頁面