Django是基于Python开发的免费的开源网站框架,也是python web开发中重量级的web框架,可以用于快速搭建高性能并且优雅的网站!
下面以Fedora为例安装Django,最新Fedora 23集成了python 3.4.3,所以可以直接安装django,同时建议不要使用自己编译安装的python来安装django,这样可能会出问题,因为很多东西要依赖于系统本身,自己编译安装的python只用来开发本地应用,而不是web开发;另外在Fedora中,输入python会提示命令找不到,而输入python3会进入python交互式界面,那是因为/usr/bin/下只有python3软链接,链接到python3.4,而并没有python这个链接,所以为了后来方便,我们可以建立一个软链接python,不用每次都再输python3了,命令如下:
ln -s /usr/bin/python3 /usr/bin/python
这样就建立了一个软链接,以后随时输入python即可了,好的,下面正式的开始安装Django
安装django之前,首先要安装pip,pip是一种类似yum这样的软件安装工具,用它可以很方便的安装软件,并且自动解决版本升级问题,实际上pip是专门安装和管理python包的工具,是easy_install的替代品,所以要先安装pip,pip的在python官网的链接是:https://pypi.python.org/pypi/pip/
进去上述网站之后,点击Installation就可以进入安装说明界面了,网址是:https://pip.pypa.io/en/latest/installing/
紧接着我们就看到,pip的安装方法之一就是使用get-pip.py脚本来安装,我们可以复制get-pip.py的链接,也可以先下载到本地计算机上然后上传至服务器,可以看到get-pip.py的链接是:https://bootstrap.pypa.io/get-pip.py
执行下面命令下载该文件:
wget https://bootstrap.pypa.io/get-pip.py
下载完之后,根据官网说明,要使用本地的python运行该脚本:
python get-pip.py
稍等一下pip就安装成功了,可以通过执行的pip命令查看对应的参数,下面使用pip来安装django,django官网有详细的教程:https://www.djangoproject.com/,根据说明知道,安装django的命令是:pip install Django,这样运行默认安装的是最新版,目前是1.9.2,因为python版本的原因,所以会出现错误,安装失败,根据测试在python3.4基础上安装Django 1.8.9正式版是没有问题的,所以要执行下面命令:
pip install Django==1.8.9
回车后稍等一会,需要下载相应的文件,等执行完毕,Django 1.8.9就安装成功了,如果是CentOS 6.6或者更低版本,系统上带的python版本是2.6.6,那么经过测试安装Django 1.5.8是没有任何问题的所以用pip应该是:pip install Django==1.5.8
等安装完成之后,执行python进入交互式界面,输入import django,然后再输入django.VERSION回车后可以看到刚刚安装的Django的版本号,或者直接执行下面命令:
python -c "import django; print(django.get_version())"
这同时也说明django安装成功了
接下来可以开始创建web应用了,在我们的根目录下随便创建一个目录,用来专门放置Django项目,在该目录下执行下面命令:
django-admin.py startproject HelloDjango
这就是创建django项目的命令,使用pip安装django后,在/usr/bin/下会生成django-admin.py新版本中也会生成django-admin可执行文件,所以也可以执行:django-admin startproject HelloDjango创建项目,创建后我们进入项目目录:
cd HelloDjango/
进入目录之后,可以通过tree命令查看目录结构,如果提示没有tree命令的话,可以使用yum -y install tree命令来安装
我们可以看到初始目录的文件了,项目目录下manage.py是一个实用的命令行工具,可以通过它管理django服务器等,容器下还有一个和容器同名的HelloDjango目录,__init__.py是项目初始化文件,告诉python该目录是一个python包,settings.py是用来进行项目配置的文件,urls.py是项目中所有的url声明,可以认为是django驱动整个项目的url目录,可以定义多种优雅的路由请求,wsgi.py是一个WSGI兼容的Web服务器入口,方便运行web项目。现在这就是一个初始的项目,我们接下来启动这个项目:
python manage.py runserver 192.168.1.41:80
因为要从局域网访问所以后面我们自己定义的是服务器本身的ip和端口号,启动之后命令行进入等待,访问之前不要忘了关闭防火墙,对于centos可以使用如下命令关闭:
/etc/init.d/iptables stop
对于我现在使用的Fedora,关闭命令是:
/bin/systemctl stop firewalld.service
关闭防火墙之后,我们通过浏览器访问http://192.168.1.41/即可以打开页面,
看到这个页面说明django运行一切正常了,浏览器每发出请求,服务器都会更新消息:
通过Ctrl+C快捷键可以终止服务器,接下来我们新建一个简单的测试应用,可以在HelloDjango下直接建立视图文件,但是为了应用结构的清晰不建议这样做,正确方法是在容器根目录下,使用如下命令可以建立一个应用,一个项目可以包括多个应用:
python manage.py startapp app1
这样在容器下就会出现一个app1的目录,结构如下:
每个源文件的含义也不难理解,下面使用vim打开views.py,如果没有vim可以使用yum install vim进行安装
打开后views.py是空的,有用的只有头部一行代码,是用于后来模板渲染的
现在我们直接补充如下代码,打印一行简单的输出:
from django.http import HttpResponse def index(request): return HttpResponse("Hello Django!")
头部包含了请求库,每个方法都必须有request参数,这是用来接收请求的,HttpResponse方法的作用就是响应请求,然后保存视图文件,进入项目下的HelloDjango目录,编辑settings.py配置文件,找到INSTALLED_APPS配置项,追加一项app1,将应用app1添加到项目容器
保存之后,编辑urls.py文件,头部追加一行from app1 import views as app1_views,这个app_views是我们自己定义的导入的视图名,然后给urlpatterns这个列表添加一项:url(r'^$', app1_views.index), 注意后面要有一个逗号,前面是定义请求url的正则表达式,后面是响应输出的视图方法,这里正则表达式匹配为空,就是代表的根目录,如下图,带有# new注释的是新增的代码:
现在保存,回到容器下再次运行:python manage.py runserver 192.168.1.41:80启动开发服务器,用浏览器访问即可
下面可以在之前的视图中再定义一个方法,
def home(request): return render(request, 'home.html')
使用render方法之前要使用from django.shortcuts import render导入对应库,因为前面默认导入了所以不用再次导入了,render方法的作用就是调用对应的视图模板也就是home.html,那么home.html放到什么地方呢,在app1目录下执行下面命令:
$ mkdir templates $ cd templates/ $ vim home.html
在django加载app1应用时,会自动读取templates模板目录从而渲染里面的数据,home.html就是一个网页模板,为了简单,没有添加动态的数据:
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>home视图</title> 6 </head> 7 <body> 8 <h3>Hello Django!</h3> 9 </body> 10 </html>
同样添加urls.py的配置项,设置访问url,代码就是下图列表中的第三项:
保存后,同样启动服务器,访问http://192.168.1.41/home就可以看到对应的响应
以上就是Django基本的安装和最简单的例子,Django还有很多强大的功能,特别在国外,很多网站都是基于Django构建的,Django的特点就是功能强大并且使用简单,适合快速开发