Django部署到服务器后无法获取到静态元素 The requested resource was not found on this server

问题描述

Django项目部署到服务器后无法获取到静态元素 The requested resource was not found on this server。如图:

原因分析

  • 当 DEBUG = False 时,Django 不会自动提供静态文件服务
  • urls.py 中,静态文件的路由是通过 static() 函数添加的,但这个函数只在 DEBUG = True 时才会生效
  • 静态文件存储在 media/files 目录下,通过 /media/ URL 访问

解决方案

  1. 修改环境配置backend/conf/env.py 中添加:

    python 复制代码
    DEBUG = False
    SERVE_STATIC_FILES = True  # 新增配置项
  2. URL配置已自动处理

    项目已配置了媒体文件路由,确保在生产环境中也能访问:

    python 复制代码
    path("media/<path:file_path>", server_file, name="media_file"),
  3. 改进的server_file视图

    backend/dvadmin/system/views/server_file.py 优化,包含:

    • 路径安全检查
    • MIME类型支持
    • 错误处理
    • 多种文件格式支持
python 复制代码
   def server_file(request, file_path):
    """
    处理媒体文件访问的视图
    用于在生产环境中提供静态文件服务
    
    Args:
        request: HTTP请求对象
        file_path: 文件路径(从URL中获取)
    """
    # 清理文件路径
    file_path = file_path.lstrip('/')
    
    # 构建完整的文件路径
    full_path = os.path.join(settings.MEDIA_ROOT, file_path)
    
    # 安全检查:确保文件路径在MEDIA_ROOT目录内
    if not os.path.abspath(full_path).startswith(os.path.abspath(settings.MEDIA_ROOT)):
        raise Http404("文件路径无效")
    
    # 检查文件是否存在
    if not os.path.exists(full_path) or not os.path.isfile(full_path):
        raise Http404("文件不存在")
    
    # 获取文件扩展名
    file_ext = os.path.splitext(full_path)[1].lower()
    
    # 设置MIME类型
    mime_types = {
        '.pdf': 'application/pdf',
        '.jpg': 'image/jpeg',
        '.jpeg': 'image/jpeg',
        '.png': 'image/png',
        '.gif': 'image/gif',
        '.bmp': 'image/bmp',
        '.svg': 'image/svg+xml',
        '.txt': 'text/plain',
        '.doc': 'application/msword',
        '.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
        '.xls': 'application/vnd.ms-excel',
        '.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
        '.zip': 'application/zip',
        '.rar': 'application/x-rar-compressed',
        '.7z': 'application/x-7z-compressed',
        '.mp4': 'video/mp4',
        '.avi': 'video/x-msvideo',
        '.mp3': 'audio/mpeg',
        '.wav': 'audio/wav',
    }
    
    content_type = mime_types.get(file_ext, 'application/octet-stream')
    
    try:
        # 返回文件响应
        response = FileResponse(open(full_path, 'rb'), content_type=content_type)
        
        # 设置文件名(用于下载)
        filename = os.path.basename(full_path)
        response['Content-Disposition'] = f'inline; filename="{filename}"'
        
        return response
    except Exception as e:
        raise Http404(f"文件访问失败: {str(e)}")
相关推荐
XiaoMu_0014 小时前
【Django + Pure Admin】基于Django+Vue3的前后端分离管理系统框架设计
django·vue
修一呀1 天前
[后端快速搭建]基于 Django+DeepSeek API 快速搭建智能问答后端
后端·python·django
dreams_dream4 天前
Django的Settings 配置文件详解
数据库·django·sqlite
风清再凯4 天前
DRF序列化器
django
dreams_dream4 天前
django错误记录
后端·python·django
captainOO74 天前
MRO and mixin in Python Django
后端·python·django
义达6 天前
Django环境下使用wsgi启动MCP服务
后端·django·mcp
PythonicCC7 天前
Django中的MVC和MVT模式
数据库·django·mvc
PythonicCC7 天前
Django的生命周期
python·django·sqlite