使用fastapi部署网页模板

news/2025/3/14 22:12:27/文章来源:https://www.cnblogs.com/codedingzhen/p/18772982

背景

如果你想快速实现一个网站的前后端的部署,那么现成的站点模板是必须的,如果我们使用nginx做反向代理可以实现部署静态网站,如果我想相对请求或者页面有一些更新,那么就需要用到后端框架,这里我们使用fastapi去代理静态资源同时将模板的请求根据我们的需求进行动态的返回,可以在网站的模板上进行修改,这样是最快速的建站方式,用fastapi做后台管理

首先是网站的克隆

网站克隆有很多开源的工具,参考我之前的博客,我使用的是Httrack去克隆,这个软件可以完整的克隆站点的所有链接和资源,实现本地化的站点。
然后我们用fastapi去部署,将我们需要自定义的路由去做修改,静态资源部分直接拿文件资源就可以
区别于下载的网站模板,克隆的网站模板很乱,所以不会很严格的按照资源assest。static。img这样去分类,里面只有相对路径。

这是我clone的一整个站点的目录
image
image
可以看到里面的资源是很乱的,但是在本地是完全可以离线运行的。

实现过程

fastapi文件结构
image
主要是main部分,这一块对静态资源进行分类,防止跳转404,写一个兜底的默认路由,主要是拿静态文件,别的数据库可以没有
核心代码

from fastapi.responses import HTMLResponse, RedirectResponse, FileResponse
from jinja2 import Environment, FileSystemLoader
from fastapi import FastAPI, Request, HTTPException
from typing import Union
import logging
import os
current_dir=os.path.dirname(os.path.abspath(__file__))
logging.basicConfig(level=logging.INFO)
app = FastAPI()# 设置 Jinja2 模板环境
templates = Environment(loader=FileSystemLoader("templates"))# 定义一个类型,用于匹配任何路径
AnyPath = Union[str, int]@app.get("/", response_class=HTMLResponse)
async def read_root(request: Request):return templates.get_template("index.html").render()@app.get("/labs", response_class=HTMLResponse)
async def read_labs(request: Request):logging.info(f"Request path: {request.url.path}")return templates.get_template("seedlab/index.html").render()@app.get("/books", response_class=HTMLResponse)
async def read_books(request: Request):return templates.get_template("books.html").render()@app.get("/lectures", response_class=HTMLResponse)
async def read_lectures(request: Request):return templates.get_template("lectures.html").render()@app.get("/emulator", response_class=HTMLResponse)
async def read_emulator(request: Request):return templates.get_template("emulator.html").render()@app.get("/contact", response_class=HTMLResponse)
async def read_contact(request: Request):return templates.get_template("contact.html").render()@app.get("/news", response_class=HTMLResponse)
async def read_news(request: Request):return templates.get_template("news.html").render()# 定义一个兜底路由来处理所有未明确定义的路径
@app.get("/{any_path:path}")
async def catch_all(any_path: str):print("path",any_path)# 获取文件扩展名_, ext = os.path.splitext(any_path)media_type = get_media_type(ext)if media_type=="text/html":try:# 尝试根据路径渲染模板template=templates.get_template(f"seedlab/{any_path}").render()return HTMLResponse(content=template)except Exception as e:# 如果模板不存在,返回 404 错误raise HTTPException(status_code=404, detail="Page not found")else:return FileResponse(os.path.join(current_dir,f"templates/seedlab/{any_path}"), media_type=media_type)# 如果文件和模板都不存在,返回 404 错误raise HTTPException(status_code=404, detail="Page not found")def get_media_type(ext: str):"""根据文件扩展名返回对应的媒体类型"""media_types = {'.html': 'text/html','.htm': 'text/html','.css': 'text/css','.js': 'application/javascript','.json': 'application/json','.jpg': 'image/jpeg','.jpeg': 'image/jpeg','.png': 'image/png','.gif': 'image/gif','.svg': 'image/svg+xml','.ico': 'image/x-icon','.ttf': 'font/ttf','.woff': 'font/woff','.woff2': 'font/woff2',}return media_types.get(ext, 'application/octet-stream')

一定要注意,FileResponse为绝对路径

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/898897.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第四周第五天

所用时间:270分钟 代码量(行):174 博客量(篇):1 了解到的知识点: 1.课堂测试 编写了简单的地铁购票系统app,实现了按站计算购票费用,将项目打包为apk后再手机端运行成功 学习了如何将项目打包为apk文件,如下图所示2.计算机网络

Apache Tomcat RCE漏洞复现(CVE-2025-24813)

今日官方披露 Apache Tomcat partial PUT文件上传反序列化漏洞。在 CVE-2025-24813 中tomcat开启文件会话持久化,攻击者可利用PUT上传文件,并构造恶意请求触发session文件反序列化。漏洞描述 该漏洞的核心在于不完整PUT请求上传时 Tomcat 会使用了一个基于用户提供的文件名和…

SparkSubmit提交任务到yarn及报错解决方案

SparkSubmit提交任务到yarn及报错解决方案@目录一、提交任务代码二、Linux提交可能出现的问题及解决方案情况1:JSON解析异常情况2:java.lang.InstantiationException spark.sql.driver情况3 中kafka:java.lang.NoClassDefFoundError: org/apache/kafka/clients/producer/Cal…

线程异步处理任务

实际开发中,service层可能会执行多个步骤,那有些步骤可能和主任务没有太大关联,那我们可以采用线程去处理,这样就提高响应速度,当然也可以采用MQ,此处介绍的是用线程处理 1、controller层@GetMapping("/thread")public void thread(){demo1Service.process();}…

08. 通用定时器

一、什么是通用定时器ESP32 S3 芯片配备了两个通用定时器组,每组均包含两个通用定时器和一个主系统看门狗定时器。每个通用定时器都具备多个通道。通过明确指定定时器号和通道号,用户可以精准地选定所需的定时器和通道。每个定时器均支持独立编程,并且具备微秒级的精确时间中…

全链路赋能游戏鸿蒙化适配,鸿蒙游戏开发者服务焕新升级

3月14日,华为游戏中心在成都开展了鸿蒙游戏开发者服务日线下活动。本次活动吸引了百余位游戏厂商代表以及开发者参与。华为一线技术专家团队与众多游戏开发者进行了面对面的深入交流,聚焦游戏鸿蒙化全流程技术实践,通过专家授课、案例解析与现场互动,为开发者提供从技术适配…

多线程程序设计(三)——Guarded Suspension

本文摘要了《Java多线程设计模式》一书中提及的 Guarded Suspension 模式的适用场景,并针对书中例子(若干名称有微调)给出一份 C++ 参考实现及其 UML 逻辑图,也列出与之相关的模式。 ◆ 适用场景 当线程访问的共享数据没有准备好时,让该线程进入等待状态,直到数据被准备好…

西部数据企业级硬盘HC310开盘数据恢复,300G左右数据量耗时半年

这块西数4T企业级硬盘HC310是杭州某研究所送过来的,突发损坏不识别,通电后咯吱咯吱敲盘异响,磁头坏了。这款企业级硬盘目前开盘成功率一般,因为磁头适配很困难,需要反复更换磁头,备件成本很高。这种硬盘的开盘难度跟服务器SCSI或SAS硬盘有的一拼,没有经验甚至拆一个废一…

5分钟,构建国产数据库智能体

近期,圈里很多朋友,都尝试利用 DeepSeek 构建自己的智能体。我也利用腾讯元器,将个人公众号内容做了个智能体,可以实现简单的问答。那么延展来看,智能体除了可利用公众号内容,也可使用离线文件等方式来构建。这不禁让我考虑,是否可用这样方式构造一个数据库智能体。说干…

Ubuntu 22.04 LTS 基于 Docker 部署 WordPress

Ubuntu 22.04 LTS 基于 Docker 部署 WordPress 1. 引言 WordPress 是全球最受欢迎的内容管理系统 (CMS),使用 Docker 可以简化其部署过程。本教程将介绍如何在 Ubuntu 22.04 LTS 上使用 Docker 部署 WordPress。2. WordPress 简介 2.1 WordPress 是什么? WordPress 是全球最流…

7.接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例1:输入:height = [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示…

K近邻算法等

1. KNN算法和KD - tree总结 1.1 KNN算法 模型 K近邻(K - Nearest Neighbors,KNN)算法是一种基本的分类与回归方法。它的模型实际上是对特征空间的划分,给定一个训练数据集,对于新的输入实例,在训练数据集中找到与该实例最邻近的 \(K\) 个实例,然后根据这 \(K\) 个实例的…