首页 > 代码库 > Django之初始庐山真面目

Django之初始庐山真面目

Django可以说是基于Python语言的一款非常成熟的框架,其功能之强大,应用之广泛,开发之便捷,可以说每一个细节都值得一赞

最重要的是,Django其实是我们学习Python过程中非常重要的部分之一,可以说Django学会70%那么找工作应该是不在话下了,学会80%找一份不错的工作是可以了,学会90%找一份满意的工作就足够了!

当然学习Django也不能太过激进,一夜之间并不能学会,也是靠之后慢慢研究,细心钻研,才能有更多更好的收货

现阶段先明白Django的运作原理,是首当其冲的任务.

在开始之前,请在心中默念3次我们的口号:

Django要学会,对得起学费
Django要学好,工作不难找
Django要学精,工资决不轻

---------------------------Let‘s Go---------------------------

那么请跟着我,咱们来一探Django的庐山真面目(基本运作原理):

Django的基本运作原理并不难,但是前提你要先理解什么是"请求","接收","响应","返回"这里说的有点啰嗦,但是也一定要强调这些,理解了它们,再去学Django,那就是平步青云,行云流水

"请求":由客户端向服务器端发起"请求"

"接收":服务器端收取客户端发来的"请求"

"响应":服务器端对"接收"来的客户端"请求"进行处理

"返回":由服务器端向客户端发起"返回"

以上就是简单的概念,再之后的讲解中会逐一击破!

Django就是基于这四点要素进行运作的,客户端就是PC上的浏览器,向服务器发起一个访问请求,服务器收到访问请求之后,找到客户端想要访问的页面,将页面进行处理返回给客户端(如图)

技术分享

怎么样,是不是理解起来并不难,有了初步的概念就可以往下进行了,可是等到了实际应用起来就会绕来绕去,自己把自己弄得稀里糊涂

---------------------------废话不多说Django项目走一遭---------------------------

首先要先有一个Django模块,这里就不做过多的阐述了

使用命令创建Django:

django-admin startproject sitename

这里一定要注意,你想将Django创建在哪个目录就一定要在该目录下执行上述命令

技术分享

当然如果你不想记住这些繁琐的命令,你也可以使用pycharm内置的创建Django项目功能,来创建,但这个功能的内部实际上也是又命令完成的,只不过它帮你自动完成了,你感知不到

技术分享

一点创建,pycharm就会为我们创建自己的Django项目了并且还会帮我打开

技术分享

刚刚见到新的Django项目是否一脸懵逼状呢?别慌别懵逼,龙哥带你开飞机:

与项目同名的目录:工程目录-用于存放配置文件,路由文件等相关

技术分享

__init__.py:
项目工程目录加载时执行的py脚本,可以用于更改环境变量等等

settings.py:
项目配置文件,这个文件老厉害了,如果没有这个文件整个Django项目运行就会崩溃,甚至说根本无法运行,配置文件在接下来会重点说一下

urls.py:
Django的路由文件,利用正则解析URL地址得到匹配的,视图函数(稍后会着重)

wsgi.py:通讯协议配置文件,在settings.py中WSGI_APPLICATION配置指向这个文件,而这个文件默认是使用get_wsgi_application来调用WSGI协议
settings:WSGI_APPLICATION = ‘project.wsgi.application‘
wsgi:application = get_wsgi_application()

技术分享

template文件夹:
用于存放可以被渲染的模板文件(html文件)

技术分享

manager.py:
顾名思义这里Django的管理文件,用于执行对Django项目的操作,比如新建app,建立moudels等

之后再研究一下settings.py:

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))):
和咱们平时写代码一样一样的,首先我要拿到我当前项目所在的绝对路径,这里就是拿到项目的绝对路径

SECRET_KEY:
提供算法的随机字符串(暂时不知道用途)

DEBUG:
是否启用调试模式,如果是True的话,页面报错会将错误信息打印在页面中,如果是False的话,错误信息不回打印到页面中,而如果页面出错,则会弹出Django默认的错误页面

ALLOWED_HOSTS=[]:
绑定域名,如果不使用此域名,是无法访问的

INSTALLED_APPS:
所注册的应用,如果有新创建的app,必须在此处进行注册,才可以进行后续的models操作

MIDDLEWARE:
所注册的中间件,这里就是在请求到达视图函数之前,所需要经历的所有中间件

ROOT_URLCONF= ‘StudentManager.urls‘:
根路由文件指向,当Django需要路由指向时,会读取这个参数

TEMPLATES:
模板相关配置,这里面关注DIRS就可以了,它是Django识别模板目录的配置
‘DIRS‘: [os.path.join(BASE_DIR, ‘templates‘)],
templates刚才咱们再上边说过它是默认的模板路径

WSGI_APPLICATION = ‘StudentManager.wsgi.application‘:
当前Django项目所使用的WSGI

DATABASES:
数据库配置(字典),这里面关注一下‘default‘(字典),它是用于配置Django所连接的数据库,default是链接名称,在Django项目中可以连接多个数据库.这里字典中的Key其实就是咱们在pymysql.connect中传入的参数:

技术分享
mysqlDB: {
ENGINE: django.db.backends.mysql,数据库驱动
NAME: "students",数据库名称
USER: "root",数据库用户名
PASSWORD: "123",数据库密码
HOST: "127.0.0.1",数据库所在服务器地址
PORT: 8000,数据库服务器端口
}
数据库配置

AUTH_PASSWORD_VALIDATORS:看名字就知道,这个是用来做密码验证的。
比如当你运行mange.py createsuperuser 时,输入的密码必须满足以上的条件。

LANGUAGE_CODE = ‘en-us‘
语言
TIME_ZONE = ‘UTC‘
时区
USE_I18N = True
是否国际化
USE_L10N = True
是否本地化

STATIC_URL:
映射到静态文件的URL路径,一般咱们默认为"/static/"
STATICFILES_DIRS:
元组类型,这里面存放的每一个元素都是URL路径用于,放各个app的static目录及公共的static目录,这里一定要在每个元素的后面加上","否则会报错的

今后的项目中,每一个APP中都要有一个static,都要配置到STATICFILES_DIRS中
很重要,不能错,怎么记?
静态文件们的目录们

 

还有一个尤为重要的文件跟路由配置文件urls.py

settings文件中已经提到了一个配置ROOT_URLCONF,跟路由,这个文件就是配置中的指向

urlpatterns:
url(r^index$, views.index),

这个列表中存放着多个url函数,url函数里面是什么,regex,view

这样的话,我们就可以理解为,url帮我们做的事情,就是当匹配到某字符串之后,执行某方法

当然这里还有regex,view,kwargs,name参数,我们来逐一看一下
regex,正则表达式
view,视图函数
kwargs,看起来是一个字典,没错这里面是额外参数,但是在你的视图函数中需要一个**kwargs来接收,否则会在抛出来一个,异常参数的错误
name,视图函数匿名,可以在模板中使用{% url "name" 参数 %}的方式来调用URL,这种调用url的方式可以有效避免掉一些恶意产生的"死地址",这种死地址可能会造成页面的崩溃

 

接下来,看一下:regex中的正则匹配方式:
第一种,标准规范化的单一路由对应

url(r^index$, views.index),

第二种,正则参数url路由

url(r^index/(\d*), views.index),
url(r^manage/(?P<name>\w*)/(?P<id>\d*), views.manage),

第三种,正则外的参数

url(r^index/$, index.Index.as_view(),{"name":"sb"}),

第四种,匿名url

url(r^index/$, index.Index.as_view(),name="a")

第五种,匿名反向URL

技术分享
1.url(r^index/$, index.Index.as_view(),name="a")
{% url "a" %}
reverse("a")
2.url(r^index/(\w+)/$, index.Index.as_view(),name="a")
{% url "a" 1 %}
reverse("a",args=(123,))
3.url(r^index/(?P<name>\w*)/(?P<id>\w*), index.Index.as_view(),name="a"),
{% url "a" 1 %}
reverse("a",kwargs={"name":"a","id":"b"})
匿名反向url

路由分发:
url(r‘^social/‘, include("Social.urls")),
但凡遇到social/的url被正则匹配到,都要去Social.urls中,进行重新定向
但是这里要注意的是,social已经被匹配走了,剩下的就是social/之后的内容
如:social/this/ 被定向到 Social.urls 中,就剩下了this/,所以在匹配时应注意

 

Django之初始庐山真面目