一、一些基本术语
- MVC:软件架构模式
-- Model:程序的基本功能、数据库操作等
-- View:界面设计
-- Controller:请求进行处理 - CGI:通用网关接口(Common Gateway Interface/CGI),可以让一个客户端从网页浏览器向执行在网络服务器上的程序请求数据。
CGI描述了客户端和服务器程序之间传输数据的一种标准。
先补充这么多,后续根据需要考虑是否单独开辟一篇。
二、appName项目解析
1.在通过如下命令:
>>> django-admin.py startproject projectName
创建项目之后,对应的文件目录如下:
通过上面的目录结构,可知这里面有两个projectName。外面的projectName是项目目录,里面的projectName为该项目的配置文件。一般对项目进行操作时,在外面的projectName目录下,例如创建该项目的应用。下面,我们先看看里面的projectName都有啥:
- init.py: 让 Python 把该目录当成一个开发包 (即一组模块)所需的文件,初始化用,暂时不需要考虑
- settings.py: Django的项目设置,主要设置了关于数据库,后台管理等配置
- urls.py: Django项目的URL设置,负责把你要显示的内容,变成在服务器上可访问的地址,这个是重点要操作的文件。
- wsgi.py:部署服务器时用到的 wsgi.py,暂时不需要考虑
那外面的manage.py是做啥的呢:
- 项目管理工具,可以操作整个工程,可以输入python manage.py help查看具体能做啥
- 加载DJANGO_SETTINGS_MODULE,指明该工程的配置文件是mysite/settings.py
- 把该工程的包加入了sys.path;以后你可以直接在你的代码中引用该工程中其他的包(默默地做了好事)
2.上面的讲完了,插一句关于发布网页的基本逻辑:
- 设置要输出的内容,如’Hello,world’;
- 放到服务器的目录下,生成即该页面的URL,如’127.0.0.1:8000/hello.html’;
对应到Django中来说,需要作如下事情:
- 页面的内容生产,需要靠view function(视图函数),对应views.py文件
- 绑定视图函数和URL,通过 URLconf(即urls.py)进行。URLconf 就像是 Django 所支撑网站的目录,可以理解为总的urls配置文件。它的本质是 URL 模式以及要为该 URL 模式调用的视图函数之间的映射表。
3.回归主题,接下来就是主角登场了:views.py 和 urls.py
请打开之前的文章,有一段如下:
3.1 在appName这个目录中,把views.py打开,并修改如下:
\#coding:utf-8
from django.http import HttpResponse
def index(request):
return HttpResponse(‘欢迎来到Django的乐园:)’)
对的,在编辑views.py之前,你需要先创建一个app,命令如下:
python manage.py startapp appName
然后进入appName目录下,找到views.py,进行如上编辑。下面讲解一下每行的代码:
- #coding:utf-8:声明编码为utf-8,因为用了中文,否则就是乱码了;
- from django.http import HttpResponse:从django.http模块导入HttpResponse 类,用于在网页显示内容。
- def index(request): ”定义一个函数,进行显示操作,第一个参数必须是request
- return HttpResponse(‘欢迎来到Django的乐园:)’):返回一个HttpResponse对象,这个对象包含了文本“欢迎来到Django的乐园:)。
so,我们再来复习下:
- 一个视图就是Python的一个函数。
- 这个函数第一个参数的类型是HttpRequest;
- 它返回一个HttpResponse实例。
3.2 再来看看urls.py如何处理,继续之前的代码:
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover() # Notice this line
urlpatterns = patterns('',
# Examples:
url(r'^$', 'learn.views.index', name='home'), # Notice this line
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)), )
注意,urls.py是在projectName/projectName/里面的不是appName里面的。默认的URLconf包含了一些被注释起来的Django中常用的功能,仅仅只需去掉这些注释就可以开启这些功能. 上面的代码是URLconf中忽略被注释的行,并添加后的内容。
请注意注释部分的两处“# Notice this line”
- admin.autodiscover()”用来自动发现INSTALLED_APPS里面的模块;在此处操作之前,需要提前处理另外的一个文件,修改projectName/projectName/settings.py文件,增加appName相关描述:
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth'
'django.contrib.contenttypes'
'django.contrib.sessions'
'django.contrib.messages'
'django.contrib.staticfiles'
'appName'
)
接下来,我们为urlpatterns加上一行:
url(r'^$', 'learn.views.index', name='home')
- 它是一个元组,元组中第一个元素是模式匹配字符串(正则表达式),“'^$'”它代表一个空字符串,代表网站的根目录;
- 第二个元素是那个模式将使用的视图函数。
- 第三个元素暂时没看明白,猜测表示根目录。
这行代码就是告诉 Django,所有指向 根目录(url) 的请求都应由 learn.views.index 这个视图函数来处理。
Good, 你的第一个Django web页面已经有了,而且似懂非懂的学到了些东西,对吧。当你在运行应用的时候,Django是怎么处理请求的呢?且听下回分解,duang~
参考文献:
[1]. http://www.ziqiangxuetang.com/django/django-views-urls.html Django 教程 - 自强学堂
[2]. http://www.ccpt.cc/django_hello_world/ 墙外行人
[3]. http://djangobook.py3k.cn/2.0/chapter02/ The Django book
[4]. https://github.com/django/django/blob/master/django/contrib/admin/init.py