Django简介
Django是使用Python编写的一个开源Web框架。可以用它来快速搭建一个高性能的网站。
Django也是一个MVC框架。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式:
M 代表模型(Model),即数据存取层。 该层处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。
T 代表模板(Template),即表现层。 该层处理与表现相关的决定: 如何在页面或其他类型文档中进行显示。
V 代表视图(View),即业务逻辑层。 该层包含存取模型及调取恰当模板的相关逻辑。 你可以把它看作模型与模板之间的桥梁。
需要注意的是,不能简单的把MVC控制器,把MVC视图。
区别在于:
Django视图指定的数据。
或者说, Django将MVC中的视图进一步分解为“展现哪些数据”“如何展现”,使得Django的模板可以根据需要随时替换,而不仅仅限制于内置的模板。
至于MVC控制器部分,由Django框架的URLconf来实现。URLconf设计非常巧妙,其机制是使用正则表达式匹配URL,然后调用合适的Python函数。虽然一开始有些不习惯,但是你很快就会喜欢上它,因为URLconf对于URL的规则没有任何限制,你完全可以设计成任意的URL风格,不管是传统的,RESTful的,或者是另类的。
Django基本命令
1、下载Django:
pip3 install diango
2、创建一个django project
django-admin.py startproject mysite
当前目录下会生成mysite的工程,目录结构如下:
manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
urls.py ----- 负责把URL模式映射到应用程序。
wsgi.py------遵循WSGI规范,上线一般使用uwsgi+nginx
3、在mysite目录下创建应用
python manage.py startapp blog
migrations #数据库修改表结构记录
admin.py #Django提供的后台管理
apps.py #当前app配置文件
models.py #Django中的ORM,写指定的类 通过命令可以创建数据库结构
tests.py #项目的单元测试
views.py #MTV中的视图,用于写业务逻辑
4、启动django项目
python manage.py runserver 8080
这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到:
django常用命令
#创建django命令
django-admin.py startproject project-name
#创建django的app
python manage.py startapp app-name
或 django-admin.py startapp app-name
#同步数据库
python manage.py syncdb
#注意:Django 1.7.1及以上的版本需要用以下命令
python manage.py makemigrations
python manage.py migrate
#命令行调试模式
python manage.py runserver 8001
python manage.py runserver 0.0.0.0:8000
#清除数据库
python manage.py flush
#创建超级管理员
python manage.py createsuperuser
按照提示输入
#修改管理员密码
python manage.py changepassword username(需要修改的用户名)
#导入和导出数据
python manage.py dumpdata appname > appname.json
python manage.py loaddata appname.json
#进入数据库
python manage.py dbshell
在windows下推荐使用Pycharm创建Django项目
在Pycharm中创建Django项目的方法。
启动Pycharm后,点击file-->new project,出现下面的对话框。
选择Django栏目,输入项目名称,按照惯例的mysite。选择Python解释器版本,点击create创建。
Django将自动生成下面的目录结构:
不用手动调用diango-admin命令。同样的是,会自动创建与项目同名的目录,包含了配置文件。templates目录是Pycharm自动安装,HTML文件存放处,也就是MTV中的T的目录。manage.py则一样是Django项目管理文件。
启动django项目
在pycharm中启动服务器也不需要输入命令,如下图:
在Pycharm的上部工具栏中找到下面图示的图标。
点击edit configurations
在host中填入127.0.0.1,port中填入8000。
OK确定之后,点击绿色的三角,web服务就运行起来了。
按图所示,自动跳转到浏览器程序界面,如果看到下面的界面,程序可以正常使用
如果想让局域网内其他机器通过IP访问,则需要在全局设置setting中设置 ALLOWED_HOSTS = ['192.168.1.101'],
简单的django编写
创建Django
一个project包含很多个Django app以及对它们的配置。技术上,project的作用是提供配置文件,比方说哪里定义数据库连接信息, 安装的app列表, TEMPLATE_DIRS ,等等。一个app是一套Django功能的集合,通常包括模型和视图,按Python的包结构的方式存在。
创建app blog:
执行命令后,在项目结构中,可见新增了目录blog
编写urls,views,models
编写视图blog/views.py 文件
views:作为MVC中的C,接收用户的输入,调用数据库Model层和业务逻辑Model层,处理后将处理结果渲染到V层中去。
blog/views.py:
from django.http import HttpResponse
# Create your views here.
def index(request):
return HttpResponse("Hello, world 你好")
编写urls
urls,程序的入口,支持正则匹配访问url,将访问url映射到views中的具体某个函数中。
为了能调用到上面这个views,我们需要将views.index函数映射到URL中。
在blog目录没有urls.py 文件,我们在blog目录下创建一个urls.py 文件
blog/urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^$', views.index, name='index'),
]
将创建的urls.py 添加到全局urls.py中 mysite/urls.py
from django.conf.urls import include,url
from django.contrib import admin
urlpatterns = [
#当用户访问http://127.0.0.1:8000,采用views下面的index函数处理,^表示开头,$表示结尾
url(r'^blog/', include('blog.urls')),
#当用户访问http://127.0.0.1:8000/admin/时候使用admin.site.urls处理
url(r'^admin/', admin.site.urls),
]
通过访问 http://127.0.0.1:8000/blog/ 可以调用到所编写的views
通常我们都是将html文件返回给用户。
写这么一个index.html文件:
在templates目录中 编写一个index 文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<style>
.classh1{
color: antiquewhite;
}
</style>
<body>
<h1 class="classh1">Hell world!</h1>
</body>
</html>
index 文件
修改一下blog/views.py文件
from django.shortcuts import render #render模块是pycharm自动导入的
from django.http import HttpResponse
# Create your views here.
def index(request):
#return HttpResponse("Hello, world 你好")
return render(request,"index.html",)
让django知道我们的html文件在哪里,需要修改mysite/settings.py文件的相应内容。默认情况下,无需修改。
重新启动web服务。在浏览器刷新一下,你会看到带有样式的“hello world”。
静态文件
在django中,一般将静态文件放在static目录中。接下来,在mysite中新建个static目录。CSS,JS和各种插件都可以放置在这个目录里。
让django找到这个目录,需要对mysite/settings进行配置
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/
STATIC_URL = '/static/'
STATICFILES_DIRS=[
os.path.join(BASE_DIR,"static")
]
在index.html文件中,可以引入js文件了:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link href="/static/dist/css/bootstrap.css" rel="stylesheet">
<style>
*{
margin-top: 10px;
}
</style>
</head>
<body>
<div class="jumbotron container">
<h1>Hello world!!</h1>
<p ><a class="btn btn-primary btn-lg" href="#" role="button">Learn more</a></p>
</div>
<script src="/static/dist/js/jquery-3.2.1.min.js"></script>
<script src="/static/dist/js/bootstrap.min.js"></script>
</body>
</html>
View Code
重新启动web服务,刷新浏览器,查看结果。
接收用户发送的数据
web服务器和用户之间没有动态交互。
下面我们设计一个表单,让用户输入用户名和密码,提交给index这个url,服务器将接收到这些数据。
先修改index.html文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link href="/static/dist/css/bootstrap.css" rel="stylesheet">
<style>
*{
margin-top: 10px;
}
</style>
</head>
<body>
<h1 style="...">用户输入</h1>
<form action="/index/" method="post">
<input type="text" name="username"/>
<input type="password" name="password"/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
View Code
然后修改blog/views.py文件
def index(request):
if request.method == "POST":
username = request.POST.get("username",None)
password = request.POST.get("password",None)
print(username,password)
return render(request,"index.html")
View Code
重启web服务时,会出错,因为django有一个跨站请求保护机制,我们在settings文件中将它关闭。
浏览器,刷新页面:
输入点内容提交 ,然后我们在pycharm中可以看到相应的数据。
收到了用户的数据,但返回给用户的依然是个静态页面,通常我们会根据用户的数据,进行处理后在返回给用户。
django采用自己的模板语言,根据提供的数据,替换掉html中的相应部分
修改views.py文件:
数据库
支持SQLite 3(默认)、PostgreSQL 、MySQL、Oracle数据库的操作
# 默认是SQLit 3 的配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
# MySQL的配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'dbname', #注意这里的数据库应该以utf-8编码
'USER': 'xxx',
'PASSWORD': 'xxx',
'HOST': '',
'PORT': '',
}
}
# 对于python3的使用者们还需要再加一步操作
# 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替
# 如下设置放置的与project同名的配置的 __init__.py文件中
import pymysql
pymysql.install_as_MySQLdb()
# PostgreSQL配置
DATABASES = {
'default': {
'NAME': 'app_data',
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'USER': 'XXX',
'PASSWORD': 'XXX'
}
# Oracle配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.oracle',
'NAME': 'xx',
'USER': 'xxx',
'PASSWORD': 'a_xxx',
'HOST': '',
'PORT': '',
}
}
View Code