百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

使用 Python、FastHTML 和 Uvicorn 构建简单的博客网站

yund56 2025-05-12 16:42 18 浏览


FastHTML 是2024 年 7 月推出的 Python Web 框架,是一个简单但功能强大的框架,允许开发人员使用纯 Python 构建 Web 应用程序。 (不需要复杂的模板引擎)。 FastHTML 轻量级且易于使用,使其成为博客网站等小型项目的绝佳选择。本文将构建一个非常简单的博客应用程序,允许用户创建和查看博客文章,使用 FastHTML 和 SQLite 作为后端,并使用 Uvicorn 在http://127.0.0.1:8000本地运行该应用程序。

项目概况

  1. 设置虚拟环境。
  2. 设置项目结构。
  3. 设置 SQLite 数据库。
  4. 定义博客文章模型和模板。
  5. 编写 FastHTML 应用程序。
  6. 使用 Uvicorn 运行应用程序。

第 1 步:设置虚拟环境

第一步是创建虚拟环境来隔离项目的依赖关系。

创建项目目录

mkdir fasthtml_blog
cd fasthtml_blog

创建虚拟环境

  • 在 macOS/Linux 上:
python3 -m venv venv
  • 在 Windows 上:
python -m venv venv

激活虚拟环境

  • 在 macOS/Linux 上:
source venv/bin/activate
  • 在 Windows 上:
venv\Scripts\activate

激活虚拟环境后,现在就可以安装必要的软件包了。

pip install python-fasthtml uvicorn

第 2 步:设置项目结构

接下来,将为博客应用程序创建目结构。需要一个app/目录来保存应用程序文件和一个 SQLite 数据库文件来存储博客文章。可以使用Python脚本自动生成所需的目录和文件。

用于创建项目结构的 Python 脚本

创建一个名为 create_directory.py 的文件并添加以下代码。

# static file | create_directory.py
import os

# Define the structure
directories = [
    'app'
]

files = [
    'app/__init__.py',
    'app/main.py',
    'app/models.py',
    'app/templates.py',
    'app/database.py'
]

# Create directories
for directory in directories:
    os.makedirs(directory, exist_ok=True)

# Create empty files
for file in files:
    with open(file, 'w') as f:
        pass

print("Directories and files created successfully.")

运行此脚本以设置项目结构。它将创建必要的目录和空文件( main.pymodels.pytemplates.py 、 database_py 和__init__.py )。

项目现在应该如下所示:

fasthtml_blog/
│
├── app/
│   ├── __init__.py
│   ├── database.py
│   ├── main.py
│   ├── models.py
│   ├── templates.py
└── venv/
└── create_directory.py

第 3 步:设置 SQLite 数据库

现在,设置 SQLite 数据库来存储博客文章。我在app/目录中创建一个database.py文件,用于管理与 SQLite 数据库的连接并创建必要的表。

app/database.py

import sqlite3
from contextlib import contextmanager

DATABASE_NAME = 'blog.db'

def create_tables():
    with sqlite3.connect(DATABASE_NAME) as conn:
        conn.execute('''
            CREATE TABLE IF NOT EXISTS blog_posts (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                title TEXT NOT NULL,
                content TEXT NOT NULL
            )
        ''')

@contextmanager
def get_db():
    conn = sqlite3.connect(DATABASE_NAME)
    try:
        yield conn
    finally:
        conn.commit()
        conn.close()
  • create_tables()创建blog_posts表(如果尚不存在)。
  • get_db()是一个上下文管理器,提供与 SQLite 数据库的连接。

第 4 步:定义博客文章模型和模板

现在数据库已经设置完毕,需要一个模型来表示博客文章和与数据库交互的函数。在models.py文件中,将定义一个BlogPost类和函数来获取所有帖子并创建新帖子。

app/models.py

from app.database import get_db

class BlogPost:
    def __init__(self, id: int, title: str, content: str):
        self.id = id
        self.title = title
        self.content = content

def get_all_posts():
    with get_db() as conn:
        cursor = conn.execute('SELECT id, title, content FROM blog_posts')
        rows = cursor.fetchall()
        return [BlogPost(id=row[0], title=row[1], content=row[2]) for row in rows]

def create_post(title: str, content: str):
    with get_db() as conn:
        conn.execute('INSERT INTO blog_posts (title, content) VALUES (?, ?)', (title, content))
  • get_all_posts()从数据库中获取所有博客文章。
  • create_post()将新博客文章插入数据库。

Python 中的 HTML 模板

接下来,将创建两个用于呈现博客文章列表的基本模板和一个用于创建新文章的表单。这些将在templates.py文件中定义。

app/templates.py

def blog_list_template(posts):
    return f"""
    
        
        
            All Blog Posts
            
                {''.join([f'{post.title}' for post in posts])}
            
            Create a new post
        
    
    """

def create_post_template():
    return """
    
        
        
            Create a New Blog Post
            

Title:

Content:

Back to posts """

  • blog_list_template()呈现所有博客文章的列表。
  • create_post_template()提供了一个用于创建新博客文章的表单。

第 5 步:编写 FastHTML 应用程序

现在,将在main.py文件中将所有内容联系在一起。这是定义路由和处理请求的地方。

app/main.py

from fasthtml import FastHTML
from app.templates import blog_list_template, create_post_template
from app.models import get_all_posts, create_post
from app.database import create_tables

app = FastHTML()

# Create the database tables before starting the app
create_tables()

@app.route("/")
def index():
    posts = get_all_posts()
    return blog_list_template(posts)

@app.route("/create", methods=["GET"])
def create_post_get():
    return create_post_template()

# Define this as an async function to handle form data properly
@app.route("/create", methods=["POST"])
async def create_post_post(request):
    form_data = await request.form()  # Await for the form data
    title = form_data.get("title")
    content = form_data.get("content")
    create_post(title, content)
    return f"Post '{title}' created! Go back"

该文件定义了三个主要路由:

  1. GET / :显示所有博客文章的列表。
  2. GET /create :显示用于创建新博客文章的表单。
  3. POST /create :处理表单提交以创建新帖子。

第 6 步:使用 Uvicorn 运行应用程序

FastHTML 不会自动启动服务器。相反,将使用Uvicorn (一个 ASGI 服务器)来为应用程序提供服务。

运行应用程序

要使用 Uvicorn 运行应用程序,请使用以下命令:

uvicorn app.main:app --reload

第 7 步:测试博客网站

  1. 查看所有帖子:导航至http://127.0.0.1:8000/查看博客帖子列表。
  2. 创建新帖子:转到http://127.0.0.1:8000/create添加新博客帖子。提交表单后,将被重定向并显示成功消息。

要在使用 Uvicorn 运行 FastHTML 应用程序时更改默认的8000端口号,可以使用 Uvicorn 命令中的--port选项指定所需的端口。

例如,如果想在端口5000而不是8000上运行应用程序,您可以使用以下命令:

uvicorn app.main:app --reload --port 5000

在此命令中:

  • --port 5000将端口设置为5000 (或您喜欢的任何其他端口号)。

完整命令细分:

  • app.main:app :这将 Uvicorn 指向app/目录中main.py文件中的app对象。
  • --reload :每当您进行代码更改时,这都会自动重新加载服务器。
  • --port 5000 :指定运行应用程序的端口号。

可以将5000替换为您希望应用程序运行的任何其他端口号。运行此命令后,您的应用程序将可以通过http://127.0.0.1:5000/ (或您指定的端口)访问。

相关推荐

SM小分队Girls on Top,女神战队少了f(x)?

这次由SM娱乐公司在冬季即将开演的smtown里,将公司的所有女团成员集结成了一个小分队project。第一位这是全面ACE的大姐成员权宝儿(BoA),出道二十年,在日本单人销量过千万,韩国国内200...

韩国女团 aespa 首场 VR 演唱会或暗示 Quest 3 将于 10 月推出

AmazeVR宣布将在十月份举办一场现场VR音乐会,观众将佩戴MetaQuest3进行体验。韩国女团aespa于2020年11月出道,此后在日本推出了三张金唱片,在韩国推出了...

韩网热议!女团aespa成员Giselle在长腿爱豆中真的是legend

身高163的Giselle,长腿傲人,身材比例绝了...

假唱而被骂爆的女团:IVE、NewJeans、aespa上榜

在韩国,其实K-pop偶像并不被认为是真正的歌手,因为偶像们必须兼备舞蹈能力、也经常透过对嘴来完成舞台。由于科技的日渐发达,也有许多网友会利用消音软体来验证K-pop偶像到底有没有开麦唱歌,导致假唱这...

新女团Aespa登时尚大片 四个少女四种style

来源:环球网

韩国女团aespa新歌MV曝光 画面梦幻造型超美

12月20日,韩国女团aespa翻唱曲《DreamsComeTrue》MV公开,视频中,她们的造型超美!WINTER背后长出一双梦幻般的翅膀。柳智敏笑容甜美。宁艺卓皮肤白皙。GISELLE五官精致...

女网友向拳头维权,自称是萨勒芬妮的原型?某韩国女团抄袭KDA

女英雄萨勒芬妮(Seraphine)是拳头在2020年推出的第五位新英雄,在还没有正式上线时就备受lsp玩家的关注,因为她实在是太可爱了。和其他新英雄不同的是,萨勒芬妮在没上线时就被拳头当成虚拟偶像来...

人气TOP女团是?INS粉丝数见分晓;TWICE成员为何在演唱会落泪?

现在的人气TOP女团是?INS粉丝数见分晓!现在爱豆和粉丝之间的交流方法变得多种多样,但是Instagram依然是主要的交流手段。很多粉丝根据粉丝数评价偶像的人气,拥有数百、数千万粉丝的组合作为全球偶...

韩国女团MVaespa Drama MV_韩国女团穿超短裙子跳舞

WelcometoDrama.Pleasefollow4ruleswhilewatchingtheDrama.·1)Lookbackimmediatelywhenyoufe...

aespa师妹团今年将出道! SM职员亲口曝「新女团风格、人数」

记者刘宛欣/综合报导南韩造星工厂SM娱乐曾打造出东方神起、SUPERJUNIOR、少女时代、SHINee、EXO等传奇团体,近年推出的aespa、RIIZE更是双双成为新生代一线团体,深受大众与粉丝...

南韩最活跃的女团aespa,新专辑《Girls》即将发布,盘点昔日经典

女团aespa歌曲盘点,新专辑《Girls》即将发布,期待大火。明天也就是2022年的7月8号,aespa新专辑《Girls》即将发行。这是继首张专辑《Savage》之后,时隔19个月的第二张专辑,这...

章泽天女团aespa出席戛纳晚宴 宋康昊携新片亮相

搜狐娱乐讯(山今/文玄反影/图科明/视频)法国时间5月23日晚,女团aespa、宋康昊、章泽天等明星亮相戛纳晚宴。章泽天身姿优越。章泽天肩颈线优越。章泽天双臂纤细。章泽天仪态端正。女团aespa亮...

Aespa舞台暴露身高比例,宁艺卓脸大,柳智敏有“TOP”相

作为SM公司最新女团aespa,初舞台《BlackMamba》公开,在初舞台里,看得出来SM公司是下了大功夫的,虽然之前SM公司新出的女团都有很长的先导片,但是aespa显然是有“特殊待遇”。运用了...

AESPA女团成员柳智敏karina大美女

真队内速度最快最火达成队内首个且唯一两百万点赞五代男女团中输断层第一(图转自微博)...

对来学校演出的女团成员语言性骚扰?韩国这所男高的学生恶心透了

哕了……本月4日,景福男子高中相关人士称已经找到了在SNS中上传对aespa成员进行性骚扰文章的学生,并开始着手调查。2日,SM娱乐创始人李秀满的母校——景福高中迎来了建校101周年庆典活动。当天,S...