从零开始搭建 flask 博客(1)实验

🧱 一、项目结构

最终项目目录如下:

复制代码
flask_blog/
├── app/
│   ├── __init__.py
│   ├── routes.py
│   └── templates/
│       ├── base.html
│       └── index.html
└── myblog.py

⚙️ 二、环境配置

1. 创建虚拟环境

复制代码
# 创建并激活虚拟环境
python -m venv venv
source venv/bin/activate       # macOS / Linux
venv\Scripts\activate          # Windows

2. 安装 Flask

pip install flask


🧩 三、项目代码

app/init.py

复制代码
from flask import Flask

app = Flask(__name__)

# 注意:这里导入 routes,是为了注册路由
from app import routes

app/routes.py

复制代码
from flask import render_template
from app import app

@app.route('/')
@app.route('/index')
def index():
    user = {'username': 'duke'}
    posts = [
        {'author': {'username': '刘'}, 'body': '这是模板模块中的循环例子~1'},
        {'author': {'username': '忠强'}, 'body': '这是模板模块中的循环例子~2'}
    ]
    return render_template('index.html', title='我的博客', user=user, posts=posts)

app/templates/base.html

复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    {% if title %}
        <title>{{ title }} - 博客</title>
    {% else %}
        <title>欢迎来到博客!</title>
    {% endif %}
</head>
<body>
    <div>
        <h1>我的 Flask 博客</h1>
        <hr>
        {% block content %}{% endblock %}
    </div>
</body>
</html>

app/templates/index.html

复制代码
{% extends "base.html" %}
{% block content %}
    <h2>你好呀, {{ user.username }}!</h2>
    {% for post in posts %}
        <div>
            <p><b>{{ post.author.username }}</b> 说: {{ post.body }}</p>
        </div>
    {% endfor %}
{% endblock %}

myblog.py

复制代码
from app import app

if __name__ == '__main__':
    app.run(debug=True)

🚀 四、运行项目

1️⃣ 在项目根目录下设置环境变量

复制代码
export FLASK_APP=myblog.py       # macOS / Linux
set FLASK_APP=myblog.py          # Windows

2️⃣ 启动 Flask 服务器

flask run

3️⃣ 打开浏览器访问:

http://127.0.0.1:5000/

相关推荐
程序员清风4 小时前
北京回长沙了,简单谈谈感受!
java·后端·面试
何中应4 小时前
请求头设置没有生效
java·后端
NPE~4 小时前
自动化工具Drissonpage 保姆级教程(含xpath语法)
运维·后端·爬虫·自动化·网络爬虫·xpath·浏览器自动化
极客小云4 小时前
【ComfyUI API 自动化利器:comfyui_xy Python 库使用详解】
网络·python·自动化·comfyui
闲人编程4 小时前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
痴儿哈哈4 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
Hello.Reader4 小时前
Flink 对接 Azure Blob Storage / ADLS Gen2:wasb:// 与 abfs://(读写、Checkpoint、插件与认证)
flink·flask·azure
宋小黑4 小时前
JDK 6到25 全版本网盘合集 (Windows + Mac + Linux)
java·后端
花酒锄作田4 小时前
SQLAlchemy中使用UPSERT
python·sqlalchemy
SoleMotive.5 小时前
一个准程序员的健身日志:用算法调试我的增肌计划
python·程序员·健身·职业转型