1.1 HTTP協議基礎
HTTP(超文本傳輸協議)是Web通信的基礎協議,定義了客戶端和服務器之間交換信息的方式。
關鍵概念:
- 請求方法:GET(獲取資源)、POST(提交數據)、PUT(更新資源)、DELETE(刪除資源)
- 狀態碼:200(成功)、404(未找到)、500(服務器錯誤)、302(重定向)
- 頭部信息:包含元數據如Content-Type、Cookie等
1.2 請求/響應周期
Web交互遵循標準流程:
- 客戶端發送HTTP請求:瀏覽器或應用發起請求
- 服務器解析請求:Web服務器解析請求內容
- 應用處理業務邏輯:框架處理路由、數據庫操作等
- 生成HTTP響應:構建響應頭和內容
- 返回給客戶端:服務器發送響應,客戶端渲染結果
要點:
2.1 WSGI接口
WSGI(Web Server Gateway Interface)是Python Web應用與服務器之間的標準接口。
基礎實現:
def simple_app(environ, start_response):
"""最簡單的WSGI應用"""
status = '200 OK'
headers = [('Content-type', 'text/plain')]
start_response(status, headers)
return [b"Hello World!"]
# 使用wsgiref運行
from wsgiref.simple_server import make_server
httpd = make_server('', 8000, simple_app)
httpd.serve_forever()
關鍵參數:
environ:包含請求信息的字典
start_response:設置響應狀態和頭部的函數
2.2 WSGI中間件
中間件是WSGI應用的包裝器,用于處理請求/響應的預處理和后處理。
class Middleware:
"""WSGI中間件示例"""
def__init__(self, app):
self.app = app
def__call__(self, environ, start_response):
# 預處理 - 日志記錄
print(f"請求路徑: {environ['PATH_INFO']}")
# 調用下層應用
defcustom_start_response(status, headers):
# 后處理 - 添加自定義頭部
headers.append(('X-Middleware', 'Processed'))
return start_response(status, headers)
returnself.app(environ, custom_start_response)
# 包裝應用
wrapped_app = Middleware(simple_app)
中間件常見用途:
3.1 Flask框架
輕量級微框架,適合中小型項目和API開發。
基本應用:
from flask import Flask, request, jsonify
app = Flask(__name__)
@app.route('/')
defhome():
return"<h1>歡迎使用Flask</h1>"
@app.route('/api/data', methods=['GET', 'POST'])
defhandle_data():
if request.method == 'POST':
return jsonify({"status": "成功", "data": request.json})
return jsonify({"values": [1, 2, 3]})
if __name__ == '__main__':
app.run(debug=True)
Flask特點:
3.2 Django框架
全功能框架,遵循"不重復自己"(DRY)原則,適合大型項目。
MTV架構:
快速開始:
# views.py
from django.http import HttpResponse
from django.shortcuts import render
defindex(request):
return HttpResponse("Hello Django")
defuser_view(request, username):
return render(request, 'user.html', {'name': username})
# urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.index),
path('user/<str:username>/', views.user_view)
]
Django特點:
3.3 FastAPI框架
現代異步框架,適合高性能API和實時應用。
基本示例:
from fastapi import FastAPI
from pydantic import BaseModel
app = FastAPI()
classItem(BaseModel):
name: str
price: float
@app.get("/")
asyncdefroot():
return {"message": "Hello FastAPI"}
@app.post("/items/")
asyncdefcreate_item(item: Item):
return {"item": item.dict()}
WebSocket支持:
from fastapi import WebSocket
@app.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket):
await websocket.accept()
while True:
data = await websocket.receive_text()
await websocket.send_text(f"收到: {data}")
FastAPI優勢:
- 高性能(基于Starlette和Pydantic)
4.1 Jinja2語法
Jinja2是Python流行的模板引擎,用于動態生成HTML。
基礎語法:
<!-- base.html -->
<html>
<head><title>{% block title %}{% endblock %}</title></head>
<body>
{% block content %}{% endblock %}
</body>
</html>
<!-- user.html -->
{% extends "base.html" %}
{% block title %}用戶 {{ name }}{% endblock %}
{% block content %}
<h1>歡迎, {{ name }}!</h1>
{% if is_admin %}
<p>您擁有管理員權限</p>
{% endif %}
<ul>
{% for item in items %}
<li>{{ item.name }}: ${{ item.price }}</li>
{% endfor %}
</ul>
{% endblock %}
4.2 模板繼承與渲染
from jinja2 import Environment, FileSystemLoader
# 創建模板環境
env = Environment(loader=FileSystemLoader('templates'))
template = env.get_template('user.html')
# 渲染模板
context = {
'name': '張三',
'is_admin': True,
'items': [
{'name': '筆記本', 'price': 5999},
{'name': '鼠標', 'price': 199}
]
}
output = template.render(context)
print(output)
模板實踐:
Web開發核心要點:
進階學習方向:
掌握Python Web開發技能,我們將能夠構建從簡單博客到復雜企業級應用的各類系統。不斷實踐并參與真實項目是提升技能的最佳途徑!
閱讀原文:原文鏈接
該文章在 2025/7/18 10:54:28 編輯過