|
|
@@ -1,6 +1,6 @@
|
|
|
-## Django 2实战-01:快速上手
|
|
|
+## Django实战(01) - 快速上手
|
|
|
|
|
|
-Web开发的早期阶段,开发者需要手动编写每个页面,例如一个新闻门户网站,每天都要修改它的HTML页面,这样随着网站规模和体量的增大,这种方式就变得极度糟糕。为了解决这个问题,开发人员想到了用外部程序来为Web服务器生成动态内容,也就是说HTML页面以及页面中的动态内容不再通过手动编写而是通过程序自动生成。最早的时候,这项技术被称为CGI(公共网关接口),当然随着时间的推移,CGI暴露出的问题也越来越多,例如大量重复的样板代码,总体性能较为低下等,因此在时代呼唤新英雄的背景下,PHP、ASP、JSP这类Web应用开发技术在上世纪90年代中后期如雨后春笋般涌现。通常我们说的Web应用是指通过浏览器来访问网络资源的应用程序,因为浏览器的普及性以及易用性,Web应用使用起来方便简单,免除了安装和更新应用程序带来的麻烦,而且也不用关心用户到底用的是什么操作系统,甚至不用区分是PC端还是移动端。
|
|
|
+Web开发的早期阶段,开发者需要手动编写每个页面,例如一个新闻门户网站,每天都要修改它的HTML页面,随着网站规模和体量的增大,这种方式就变得极度糟糕。为了解决这个问题,开发人员想到了用外部程序来为Web服务器生成动态内容,也就是说HTML页面以及页面中的动态内容不再通过手动编写而是通过程序自动生成。最早的时候,这项技术被称为CGI(公共网关接口),当然随着时间的推移,CGI暴露出的问题也越来越多,例如大量重复的样板代码,总体性能较为低下等,因此在时代呼唤新英雄的背景下,PHP、ASP、JSP这类Web应用开发技术在上世纪90年代中后期如雨后春笋般涌现。通常我们说的Web应用是指通过浏览器来访问网络资源的应用程序,因为浏览器的普及性以及易用性,Web应用使用起来方便简单,免除了安装和更新应用程序带来的麻烦,而且也不用关心用户到底用的是什么操作系统,甚至不用区分是PC端还是移动端。
|
|
|
|
|
|
### Web应用机制和术语
|
|
|
|
|
|
@@ -8,7 +8,7 @@ Web开发的早期阶段,开发者需要手动编写每个页面,例如一
|
|
|
|
|
|

|
|
|
|
|
|
-> 说明:相信有经验的读者会发现,这张图中其实还少了很多东西,例如反向代理服务器、数据库服务器、防火墙等,而且图中的每个节点在实际项目部署时可能是一组节点组成的集群。当然,如果你对这些没有什么概念也不要紧,后续的课程中我们会为大家进行讲解。
|
|
|
+> 说明:相信有经验的读者会发现,这张图中其实还少了很多东西,例如反向代理服务器、数据库服务器、防火墙等,而且图中的每个节点在实际项目部署时可能是一组节点组成的集群。当然,如果你对这些没有什么概念也不要紧,继续下去就行了,后面会给大家一一讲解的。
|
|
|
|
|
|
| 术语 | 解释 |
|
|
|
| ------------- | ------------------------------------------------------------ |
|
|
|
@@ -23,7 +23,7 @@ Web开发的早期阶段,开发者需要手动编写每个页面,例如一
|
|
|
|
|
|
#### HTTP协议
|
|
|
|
|
|
-这里我们稍微费一些笔墨来谈谈上面提到的HTTP。HTTP(超文本传输协议)是构建于TCP(传输控制协议)之上应用级协议,它利用了TCP提供的可靠的传输服务实现了Web应用中的数据交换。按照维基百科上的介绍,设计HTTP最初的目的是为了提供一种发布和接收[HTML](https://zh.wikipedia.org/wiki/HTML)页面的方法,也就是说这个协议是浏览器和Web服务器之间传输的数据的载体。关于这个协议的详细信息以及目前的发展状况,大家可以阅读阮一峰老师的[《HTTP 协议入门》](http://www.ruanyifeng.com/blog/2016/08/http.html)、[《互联网协议入门》](http://www.ruanyifeng.com/blog/2012/05/internet_protocol_suite_part_i.html)系列以及[《图解HTTPS协议》](http://www.ruanyifeng.com/blog/2014/09/illustration-ssl.html)进行了解,下图是我于2009年9月10日凌晨4点在四川省网络通信技术重点实验室用开源协议分析工具Ethereal(抓包工具WireShark的前身)截取的访问百度首页时的HTTP请求和响应的报文(协议数据),由于Ethereal截取的是经过网络适配器的数据,因此可以清晰的看到从物理链路层到应用层的协议数据。
|
|
|
+这里我们稍微费一些笔墨来谈谈上面提到的HTTP。HTTP(超文本传输协议)是构建于TCP(传输控制协议)之上应用级协议,它利用了TCP提供的可靠的传输服务实现了Web应用中的数据交换。按照维基百科上的介绍,设计HTTP最初的目的是为了提供一种发布和接收[HTML](https://zh.wikipedia.org/wiki/HTML)页面的方法,也就是说这个协议是浏览器和Web服务器之间传输的数据的载体。关于这个协议的详细信息以及目前的发展状况,大家可以阅读阮一峰老师的[《HTTP 协议入门》](http://www.ruanyifeng.com/blog/2016/08/http.html)、[《互联网协议入门》](http://www.ruanyifeng.com/blog/2012/05/internet_protocol_suite_part_i.html)系列以及[《图解HTTPS协议》](http://www.ruanyifeng.com/blog/2014/09/illustration-ssl.html)进行了解。下图是我于2009年9月10日凌晨4点在四川省网络通信技术重点实验室用开源协议分析工具Ethereal(抓包工具WireShark的前身)截取的访问百度首页时的HTTP请求和响应的报文(协议数据),由于Ethereal截取的是经过网络适配器的数据,因此可以清晰的看到从物理链路层到应用层的协议数据。
|
|
|
|
|
|
HTTP请求(请求行+请求头+空行+[消息体]):
|
|
|
|
|
|
@@ -33,11 +33,11 @@ HTTP响应(响应行+响应头+空行+消息体):
|
|
|
|
|
|

|
|
|
|
|
|
-> 说明:但愿这两张如同泛黄的照片般的截图帮助你大概的了解到HTTP是一个怎样的协议。
|
|
|
+> 说明:但愿这两张如同泛黄的照片般的截图能帮助你了解HTTP到底是什么样子的。
|
|
|
|
|
|
### Django概述
|
|
|
|
|
|
-Python的Web框架有上百个,比它的关键字还要多。所谓Web框架,就是用于开发Web服务器端应用的基础设施(通常指封装好的模块和一系列的工具)。事实上,即便没有Web框架,我们仍然可以通过socket或[CGI](https://zh.wikipedia.org/wiki/%E9%80%9A%E7%94%A8%E7%BD%91%E5%85%B3%E6%8E%A5%E5%8F%A3)来开发Web服务器端应用,但是这样做的成本和代价在实际开发中通常是不能接受的。通过Web框架,我们可以化繁为简,同时降低创建、更新、扩展应用程序的工作量。Python的Web框架中比较有名的有:Flask、Django、Tornado、Pyramid、Bottle、Web2py、web.py等。
|
|
|
+Python的Web框架有上百个,比它的关键字还要多。所谓Web框架,就是用于开发Web服务器端应用的基础设施(通常指封装好的模块和一系列的工具)。事实上,即便没有Web框架,我们仍然可以通过socket或[CGI](https://zh.wikipedia.org/wiki/%E9%80%9A%E7%94%A8%E7%BD%91%E5%85%B3%E6%8E%A5%E5%8F%A3)来开发Web服务器端应用,但是这样做的成本和代价在实际开发中通常是不能接受的。通过Web框架,我们可以化繁为简,同时降低创建、更新、扩展应用程序的工作量。Python的Web框架中比较有名的有:Flask、Django、Tornado、Sanic、Pyramid、Bottle、Web2py、web.py等。
|
|
|
|
|
|
在基于Python的Web框架中,Django是所有重量级选手中最有代表性的一位,开发者可以基于Django快速的开发可靠的Web应用程序,因为它减少了Web开发中不必要的开销,对常用的设计和开发模式进行了封装,并对MVC架构提供了支持(MTV)。许多成功的网站和App都是基于Django框架构建的,国内比较有代表性的网站包括:知乎、豆瓣网、果壳网、搜狐闪电邮箱、101围棋网、海报时尚网、背书吧、堆糖、手机搜狐网、咕咚、爱福窝、果库等。
|
|
|
|
|
|
@@ -49,7 +49,7 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
|
|
|
#### 准备工作
|
|
|
|
|
|
-1. 检查Python环境:Django 1.11需要Python 2.7或Python 3.4以上的版本;Django 2.0需要Python 3.4以上的版本。
|
|
|
+1. 检查Python环境:Django 1.11需要Python 2.7或Python 3.4以上的版本;Django 2.0需要Python 3.4以上的版本;Django 2.1需要Python 3.5以上的版本。
|
|
|
|
|
|
```Shell
|
|
|
$ python3 --version
|
|
|
@@ -75,12 +75,18 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
$ python3 -m venv venv
|
|
|
$ source venv/bin/activate
|
|
|
```
|
|
|
- > 注意:Windows系统下是执行`venv/Scripts/activate.bat`批处理文件。
|
|
|
+ > 说明:上面使用了Python自带的venv模块完成了虚拟环境的创建,当然也可以使用其他的工具,例如:virtualenv或pipenv等。要激活虚拟环境,在Windows系统下是通过"venv/Scripts/activate"`执行批处理文件来实现。
|
|
|
|
|
|
4. 更新包管理工具pip。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ python -m pip install --upgrade pip
|
|
|
+ (venv)$ pip install -U pip
|
|
|
+ ```
|
|
|
+
|
|
|
+ 或
|
|
|
+
|
|
|
+ ```Shell
|
|
|
+ (venv)$ python -m pip install -U pip
|
|
|
```
|
|
|
> 注意:请注意终端提示符发生的变化,前面的`(venv)`说明我们已经进入虚拟环境,而虚拟环境下的python和pip已经是Python 3的解释器和包管理工具了。
|
|
|
|
|
|
@@ -103,21 +109,29 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
(venv)$ django-admin --version
|
|
|
```
|
|
|
|
|
|
+ 或
|
|
|
+
|
|
|
```Shell
|
|
|
(venv)$ python
|
|
|
>>> import django
|
|
|
>>> django.get_version()
|
|
|
```
|
|
|
- 下图展示了Django版本和Python版本的对应关系,在我们的项目中我们选择了最新的Django 2.0的版本。
|
|
|
+ 当然,也可以通过pip来查看安装的依赖库及其版本,如:
|
|
|
+
|
|
|
+ ```Shell
|
|
|
+ (venv)$ pip freeze
|
|
|
+ (venv)$ pip list
|
|
|
+ ```
|
|
|
+
|
|
|
+ 下图展示了Django版本和Python版本的对应关系,如果在安装时没有指定版本号,将自动选择最新的版本(在写作这段内容时,最新的版本是2.0;目前最新的版本已经更新到2.2)。
|
|
|
|
|
|
| Django版本 | Python版本 |
|
|
|
| ---------- | ----------------------- |
|
|
|
| 1.8 | 2.7、3.2、3.3、3.4、3.5 |
|
|
|
| 1.9、1.10 | 2.7、3.4、3.5 |
|
|
|
- | 1.11 | 2.7、3.4、3.5、3.6 |
|
|
|
- | 2.0 | 3.4、3.5、3.6 |
|
|
|
-
|
|
|
- > 说明:在写这篇文章时Django 2.1版本尚未正式发布,因此我们的教程使用了2.0.5版本。
|
|
|
+ | 1.11 | 2.7、3.4、3.5、3.6、3.7 |
|
|
|
+ | 2.0 | 3.4、3.5、3.6、3.7 |
|
|
|
+ | 2.1、2.2 | 3.5、3.6、3.7 |
|
|
|
|
|
|
7. 使用`django-admin`创建项目,项目命名为oa。
|
|
|
|
|
|
@@ -150,15 +164,14 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
|
|
|
> 说明2:用于开发的服务器在需要的情况下会对每一次的访问请求重新载入一遍Python代码。所以你不需要为了让修改的代码生效而频繁的重新启动服务器。然而,一些动作,比如添加新文件,将不会触发自动重新加载,这时你得自己手动重启服务器。
|
|
|
|
|
|
- > 说明3:可以通过`python manage.py help`命令查看可用命令列表;在启动服务器时,也可以通过`python manage.py runserver 1.2.3.4:56789`来指定绑定的IP地址和端口。
|
|
|
+ > 说明3:可以通过`python manage.py help`命令查看可用命令列表;在启动服务器时,也可以通过`python manage.py runserver 1.2.3.4:5678`来指定绑定的IP地址和端口。
|
|
|
|
|
|
> 说明4:可以通过Ctrl+C来终止服务器的运行。
|
|
|
|
|
|
-9. 接下来我们进入项目目录oa并修改配置文件settings.py,Django是一个支持国际化和本地化的框架,因此刚才我们看到的默认首页也是支持国际化的,我们将默认语言修改为中文,时区设置为东八区。
|
|
|
+9. 接下来我们修改项目的配置文件settings.py,Django是一个支持国际化和本地化的框架,因此刚才我们看到的默认首页也是支持国际化的,我们将默认语言修改为中文,时区设置为东八区。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd oa
|
|
|
- (venv)$ vim settings.py
|
|
|
+ (venv)$ vim oa/settings.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -172,18 +185,13 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
# 此处省略下面的内容
|
|
|
```
|
|
|
|
|
|
-10. 回到manage.py所在的目录,刷新刚才的页面。
|
|
|
-
|
|
|
- ```Shell
|
|
|
- (venv)$ cd ..
|
|
|
- (venv)$ python manage.py runserver
|
|
|
- ```
|
|
|
+10. 刷新刚才的页面。
|
|
|
|
|
|

|
|
|
|
|
|
#### 动态页面
|
|
|
|
|
|
-1. 创建名为hrs(人力资源系统)的应用(注:一个项目可以包含多个应用)。
|
|
|
+1. 创建名为hrs(人力资源系统)的应用,一个Django项目可以包含一个或多个应用。
|
|
|
|
|
|
```Shell
|
|
|
(venv)$ python manage.py startapp hrs
|
|
|
@@ -192,7 +200,7 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
执行上面的命令会在当前路径下创建hrs目录,其目录结构如下所示:
|
|
|
|
|
|
- `__init__.py`:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。
|
|
|
- - `admin.py`:可以用来注册模型,让Django自动创建管理界面。
|
|
|
+ - `admin.py`:可以用来注册模型,用于在Django的管理界面管理模型。
|
|
|
- `apps.py`:当前应用的配置。
|
|
|
- `migrations`:存放与模型有关的数据库迁移信息。
|
|
|
- `__init__.py`:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。
|
|
|
@@ -200,11 +208,10 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
- `tests.py`:包含测试应用各项功能的测试类和测试函数。
|
|
|
- `views.py`:处理请求并返回响应的函数(MVC中的C,MVT中的V)。
|
|
|
|
|
|
-2. 进入应用目录修改视图文件views.py。
|
|
|
+2. 修改应用目录下的视图文件views.py。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd hrs
|
|
|
- (venv)$ vim views.py
|
|
|
+ (venv)$ vim hrs/views.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -218,8 +225,8 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
3. 在应用目录创建一个urls.py文件并映射URL。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ touch urls.py
|
|
|
- (venv)$ vim urls.py
|
|
|
+ (venv)$ touch hrs/urls.py
|
|
|
+ (venv)$ vim hrs/urls.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -231,14 +238,12 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
path('', views.index, name='index'),
|
|
|
]
|
|
|
```
|
|
|
- > 说明:上面使用的path函数是Django 2.x中新添加的函数,除此之外还有re_path是支持正则表达式的URL映射函数;Django 1.x中是用url函数来设定URL映射。
|
|
|
+ > 说明:上面使用的`path`函数是Django 2.x中新添加的函数,除此之外还可以使用支持正则表达式的URL映射函数`re_path`函数;Django 1.x中是用名为`url`函数来设定URL映射。
|
|
|
|
|
|
4. 切换到项目目录,修改该目录下的urls.py文件,对应用中设定的URL进行合并。
|
|
|
|
|
|
```Shell
|
|
|
- (venv) $ cd ..
|
|
|
- (venv) $ cd oa
|
|
|
- (venv) $ vim urls.py
|
|
|
+ (venv) $ vim oa/urls.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -251,22 +256,16 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
]
|
|
|
```
|
|
|
|
|
|
-5. 启动项目并访问应用。
|
|
|
+5. 重新运行项目,并打开浏览器中访问<http://localhost:8000/hrs>。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd ..
|
|
|
(venv)$ python manage.py runserver
|
|
|
```
|
|
|
|
|
|
- 在浏览器中访问<http://localhost:8000/hrs>。
|
|
|
-
|
|
|
- > 说明:如果想实现远程访问,需要先确认防火墙是否已经打开了8000端口,而且需要在配置文件settings.py中修改ALLOWED_HOSTS的设置,添加一个'*'表示允许所有的客户端访问Web应用。
|
|
|
-
|
|
|
6. 修改views.py生成动态内容。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd hrs
|
|
|
- (venv)$ vim views.py
|
|
|
+ (venv)$ vim hrs/views.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -309,33 +308,29 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
return HttpResponse(output.getvalue())
|
|
|
```
|
|
|
|
|
|
-7. 再次使用下面的命令来启动服务器并查看程序的运行结果。
|
|
|
+7. 刷新页面查看程序的运行结果。
|
|
|
|
|
|
- ```Shell
|
|
|
- (venv)$ cd ..
|
|
|
- (venv)$ python manage.py runserver
|
|
|
- ```
|
|
|

|
|
|
|
|
|
#### 使用视图模板
|
|
|
|
|
|
-上面通过拼接HTML代码的方式生成动态视图的做法在实际开发中是无能接受的,这一点我相信是不言而喻的。为了解决这个问题,我们可以提前准备一个模板页,所谓模板页就是一个带占位符的HTML页面,当我们将程序中获得的数据替换掉页面中的占位符时,一个动态页面就产生了。
|
|
|
+上面通过拼接HTML代码的方式生成动态视图的做法在实际开发中是无能接受的,这一点大家一定能够想到。为了解决这个问题,我们可以提前准备一个模板页,所谓模板页就是一个带占位符的HTML页面,当我们将程序中获得的数据替换掉页面中的占位符时,一个动态页面就产生了。
|
|
|
+
|
|
|
+我们可以用Django框架中template模块的Template类创建模板对象,通过模板对象的render方法实现对模板的渲染。所谓的渲染就是用数据替换掉模板页中的占位符,当然这里的渲染称为后端渲染,即在服务器端完成页面的渲染再输出到浏览器中,这种做法的主要坏处是当并发访问量较大时,服务器会承受较大的负担,所以今天有很多的Web应用都使用了前端渲染,即服务器只为浏览器提供所需的数据(通常是JSON格式),在浏览器中通过JavaScript获取这些数据并渲染到页面上,这些内容在后面为大家呈现。
|
|
|
|
|
|
-我们可以用Django框架中template模块的Template类创建模板对象,通过模板对象的render方法实现对模板的渲染。所谓的渲染就是用数据替换掉模板页中的占位符,Django框架通过shortcuts模块的快捷函数render简化了渲染模板的操作,具体的用法如下所示。
|
|
|
+Django框架通过shortcuts模块的快捷函数`render`简化了渲染模板的操作,具体的用法如下所示。
|
|
|
|
|
|
-1. 先回到manage.py文件所在的目录创建一个templates文件夹。
|
|
|
+1. 先回到manage.py文件所在的目录创建名为templates文件夹。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd ..
|
|
|
(venv)$ mkdir templates
|
|
|
- (venv)$ cd templates
|
|
|
```
|
|
|
|
|
|
2. 创建模板页index.html。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ touch index.html
|
|
|
- (venv)$ vim index.html
|
|
|
+ (venv)$ touch templates/index.html
|
|
|
+ (venv)$ vim templates/index.html
|
|
|
```
|
|
|
```HTML
|
|
|
<!DOCTYPE html>
|
|
|
@@ -364,14 +359,12 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
</body>
|
|
|
</html>
|
|
|
```
|
|
|
- 注意在模板页中我们使用了`{{ greeting }}`这样的模板占位符语法,也使用了`{% for %}`这样的模板指令,如果对此不熟悉并不要紧,我们会在后续的内容中进一步的讲解模板的用法。
|
|
|
+ 在上面的模板页中我们使用了`{{ greeting }}`这样的模板占位符语法,也使用了`{% for %}`这样的模板指令,这些都是Django模板语言(DTL)的一部分。如果对此不熟悉并不要紧,我们会在后续的内容中进一步的讲解,而且我们刚才也说到了,还有更好的选择就是使用前端渲染,当然这是后话。
|
|
|
|
|
|
3. 回到应用目录,修改views.py文件。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd ..
|
|
|
- (venv)$ cd hrs
|
|
|
- (venv)$ vim views.py
|
|
|
+ (venv)$ vim hrs/views.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -388,14 +381,12 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
return render(request, 'index.html', {'depts_list': depts_list})
|
|
|
```
|
|
|
|
|
|
- 到此为止,我们还没有办法让views.py中的render函数找到模板文件index.html,为此我们需要修改settings.py文件,配置模板文件所在的路径。
|
|
|
+ 到此为止,我们还没有办法让views.py中的`render`函数找到模板文件index.html,为此我们需要修改settings.py文件,配置模板文件所在的路径。
|
|
|
|
|
|
4. 切换到项目目录修改settings.py文件。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd ..
|
|
|
- (venv)$ cd oa
|
|
|
- (venv)$ vim settings.py
|
|
|
+ (venv)$ vim oa/settings.py
|
|
|
```
|
|
|
|
|
|
```Python
|
|
|
@@ -420,16 +411,15 @@ Django诞生于2003年,它是一个在真正的应用中成长起来的项目
|
|
|
# 此处省略下面的内容
|
|
|
```
|
|
|
|
|
|
-5. 重新运行项目并查看结果。
|
|
|
+5. 重新运行项目或直接刷新页面查看结果。
|
|
|
|
|
|
```Shell
|
|
|
- (venv)$ cd ..
|
|
|
(venv)$ python manage.py runserver
|
|
|
```
|
|
|
|
|
|
|
|
|
### 总结
|
|
|
|
|
|
-至此,我们已经利用Django框架完成了一个非常小的Web应用,虽然它并没有任何的实际价值,但是我们需要通过这个项目了解到Django框架的使用方式。当然,如果使用PyCharm的Professional版本,也可以通过PyCharm的创建项目的选项直接创建Django项目,使用PyCharm的好处在于编写代码时可以获得代码提示、错误修复、自动导入等功能,从而提升开发效率,但是代价是需要支付对应的费用才能使用专业版的PyCharm,社区版的PyCharm中并未包含对Web框架的支持。
|
|
|
+至此,我们已经利用Django框架完成了一个非常小的Web应用,虽然它并没有任何的实际价值,但是可以通过这个项目对Django框架有一个感性的认识。当然,实际开发中我们可以用PyCharm来创建项目,如果使用专业版的PyCharm,可以直接创建Django项目。使用PyCharm的好处在于编写代码时可以获得代码提示、错误修复、自动导入等功能,从而提升开发效率,但是专业版的PyCharm需要按年支付相应的费用,社区版的PyCharm中并未包含对Django框架直接的支持,但是我们仍然可以使用它来创建Django项目,只是在使用上没有专业版的方便。关于PyCharm的使用,可以参考[《玩转PyCharm》](../玩转PyCharm.md)一文。
|
|
|
|
|
|
-此外,学习Django最好的资料肯定是它的[官方文档](https://docs.djangoproject.com/zh-hans/2.0/),除此之外图灵社区最近出版的[《Django基础教程》](http://www.ituring.com.cn/book/2630)也是非常适合初学者的读物。
|
|
|
+此外,学习Django最好的资料肯定是它的[官方文档](https://docs.djangoproject.com/zh-hans/2.0/),除此之外图灵社区出版的[《Django基础教程》](http://www.ituring.com.cn/book/2630)也是非常适合初学者的读物。
|