百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Django 入门介绍

ztj100 2025-08-03 09:30 4 浏览 0 评论

Django框架是PythonWeb三大主流框架之一,以其功能强大全面而受到众多开发者追捧,现如今Django已经更新到3版本,但是并不推荐使用,更多建议使用1版本。

Django版本Python版本1.112.7、3.4、3.5、3.6、3.7(在1.11.17中添加)2.03.4、3.5、3.6、3.72.13.5、3.6、3.72.23.5、3.6、3.7、3.8(在2.2.8中添加)3.0、3.13.6、3.7、3.8

  


2|0Django安装

   使用pip install django==1.11.11安装Django

   当下载完成后,可以使用django-admin来查看是否安装成功

C:\Users\云崖先生>django-admin

Type 'django-admin help <subcommand>' for help on a specific subcommand.

Available subcommands:

[django]
    check
    compilemessages
    createcachetable
    dbshell
    diffsettings
    dumpdata
    flush
    inspectdb
    loaddata
    makemessages
    makemigrations
    migrate
    runserver
    sendtestemail
    shell
    showmigrations
    sqlflush
    sqlmigrate
    sqlsequencereset
    squashmigrations
    startapp
    startproject
    test
    testserver
Note that only Django core commands are listed as settings are not properly configured (error: Requested setting INSTALLED_APPS, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.configure() before accessing settings.).

3|0常用命令

   第一次接触Django,这里有一些常用的CMD命令

基本命令解释说明django-admin startproject 项目名称创建一个Django项目python manage.py startapp 应用名称创建一个APPpython manage.py runserver ip地址 port号运行Django项目,如不指定IP与PORT默认为127.0.0.1与8000python manage.py makemigrations创建数据库的py文件python manage.py migrate将生成的py文件应用到数据库python manage.py flush数据库中数据全部清除,只留下表python manage.py createsuperuser创建管理员用户,密码(邮箱可以留空)python manage.py changepassword 用户名修改管理员用户密码

4|0注意事项

   使用Django时,有以下4条建议

   1.计算机名称不能包含中文

   2.IDE中一个窗口只开一个项目

   3.项目中所有文件夹均不要使用中文

   4.Python解释器请按照与之相对的Django版本进行选择,我这里使用Python3.6.6

5|0目录介绍

   接下来我们使用命令行创建出一个新的Django项目。

django-admin startproject Perfect 

   然后再新建一个APP,在Django中每一个 APP都相当于一个功能的集合,如有处理学生相关的业务就创建一个名为studentAPP,老师相关的业务就创建一个名为teacherAPP

python manage.py startapp app01  # 注意在此之前要cd进项目根目录

   目录如下:

-- PERFECT	项目文件夹

	-- app01	应用文件夹
		-- migrations.py		数据库迁徙文件
		-- admin.py 			django后台管理
		-- apps.py				注册相关
		-- models.py			数据库相关(ORM类)
		-- tests.py				测试文件
		-- views.py				视图相关函数
		
	-- Perfect	项目全局文件夹
		-- settings.py			全局配置文件
		-- urls.py				路由视图关系
		-- wsgi.py				wsgiref模块(Django基于该模块)
		
	-- manage.py 入口文件
	-- sqlite3	 自带微型数据库(可有可无)

   这个时候我们应该做一件事,在项目根目录下新建一个templates文件夹,用于存放HTML文档。

   (如果你是使用Pycharm进行创建Django项目可忽略这一步)

6|0配置文件

   打开项目全局文件夹下的settings.py,认识一下各个组件及其功能。

"""
Django settings for Perfect project.

Generated by 'django-admin startproject' using Django 1.11.11.

For more information on this file, see
https://docs.djangoproject.com/en/1.11/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.11/ref/settings/
"""

import os

# 像这样在项目内部构建路径:os.path.join(BASE_DIR,...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))


# 快速启动开发设置-不适合生产
# See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/

# SESSION相关的密钥,上线之后一定要保密
SECRET_KEY = 'm00e=*1gwly+6_g=tk&rd)lu8p-v_)1k(y&@7p_xn663$ph#'

DEBUG = True # DEBUG信息,会给提示,上线后改为False即可

ALLOWED_HOSTS = [] # 允许访问的主机,上线后改为 ["*"]


# 注册的APP,新建一个APP后需要进行手动配置
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

# 中间件,新手玩家请注释掉  'django.middleware.csrf.CsrfViewMiddleware',
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

ROOT_URLCONF = 'Perfect.urls'

# HTML文件存放路径配置
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

WSGI_APPLICATION = 'Perfect.wsgi.application'


# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
# 项目指定用的数据库,可以自行修改。默认使用sqlite3
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}


# https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators
# 认证相关
AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/1.11/topics/i18n/

LANGUAGE_CODE = 'en-us' # 语言

TIME_ZONE = 'UTC' # 时区

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/

# 静态文件,尤其重要
STATIC_URL = '/static/'

7|0手动配置

   好了,在创建完APP后需要在配置文件中进行一些手动配置,分别是注册APP,拼接HTML文档路径,这两个是必须的。此外还可选择性对csrf验证中间件进行注释,以及配置数据库链接,配置静态文件等等。

   这些都放在后面会说,后面会单独开一章settings的文章来具体写各个部分的用途。

   注意:如果使用Pycharm进行创建可忽略注册APP与拼接HTML文档路径,这些Pycharm都会帮你自动做好,但是还是建议你看一眼。

7|1注册APP

   注册APP非常简单,只需要在配置文件中找到下面的位置添加上上下面一条信息即可。

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',
]

   也可以进行简写

'app01',

7|2HTML路径

   拼接HTML文档路径也是在配置文件中添加。

   以下示例中templates是我对存放HTML文档的文件夹取的名字,推荐使用这个名字。

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR,"templates")],  # 在这里添加上 os.path.join(BASE_DIR,"templates")
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

8|0启动Django

   上面的基础工作做完之后,可以尝试启动一下Django服务了,但是为了体现效果这里还是超出范畴的写一点东西。

   返回一个简单的登录页面吧,这里不涉及数据库,静态文件等操作,所以你要做的就只有3步

   1.配置路由,

   2.配置一个视图函数,

   3.写一个页面

8|1配置路由

   配置路由的作用在于对不同的请求路径进行处理,返回不同的页面,这里面其实也有很多知识点,先不涉及做个简单的。

   在项目全局文件夹下,打开urls.py,导入一下app01views.py,再插入一条代码。

from django.conf.urls import url
from django.contrib import admin
from app01 import views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r"^login/",views.login),  # 新增代码
]

8|2编写函数

   现在就可以做一下app01下的views.py中的内容了,由于路由里对于
http://127.0.0.1:8000/login
的请求处理函数是login,所以我们需要写一个login函数来进行处理。

from django.shortcuts import render

# Create your views here.
def login(request):
    return render(request,"login.html") # 必须返回request

8|3页面编写

   上面的请求处理函数返回了一个login.html,这里其实就是返回的templates中的HTML文档,可惜我们现在还没有login.html,所以新建一个即可。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            list-style: none;
        }
        
        body {
            width: 100vw;
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
        }
        body main form{
            padding: 5px;
            border: #ddd solid 1px;
            background: #eee;

        }
        body main form p{
            margin: 10px;
        }
    </style>
</head>

<body>
    <main>
        <form action="#">
            <p><input type="text" name="username" placeholder="请输入您的用户名"></p>
            <p><input type="password" name="password" placeholder="请输入您的密码"></p>
            <p><button type="submit" disabled>提交</button></p>
        </form>
    </main>
</body>

</html>

8|4结果测试

   现在将开启Django服务进行测试操作

python manage.py runserver

   看下图,已经成功到访问到了页面,其实所有的Web框架流程无非就是解析请求资源,处理数据,返回HTML文档这三步骤。


最后,小编想说:我是一名python开发工程师,整理了一套最新的python系统学习教程,想要这些资料的可以关注私信小编“01”即可(免费分享哦)希望能对你有所帮助。

相关推荐

这个 JavaScript Api 已被废弃!请慎用!

在开发过程中,我们可能会不自觉地使用一些已经被标记为废弃的JavaScriptAPI。这些...

JavaScript中10个“过时”的API,你的代码里还在用吗?

JavaScript作为一门不断发展的语言,其API也在持续进化。新的、更安全、更高效的API不断涌现,而一些旧的API则因为各种原因(如安全问题、性能瓶颈、设计缺陷或有了更好的替代品)被标记为“废...

几大开源免费的 JavaScript 富文本编辑器测评

MarkDown编辑器用的时间长了,发现发现富文本编辑器用起来是真的舒服。...

比较好的网页里面的 html 编辑器 推荐

如果您正在寻找嵌入到网页中的HTML编辑器,以便用户可以直接在网页上编辑HTML内容,以下是几个备受推荐的:CKEditor:CKEditor是一个功能强大的、开源的富文本编辑器,可以嵌入到...

Luckysheet 实现excel多人在线协同编辑

前言前些天看到Luckysheet支持协同编辑Excel,正符合我们协同项目的一部分,故而想进一步完善协同文章,但是遇到了一下困难,特此做声明哈,若侵权,请联系我删除文章!若侵犯版权、个人隐私,请联系...

从 Element UI 源码的构建流程来看前端 UI 库设计

作者:前端森林转发链接:https://mp.weixin.qq.com/s/ziDMLDJcvx07aM6xoEyWHQ引言...

手把手教你如何用 Decorator 装饰你的 Typescript?「实践」

作者:Nealyang转发连接:https://mp.weixin.qq.com/s/PFgc8xD7gT40-9qXNTpk7A...

推荐五个优秀的富文本编辑器

富文本编辑器是一种可嵌入浏览器网页中,所见即所得的文本编辑器。对于许多从事前端开发的小伙伴来说并不算陌生,它的应用场景非常广泛,平时发个评论、写篇博客文章等都能见到它的身影。...

基于vue + element的后台管理系统解决方案

作者:林鑫转发链接:https://github.com/lin-xin前言该方案作为一套多功能的后台框架模板,适用于绝大部分的后台管理系统(WebManagementSystem)开发。基于v...

开源富文本编辑器Quill 2.0重磅发布

开源富文本编辑器Quill正式发布2.0版本。官方TypeScript声明...

Python之Web开发框架学习 Django-表单处理

在Django中创建表单实际上类似于创建模型。同样,我们只需要从Django类继承,则类属性将是表单字段。让我们在myapp文件夹中添加一个forms.py文件以包含我们的应用程序表单。我们将创建一个...

Django测试入门:打造坚实代码基础的钥匙

这一篇说一下django框架的自动化测试,...

Django ORM vs SQLAlchemy:到底谁更香?从入门到上头的选择指南

阅读文章前辛苦您点下“关注”,方便讨论和分享,为了回馈您的支持,我将每日更新优质内容。...

超详细的Django 框架介绍,它来了!

时光荏苒,一晃小编的Tornado框架系列也结束了。这个框架虽然没有之前的FastAPI高流量,但是,它也是小编的心血呀。总共16篇博文,从入门到进阶,包含了框架的方方面面。虽然小编有些方面介绍得不是...

20《Nginx 入门教程》使用 Nginx 部署 Python 项目

今天的目标是完成一个PythonWeb项目的线上部署,我们使用最新的Django项目搭建一个简易的Web工程,然后基于Nginx服务部署该PythonWeb项目。1.前期准备...

取消回复欢迎 发表评论: