是一个由 Python 编写的一个开放源代码的 Web 应用框架。
使用 Django,只要很少的代码,Python 的程序开发人员就可以轻松地完成一个正式网站所需要的大部分内容,并进一步开发出全功能的 Web 服务 Django 本身基于 MVC 模型,即 Model(模型)+ View(视图)+ Controller(控制器)设计模式,MVC 模式使后续对程序的修改和扩展简化,并且使程序某一部分的重复利用成为可能。
MVC 优势:
Python 加 Django 是快速开发、设计、部署网站的最佳组合。
MVC 模式(Model–view–controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller)。
MVC 以一种插件式的、松耦合的方式连接在一起。
模型(M)- 编写程序应有的功能,负责业务对象与数据库的映射(ORM)。
视图(V)- 图形界面,负责与用户的交互(页面)。
控制器(C)- 负责转发请求,对请求进行处理。
Django 的 MTV 模式本质上和 MVC 是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django 的 MTV 分别是指:
sudo pip install virtualenv
sudo pip install virtualenvwrapper
查找python和 virtualenvwrapper安装位置
which virtualenvwrapper.sh
which python3
sudo vim ~/.bash_profile
插入如下代码:
- export WORKON_HOME=$HOME/.virtualenvs
- export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3(python目录)
- export VIRTUALENVWRAPPER_VIRTUALENV_ARGS=' -p /usr/bin/python3 '
- export PROJECT_HOME=$HOME/Devel
- source /usr/local/bin/virtualenvwrapper.sh(virtualenvwrapper目录)
source ~/.bash_profile
尝试创建django环境 ,并安装
mkvirtualenv my_django_environment
pip3 install django
❤️测试安装
在你的命令提示符/终端导航到你想存储你Django应用程序的位置。为您的测试站点创建一个文件夹并进入其中。
- mkdir django_test
- cd django_test
然后,可以像所展示的一样使用 django-admin 工具创建一个名为“ mytestsite ”的新框架站点。创建网站后,可以 CD 到此文件夹,并将在其中找到管理项目的主要脚本,名为manage.py。
- django-admin startproject mytestsite
- cd mytestsite
可以在这个文件夹中使用manager.py和runserver
命令运行开发 web 服务器。
python3 manage.py runserver
✨如果报错可尝试下面的命令
python3 manage.py migrate
一旦服务器运行,可以通过本地 Web 浏览器打开http://127.0.0.1:8000/
来查看该站点:
- mkdir locallibrary
- cd locallibrary
用django-admin startproject
命令创建新项目,并进入该文件夹。
- django-admin startproject locallibrary
- cd locallibrary
❤️❤️locallibrary 项目的子文件夹是整个网站的进入点:
manage.py脚本可以创建应用,和数据库通讯,启动开发用网络服务器。
python3 manage.py startapp catalog
打开项目设置文件 locallibrary/locallibrary/settings.py 找到 INSTALLED_APPS
列表里的定义。 如下所示,在列表的最后添加新的一行。
- INSTALLED_APPS = [
- 'django.contrib.admin',
- 'django.contrib.auth',
- 'django.contrib.contenttypes',
- 'django.contrib.sessions',
- 'django.contrib.messages',
- 'django.contrib.staticfiles',
- 'catalog.apps.CatalogConfig',
- ]
🌟tips:
(1)新的这行详细说明了应用配置文件在 (CatalogConfig
) /locallibrary/catalog/apps.py 里,当你创建应用时就完成了这个过程。
(2)注意到INSTALLED_APPS已经有许多其他的应用了
(还有 MIDDLEWARE
, 在 settings 的下面)。这些应用为 Django administration site 提供了支持和许多功能 (包括会话,认证系统等)
//***为避免性能上的差异,最好在生产和开发中使用同一种数据库。在这个项目里,我们使用 SQLite。
***//
改时区
TIME_ZONE = 'Asia/Beijing'
//安全注意⚠️
SECRET_KEY
. 这个密匙值是 Django 网站安全策略的一部分。如果在开发环境中没有包好这个密匙,把代码投入生产环境时最好用不同的密匙代替。(可能从环境变量或文件中读取)。DEBUG
. 这个会在 debug 日志里输出错误信息,而不是输入 HTTP 的返回码。在生产环境中,它应设置为 false,因为输出的错误信息会帮助想要攻击网站的人。将新的项添加到 urlpatterns
列表中。
- # Use include() to add paths from the catalog application
- from django.conf.urls import include
- from django.urls import path
-
- urlpatterns += [
- path('catalog/', include('catalog.urls')),
- ]
把网站的根 URL(例:127.0.0.1:8000
) 重定向到该 URL:127.0.0.1:8000/catalog/
将以下行再次添加到文件的底部:
- #Add URL maps to redirect the base URL to our application
- from django.views.generic import RedirectView
- urlpatterns += [
- path('', RedirectView.as_view(url='/catalog/')),
- ]
Django 默认不提供 CSS, JavaScript, 和图片等静态文件 。可以通过添加以下行在开发期间启用静态文件的服务。
- # Use static() to add url mapping to serve static files during development (only)
- from django.conf import settings
- from django.conf.urls.static import static
-
- urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
在 catalog 文件夹下创建一个名为 urls.py 的文件,并添加以下文本以定义导入(空)的 urlpatterns
。这是我们在编写应用时添加式样的地方。
(1)运行数据库迁移
//Django 使用对象关系映射器(ORM)将 Django 代码中的模型定义映射到底层数据库使用的数据结构。//
运行以下命令来定义数据库中这些模型的表(确保你位于包含 manage.py 的目录中):
- python3 manage.py makemigrations
- python3 manage.py migrate
(2)运行网站
通过调用 runserver
命令运行 Web 服务器
python3 manage.py runserver
//现在已经创建了一个完整的基本网站项目骨架,你可以继续填加网址,模型,视图和模版。
//Django 允许你定义一对一 (OneToOneField
),一对多 (ForeignKey
) 和多对多 (ManyToManyField
) 的关系
//模型通常在应用程序的Models .py文件中定义。它们被实现为django.db.models的子类。
- from django.db import models
-
- class MyModelName(models.Model):
- """
- A typical class defining a model, derived from the Model class.
- """
-
- # Fields
- my_field_name = models.CharField(max_length=20, help_text="Enter field documentation")
- ...
-
- # Metadata
- class Meta:
- ordering = ["-my_field_name"]
-
- # Methods
- def get_absolute_url(self):
- """
- Returns the url to access a particular instance of MyModelName.
- """
- return reverse('model-detail-view', args=[str(self.id)])
-
- def __str__(self):
- """
- String for representing the MyModelName object (in Admin site etc.)
- """
- return self.field_name
创建和修改记录
- # Create a new record using the model's constructor.
- a_record = MyModelName(my_field_name="Instance #1")
-
- # Save the object into the database.
- a_record.save()
-
- # Access model field values using Python attributes.
- print(a_record.id) #should return 1 for the first record.
- print(a_record.my_field_name) # should print 'Instance #1'
-
- # Change record by modifying the fields, then calling save().
- a_record.my_field_name="New Instance Name"
- a_record.save()
-
存储关于图书类别的信息:
- class Genre(models.Model):
- """
- Model representing a book genre (e.g. Science Fiction, Non Fiction).
- """
- name = models.CharField(max_length=200, help_text="Enter a book genre (e.g. Science Fiction, French Poetry etc.)")
-
- def __str__(self):
- """
- String for representing the Model object (in Admin site etc.)
- """
- return self.name
使用CharField来表示图书的标题和isbn:
- from django.urls import reverse #Used to generate URLs by reversing the URL patterns
-
- class Book(models.Model):
- """
- Model representing a book (but not a specific copy of a book).
- """
- title = models.CharField(max_length=200)
- author = models.ForeignKey('Author', on_delete=models.SET_NULL, null=True)
- # Foreign Key used because book can only have one author, but authors can have multiple books
- # Author as a string rather than object because it hasn't been declared yet in the file.
- summary = models.TextField(max_length=1000, help_text="Enter a brief description of the book")
- genre = models.ManyToManyField(Genre, help_text="Select a genre for this book")
- # ManyToManyField used because genre can contain many books. Books can cover many genres.
- # Genre class has already been defined so we can specify the object above.
-
- def __str__(self):
- """
- String for representing the Model object.
- """
- return self.title
-
-
- def get_absolute_url(self):
- """
- Returns the url to access a particular book instance.
- """
- return reverse('book-detail', args=[str(self.id)])
BookInstance表示某人可能会借阅的一本书的特定副本,并包括关于该副本是否可用、预期归还日期、“印记”或版本详细信息以及图书馆中该书的惟一id的信息:
- import uuid # Required for unique book instances
-
- class BookInstance(models.Model):
- """
- Model representing a specific copy of a book (i.e. that can be borrowed from the library).
- """
- id = models.UUIDField(primary_key=True, default=uuid.uuid4, help_text="Unique ID for this particular book across whole library")
- book = models.ForeignKey('Book', on_delete=models.SET_NULL, null=True)
- imprint = models.CharField(max_length=200)
- due_back = models.DateField(null=True, blank=True)
-
- LOAN_STATUS = (
- ('m', 'Maintenance'),
- ('o', 'On loan'),
- ('a', 'Available'),
- ('r', 'Reserved'),
- )
-
- status = models.CharField(max_length=1, choices=LOAN_STATUS, blank=True, default='m', help_text='Book availability')
-
- class Meta:
- ordering = ["due_back"]
-
-
- def __str__(self):
- """
- String for representing the Model object
- """
- return '%s (%s)' % (self.id,self.book.title)
该模型将作者定义为具有名、姓、出生日期和(可选)死亡日期。它指定在默认情况下,__str__()返回姓、名顺序的名称。get_absolute_url()方法反转作者-细节URL映射,以获取用于显示单个作者的URL:
- class Author(models.Model):
- """
- Model representing an author.
- """
- first_name = models.CharField(max_length=100)
- last_name = models.CharField(max_length=100)
- date_of_birth = models.DateField(null=True, blank=True)
- date_of_death = models.DateField('Died', null=True, blank=True)
-
- def get_absolute_url(self):
- """
- Returns the url to access a particular author instance.
- """
- return reverse('author-detail', args=[str(self.id)])
-
-
- def __str__(self):
- """
- String for representing the Model object.
- """
- return '%s, %s' % (self.last_name, self.first_name)
❤️❤️重新运行数据库迁移,将它们添加到数据库中
- python3 manage.py makemigrations
- python3 manage.py migrate
/locallibrary/catalog/admin.py) 中打开 admin.py,复制以下到文件的底部来注册模型。该代码简单地导入模型,调用 admin.site.register 来注册它们。
- from .models import Author, Genre, Book, BookInstance
-
- admin.site.register(Book)
- admin.site.register(Author)
- admin.site.register(Genre)
- admin.site.register(BookInstance)
python3 manage.py createsuperuser
3.3 登入并使用网站
重新启动
python3 manage.py runserver
使用刚刚注册的用户、密码可登录