Django笔记 —— 入门简介

时间:2022-12-13 12:59:16

  最近在学习Django,打算玩玩网页后台方面的东西,因为一直很好奇但却没怎么接触过。Django对我来说是一个全新的内容,思路想来也是全新的,或许并不能写得很明白,所以大家就凑合着看吧~

  本篇笔记(其实我的所有笔记都是),并不会过于详细的讲解。因此如果有大家看不明白的地方,欢迎在我正版博客下留言,有时间的时候我很愿意来这里与大家探讨问题。(当然,不能是简简单单就可以百度到的问题-.-)

  我所选用的教材是《The Django Book 2.0》,本节是入门简介部分,对应书中前两章。

------------------------------------------------------------------------------------------------------------------------------------------------

1、对Django的初步了解

  “本书所讲的是Django:一个可以使Web开发工作愉快并且高效的Web开发框架。 使用Django,使你能够以最小的代价构建和维护高质量的Web应用。”

  这是原书开篇对Django的介绍。不过对于它的“最小”,哪怕翻译无误,我的态度也是一笑置之。原因很简单,我并不了解其它Web开发框架,因此无法评论孰优孰劣,对于本书的评价也不能盲目认同。(小小啰嗦一下,大家忽略~)

2、什么是框架

  对于使用Python开发网页,在1998年的时候,直接使用CGI标准开发很流行——“首先做一个Python脚本,输出HTML代码,然后保存成.cgi扩展名的文件,通过浏览器访问此文件。”

  而在长期的开发中,人们慢慢从代码里总结出了一套套框架(也就是代码的模板),这就是Web开发框架,Django也就是其中之一——“Web框架为应用程序提供了一套程序框架, 这样你可以专注于编写清晰、易维护的代码,而无需从头做起。简单来说,这就是Django所能做的。”

3、MVC设计模式

  MVC设计模式,对应的中文含义是“模型-视图-控制器”。简单来说,就是把原本都写在一起的代码给拆分成松散结合的几部分,从而让思路更清晰、开发维护更方便。具体内容,这里不详加赘述。

4、Django历史与特点

  Django诞生于2003年秋天,是由Kansas州Lawrence城中的一个网络开发小组编写的。当时,他们被要求在很短的时间内完成大量的新闻站点,因此也就开发了一个Web开发框架来完成这个工作。直至2005年夏天,这个框架已经在开发许许多多网站的过程中基本开发完成,因此他们决定把这个框架发布为一个开源软件。

  之后的数年间,Django在世界广泛传播,有了数以万计的用户和贡献者。虽然仍旧是由最初的开发者(那个World Online小组的Adrian和Jacob)掌握,但其发展方向相对受社区团队的影响更大。

  说这些历史,除了为了让大家更好地了解Django,还因为它是开源的。虽然我并不反感各种商业软件,但我的确从心底里喜欢开源软件。个人性格问题,不多谈。至于更详细的Django历史,大家可以去看《The Django Book 2.0》或者自行搜索。

  除了开源软件本身的社区之外,Django还有个与历史相关的特点,那就是特别适合开发内容类的网站(因为它本身就是用来开发新闻站点的)。

5、开发环境

软件名称 版本 查看方法
Operating System Ubuntu 14.10 Ubuntu机器右上角可以找到“关于这台计算机”,点进去可以看到版本
Python 2.7.8 在终端输入“python --version”
Django 1.8.0.final.0 在终端输入"python",然后依次输入"import django"和"django.VERSION"
MySQL 5.6.24 在终端输入"mysql --version",看到"Distrib 5.6.24"就对了

  注意,我的Python和Django版本都与书中不符,因此笔记中全是以我的版本为准,书中版本并不保证兼容。

  希望大家在遇到版本兼容问题的时候,多去看看官方文档。个人感觉,除了恰好有人写的靠谱文章之外,文档总是你解决常见问题的最好方案。

6、尝试开发第一个项目(Hello World)

  之所以记录下这个过程,是为了说明使用Django开发时应当记住的一些小习惯,这都是很重要的东西。另外,再次说明,我写的仅仅是Django学习笔记,如果大家想看更详细的内容,那么一定要去看《The Django Book 2.0》原书,笔记只适合查阅。

  首先打开终端,在~/djcode/路径输入

    django-admin.py startproject qiqisite  # 创建一个站点,叫做qiqisite

  打开qiqisite,会发现里面已经建好了站点

相对路径 文件名 简单介绍
./ manage.py

一种命令行工具,允许你以多种方式与该Django项目进行交互。

键入python manage.py help,可以看到它提供的命令。

你应当不需要编辑这个文件;在这个目录下生成它纯是为了方便。

./qiqisite/ __init__.py

让Python把该目录当成一个开发包(即一组模块)所需的文件。

这是一个空文件,一般你不需要修改它。

settings.py

该Django项目的设置或配置。

应当查看并理解这个文件中可用的设置类型及其默认值。

urls.py

Django项目的URL设置。

可视其为你的django网站的目录。

目前,它里面只有一些必须代码,构成了一个Hello World。

wsgi.py

和apache交互用的

(源自csdn上的问答,详见http://bbs.csdn.net/topics/390226637)

  下面,仍在~/djcode/qiqisite/下输入

    python manage.py runserver  # 这将会在端口8000启动一个本地服务器, 并且只能从你的这台电脑连接和访问。

  如此一来,便可以在浏览器输入

    http://127.0.0.1:8000/  # 访问qiqisite这个站点

  注意,这种建立站点的方法用的是Django自带的开发服务器,这是个内建的、轻量的Web服务。它虽然使用简单,但与产品级的Web服务器(例如Apache)有很大差距——用它建立的服务器,在同一时间只能可靠的处理一次单个请求,并且没有进行任何类型的安全审计。因此,它只适用于调试,完全无法发布真正的站点。

------------------------------------------------------------------------------------------------------------------------------------------------

  至此,Django入门简介完成。下一篇,将从“视图与URL配置”开始,真正进入Django。