Django学习之天气调查实例(3):部署静态文件CSS、JS、images等(部署环境基于Ubuntu)
在设计登录界面时,采用了网上下载的登录模板,漂亮,简易。但是在测试和部署时,发现原来模板中采用的js文件和css文件,却着实让我折腾了好几天。
在以往的网页设计中,一般只要把测试站点开启后,网页中的静态文件就不会出现连接的问题,但是在Django中,包括开发环境,也包括部署环境,竟然在设置中都有所不一样,现在将自己的经历写下来,也便于以后查看。
1.开发环境的设置
(1)开发环境可以用IDLE(默认)或Pycharm,这个没有影响。首先在自己的APP中创建一个存放静态文件的文件夹,名称为“static”。如笔者的项目名称为:website,里面自动生成一个website,在该文件夹中创建static文件夹。如下图所示:

(2)设置settings.py文件
STATIC_URL = '/static/'
STATIC_ROOT= os.path.join(BASE_DIR, 'static')
STATICFILES_DIRS = (os.path.join(
BASE_DIR,'website/static'), #这里的地址注意要加上APP名称,如website
)
(3)在html文件里可以直接使用该路径即可,如:
<link rel="stylesheet" href="/static/css/style.css">
这样设置后,在开发环境就可以使用静态文件了。
2.部署环境设置(基于Ubuntu16.04)
当在开发环境完成的Django项目文件复制到基于Ubuntu环境的Django站点目录后,测试时发现静态文件不能正常显示。网上找了许多的方法,可能没有完全理解吧,折腾了好几天,到现在为止才算是真正完成。
(1)项目下添加static文件夹
笔者测试后发现,在开发环境调整的settings.py设置在部署环境也是可以的,也就是说settings.py文件不需要更改,直接复制到相应的地方即可。
在部署环境的项目文件夹创建static文件夹。如下图所示:

注意:这个地方与开发环境有所不同。在部署环境中,需要通过下面第二步,将原本开发环境中的静态文件全部复制到该文件夹中。
(2)复制文件到上面的文件夹命令:
python3 manage.py collectstatic
通过该命令,Django会把静态文件包括相应的文件夹,全部复制到项目根目录的static文件夹中。
完成该步骤后,进行测试,发现静态文件还是不能访问。经过多次查证后发现在Apache服务器中,无法找到static文件夹,然后继续百度,一番查询后,最后得到的结果是:需要在apache中设置虚拟路径。
所以通过命令首先进入: /etc/apache2/sites-available,然后修改 website.conf。在中间增加一条语句:
Alias /static/ /var/www/website/static/
添加后需要让该配置生效,所以做如下操作:
service apache2 reload
至此,部署环境中的静态文件正常工作了。
Django学习之天气调查实例(3):部署静态文件CSS、JS、images等(部署环境基于Ubuntu)的更多相关文章
- Django学习之天气调查实例(1):工程的开始
开始学习Django,一步一个脚印的进行.思考再三,还是以一个实例来开始学习.手里面正好有几万条单位天气传感器收集的数据,想做一个网页版的天气统计查询之类的小应用,也可以给学生体验,方便教学的进行(尽 ...
- Django学习之天气调查实例(2):显示数据表数据
数据表数据添加后,如添加3条用户信息,分别为“aaa”.“bbb”.“ccc”,现在通过代码的方式显示数据表中的数据. 1.在website项目文件夹中创建 userload.py文件,并且写如下代码 ...
- django系列4.2--自定义标签, 自定义过滤器, inclusion_tag, 引入静态文件(css,js等)
项目的目录为 在app中创建templates时,最好要再创建一个app名相同的文件夹,因为项目找文件时从第一个app开始遍历,不同app内的同名文件会有冲突,所以这样处理 一.自定义标签和过滤器 1 ...
- django基础知识之管理静态文件css,js,images:
管理静态文件 项目中的CSS.图片.js都是静态文件 配置静态文件 在settings 文件中定义静态内容 STATIC_URL = '/static/' STATICFILES_DIRS = [ o ...
- 我的django之旅(二)模板和静态文件
我的django之旅(二)模板和静态文件 标签(空格分隔): django 1.为什么要使用模板 在上一篇博文中,提到了HttpReponse,但是HttpReponse只能传送字符串,如果要构建一个 ...
- 百度分享不支持https的解决方案(单独部署静态文件)
首先是参考了博客,下载百度分享的静态代码 static 链接为:https://www.cnblogs.com/mmzuo-798/p/6434576.html 后来在nginx的 nginx.con ...
- 擦他丫的,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了!
擦 ,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了! 问题在于我使用的谷歌浏览器,默认使用了缓存,导致每次访问同一个url时,都返回的是缓存里面的东西.通过谷歌 ...
- IDEA中Springboot静态文件加载(热部署)
Springboot项目静态文件加载 昨天写项目的时候碰到一个问题,就是静态文件css无法读取到项目中,我仔细思考了下,总结了下,可能有两个问题 1.页面未加载更新 这个可能性非常大,Chrome就是 ...
- Django 学习笔记(三) --- HTML 模版加载 css、js、img 静态文件
人生苦短 ~ Tips:仅适用于 Python 3+(反正差别不大,py2 改改也能用).因为据 Python 之父 Guido van Rossum 说会在 2020 年停止对 Python 2 的 ...
随机推荐
- SONA Topology
N多年以前就有有人设计传了一种类似“房子”状结构的拓扑图,在Cisco的文档中可以查到这种叫SONA.这是个非常神奇的设计,适合用于中小型网络,之所以这么讲,是因为在这个结构下,但凡任何一台接入层或者 ...
- 建立自己的git账户并保存资料的重要性
Github是一个代码托管平台和开发者社区,开发者可以在Github上创建自己的开源项目并与其他开发者协作编码.创业公司可以用它来托管软件项目,开源项目可以免费托管,私有项目需付费.[2] GitHu ...
- Android(java)学习笔记58:Android 英文朗诵
1. 首先,我先把代码放到下面: package com.himi.speaker; import java.util.Locale; import android.app.Activity; imp ...
- OsharpNS轻量级.net core快速开发框架简明入门教程-Osharp.Hangfire使用
OsharpNS轻量级.net core快速开发框架简明入门教程 教程目录 从零开始启动Osharp 1.1. 使用OsharpNS项目模板创建项目 1.2. 配置数据库连接串并启动项目 1.3. O ...
- 【洛谷P3119】[USACO15JAN]草鉴定Grass Cownoisseur
草鉴定Grass Cownoisseur 题目链接 约翰有n块草场,编号1到n,这些草场由若干条单行道相连.奶牛贝西是美味牧草的鉴赏家,她想到达尽可能多的草场去品尝牧草. 贝西总是从1号草场出发,最后 ...
- 【洛谷P1005】矩阵取数游戏
矩阵取数游戏 题目链接 每行分别跑一趟区间DP即可 这道题区间DP是非常裸的,按套路来即可 但是很毒瘤的是需要高精度, “我王境泽就是爆零,从这跳下去,也不会用__int128的!” #include ...
- 【luogu P2169 正则表达式】 题解
题目链接:https://www.luogu.org/problemnew/show/P2169 tarjan缩点 + SPFA 缩完点之后加边注意别写错. 也可以不用建两个图,可以在一张图上判断是否 ...
- PHP中级面试经历
资源来自网络:http://www.2cto.com/kf/201304/204749.html 1.用PHP打印出前一天的时间格式是2006-5-10 22:21:21(2分) 2.echo(),p ...
- Restrramework源码(包含组件)分析
1.总体流程分析 rest_framework/view.py 请求通过url分发,触发as_view方法,该方法在ViewSetMixin类下 点进去查看as_view源码说明,可以看到它在正常情况 ...
- Oracle-01-数据库分类/oracle sql*plus常用命令
一.数据库分类 一.数据库分类1.小型数据库:access.foxbase2.中型数据库:informix.sql server.mysql3.大型数据库:sybase.db2.oracle 二.项目 ...