先上结论:admin界面样式失效问题不是404的问题
Django在开发环境下可以加载静态文件,部署到服务器无法加载静态文件。 界面失效问题肯定是发生在你使用了collectstatic命令,而且把settings.py文件的DEBUG参数设置为False(django项目建议生产环境下将其设置为false,开发环境下设置为true)
问题来了,如果在上线前,在本地测试,将DEBUG设置为false,就会是下面这个叼样。 为啥会404,自己明明把参数STATIC_URL ,STATIC_ROOT 设置得好好的,一脸懵逼哈。 BUT,你把DEBUG设置为True之后再试试,样式又回来了。 所以,问题不在于404或者文件路径的问题,而是Django在这里偷懒了。 DEBUG参数的值反应的是 Django 对静态文件的处理与否。若DEBUG = False,Django不再管理静态文件了,哪怕配置了url路由也没用,django就是不叼你。 Django这么设计的原因:如果静态文件都由 Django 来管理,那服务效率实在是太低了,应该交由更高效的网络服务管理起来,如 Nginx,恰好这又是Nginx的强项。所有静态文件的请求都由 Nginx 直接处理,完全不用转发给后面的 Django 了,所以在线上环境,不管你怎么折腾 Django 的配置都是没用的了。 这恰恰说明了为什么现在Django项目部署多是采用Nginx+uwsgi+django,或者Nginx+django的架构了
Django官方文档也有提示: 官方都在建议你用Nginx做静态资源服务器,那还纠结个锤子,反正Django就是不管你静态请求了。。。
|