美文网首页
[原](06)Django-TestOps网站

[原](06)Django-TestOps网站

作者: 哇哈哈E | 来源:发表于2020-01-08 14:03 被阅读0次

    Django-TestOps网站

    源码地址:https://github.com/ellaann/TestOpsPlatform

    项目实现功能

    概述:前端通过Bootstrap框架,借助AdminLte模板实现交互样式;后端通过Python+Django实现参数传递;数据库通过sqlite3,实现数据读取保存。

    1、注册

    sign_up.png

    2、登录


    sign_in.png

    3、登录后的主页显示


    index.png

    4、网站归纳

    1)公司网站

    company_websites_online.png

    2)常用网站

    common_websites.png

    3)新增网站

    add_new.gif

    5、项目部署&上线

    1)测试环境部署


    test_env_deploy.png

    2)通过dwebsocket,实现与服务器连接,输入查询指令后,页面的实时滚动


    test_deploy.gif

    6、SQL同步

    sql_sync.png

    一、官方文档

    Django中文官网: https://docs.djangoproject.com/zh-hans/3.0/

    Django英文官网: https://docs.djangoproject.com/en/3.0/

    二、初始化

    1、创建项目

    使用 startproject 来创建项目

    django-admin startproject edrainsite

    项目显示:

    test_ops/
        manage.py
        test_ops/
            __init__.py
            settings.py
            urls.py
            asgi.py
            wsgi.py
    

    这些目录和文件的用处是:

    • The outer test_ops/ root directory is a container for your project. Its name doesn't matter to Django; you can rename it to anything you like.
    • manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。你可以阅读 django-admin and manage.py 获取所有 manage.py 的细节。
    • 里面一层的 test_ops/ 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 test_ops.urls).
    • test_ops/init.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。如果你是 Python 初学者,阅读官方文档中的 更多关于包的知识。
    • test_ops/settings.py:Django 项目的配置文件。如果你想知道这个文件是如何工作的,请查看 Django 配置 了解细节。
    • test_ops/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。阅读 URL调度器 文档来获取更多关于 URL 的内容。
    • test_ops/asgi.py: 兼容ASGI的Web服务器为您的项目提供服务的入口点。See How to deploy with ASGI for more details.
    • test_ops/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。阅读 如何使用 WSGI 进行部署 了解更多细节。

    2、运行项目

    py manage.py runserver 127.0.0.1:8028
    样就可以运行起来啦 打开网址:http://127.0.0.1:8028/ 进行校验

    3、创建应用

    py manage.py startapp sign

    这些目录和文件的用处是:

    • migrations/:用于记录models中数据的变更;
    • admin.py:映射models中的数据到Django自带的admin后台;
    • apps.py:用于应用程序的配置(在新的Django版本中新增文件);
    • models.py: Django的模型文件,创建应用程序数据表模型(对应数据库的相关操作);
    • tests.py:创建Django测试用例;
    • views.py: Django的视图文件,控制向前段页面显示的内容。

    三、编写第一个视图

    1、打开 sign/views.py

    把下面这些 Python 代码输入进去:

    from django.http import HttpResponse
    
    
    def index(request):
        return HttpResponse("Hello, world. You're at the sign index.")
    

    这是 Django 中最简单的视图。如果想看见效果,我们需要将一个 URL 映射到它——这就是我们需要 URLconf 的原因了。

    为了创建 URLconf,请在 sign目录里新建一个 urls.py 文件。

    2、在 sign目录里新建一个 urls.py 文件

    输入如下代码:

    from django.urls import path
    
    from . import views
    
    urlpatterns = [
        path('', views.index, name='index'),
    ]
    

    3、在根 URLconf 文件中指定创建的 sign.urls 模块

    test_ops/urls.py 文件的 urlpatterns 列表里插入一个 include(), 如下:

    from django.contrib import admin
    from django.urls import path, include
    
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('sign/', include('sign.urls')),
    ]
    

    函数 include() 允许引用其它 URLconfs。每当 Django 遇到 include() 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。

    include() 的理念是使其可以即插即用。因为sign应用有它自己的 URLconf( sign/urls.py ),他们能够被放在 "/sign/" , "/fun_sign/" ,"/content/sign/",或者其他任何路径下,这个应用都能够正常工作。

    当包括其它 URL 模式时你应该总是使用 include()admin.site.urls 是唯一例外。

    四、通过templates来展示页面

    1、在sign文件夹下面,创建templates文件夹

    2、创建sign.html文件

    <html>
        <head>
            <title>Sign</title>
        </head>
        <body>
            <h1>Hello Web!</h1>
        </body>
    </html>
    

    3、修改sign/urls.py文件

    from django.shortcuts import render
    
    
    def sign(request):
        # return HttpResponse("Hello, world. You're at the sign index.")
        return render(request, 'sign.html')
    

    4、修改settings.py文件,新增'sign',文字

    INSTALLED_APPS = [
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        # 你项目的 TEMPLATES 配置项描述了 Django 如何载入和渲染模板。
        # 默认的设置文件设置了 DjangoTemplates 后端,并将 APP_DIRS 设置成了 True。
        # 这一选项将会让 DjangoTemplates 在每个 INSTALLED_APPS 文件夹中寻找 "templates" 子目录。
        'sign',
    ]
    

    你项目的 TEMPLATES 配置项描述了 Django 如何载入和渲染模板。默认的设置文件设置了 DjangoTemplates 后端,并将 APP_DIRS 设置成了 True。这一选项将会让 DjangoTemplates 在每个 INSTALLED_APPS 文件夹中寻找 "templates" 子目录。这就是为什么尽管我们没有像在第二部分中那样修改 DIRS 设置,Django 也能正确找到 polls 的模板位置的原因。

    输入网址:http://127.0.0.1:8028/sign/

    五、数据库配置

    Django 提供完善的模型(model)层主要用来创建和存取数据,不需要我们直接对数据库操作。

    Django模型的基础知识:

    • 每个模型是一个Python类,继承django.db.models.Model类
    • 该模型的每个属性表示一个数据库表字段
    • 所有这一切,已经给了你一个自动生成数据库访问的API

    1、打开 test_ops/settings.py ,配置Database

    这是个包含了 Django 项目设置的 Python 模块。通常,这个配置文件使用 SQLite 作为默认数据库。如果你不熟悉数据库,或者只是想尝试下 Django,这是最简单的选择。Python 内置 SQLite,所以你无需安装额外东西来使用它。当你开始一个真正的项目时,你可能更倾向使用一个更具扩展性的数据库,例如 PostgreSQL,避免中途切换数据库这个令人头疼的问题。

    如果你想使用其他数据库,你需要安装合适的 database bindings ,然后改变设置文件中 DATABASES 'default' 项目中的一些键值:

    • ENGINE -- 可选值有 'django.db.backends.sqlite3''django.db.backends.postgresql''django.db.backends.mysql',或 'django.db.backends.oracle'。其它 可用后端
    • NAME - 数据库的名称。如果使用的是 SQLite,数据库将是你电脑上的一个文件,在这种情况下, NAME 应该是此文件的绝对路径,包括文件名。默认值 os.path.join(BASE_DIR, 'db.sqlite3') 将会把数据库文件储存在项目的根目录。
    # Database
    # https://docs.djangoproject.com/en/3.0/ref/settings/#databases
    
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3',
            'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        }
    }
    

    2、打开 test_ops/settings.py ,配置INSTALLED_APPS

    test_ops/settings.py文件头部的 INSTALLED_APPS 设置项。这里包括了会在你项目中启用的所有 Django 应用。应用能在多个项目中使用,你也可以打包并且发布应用,让别人使用它们。

    通常, INSTALLED_APPS 默认包括了以下 Django 的自带应用:

    这些应用被默认启用是为了给常规项目提供方便。

    默认开启的某些应用需要至少一个数据表,所以,在使用他们之前需要在数据库中创建一些表。请执行以下命令:

    ...\> py manage.py migrate

    就像之前说的,为了方便大多数项目,我们默认激活了一些应用,但并不是每个人都需要它们。如果你不需要某个或某些应用,你可以在运行 migrate 前毫无顾虑地从 INSTALLED_APPS 里注释或者删除掉它们。 migrate 命令只会为在 INSTALLED_APPS 里声明了的应用进行数据库迁移。

    3、创建模型

    在sign/models.py文件中,新增

    
    

    4、当模型创建好以后,执行数据库迁移

    使用如下命令进行数据库表的初始化和创建(迁移):

    运行 python manage.py makemigrations sign 为模型的改变生成迁移文件。
    运行 python manage.py migrate 来应用数据库迁移。
    

    六、认证登录

    1、创建admin系统用户

    ...\> python manage.py createsuperuser

    2、输入用户、密码信息

    py manage.py createsuperuser
    
    sername (leave blank to use 'edrain'): admin
    
    mail address: admin@mail.com
    
    Password:
    
    assword (again):
    
    his password is too short. It must contain at least 8 characters.
    
    his password is too common.
    
    ypass password validation and create user anyway? [y/N]: y
    
    uperuser created successfully.
    

    七、开发模式

    这段话在Django官方文档也曾出现过:鼓励松耦合以及对应用程序中不同部分的严格分割。

    1、MVC开发模式

    MVC:Model-View-Controller

    • model:数据存取层。
    • view:表现逻辑,代表的是系统中选择显示什么和怎么显示的部分。
    • controller:业务逻辑,代表系统中根据用户输入及需要访问模型,使用哪个视图的哪部分。

    对应到Django后:

    • Model:数据存取部分,由Django数据库层处理;
    • View:表现逻辑,选择显示哪些数据要显示以及怎样显示的部分,由Django的视图和模板处理;
    • Controller:业务逻辑,由Django根据URLconf设置,对给定URL调用适当的Python函数。

    2、MTV开发模式

    由于Controller由框架自行处理,而Django里更关注的是模型(Model)、模板(Template)、视图(View),因此Django也被称为MTV框架。

    MTV:Model-Template-Views

    • Model:模型,数据存取层,该层处理与数据相关的所有事务,即如何存取、如果验证有效等;
    • Template:模板,表现层,该层处理与表现相关的所有事务,即如何在页面或者其他类型文档中进行显示;
    • View:视图,业务逻辑层,该层包含存取模型及调取恰当模板的相关逻辑,可以看作是模型和模板之间的桥梁。

    八、小技巧

    1、去除模板中的硬编码 URL

    1)修改sign/templates/sign/sign_in.html文件

    当发送登录请求时,链接是硬编码的:

    <form action="/login_action/" method="post">

    问题在于,硬编码和强耦合的链接,对于一个包含很多应用的项目来说,修改起来是十分困难的。然而,因为你在 sign.urlsurl() 函数中通过 name 参数为 URL 定义了名字,你可以使用 {% url %} 标签代替它。

    替代如下:

    <form action="{% url 'login_action' %}" method="post">

    这个标签的工作方式是在 sign.urls 模块的 URL 定义中寻具有指定名字的条目。你可以回忆一下,具有名字 'login_action' 的 URL 是在如下语句中定义的。

    2)修改sign/urls.py文件,新增name='login_action'

    path('login_action/', views.login_action, name='login_action'), # name的值可以在html中关联{% url 'xxx' %} template tag

    如果你想改变登录视图的 URL,比如想改成 sign/edrain/login_action/ ,你不用在模板里修改任何东西(包括其它模板),只要在sign/urls.py 里稍微修改一下就行。

    修改如下:

    # added the word 'edrain'
    path('edrain/login_action/', views.login_action, name='login_action'),
    

    2、为 URL 名称添加命名空间

    Django 如何知道 {% url %} 标签到底对应哪一个应用的 URL 呢?

    1)在根 URLconf 中添加命名空间。在 sign/urls.py 文件中稍作修改,加上 app_name 设置命名空间:

    from django.urls import path
    
    from . import views
    
    app_name = 'sign'  # 设置命名空间
    urlpatterns = [
        path('', views.sign, name='sign'),
        path('login_action/', views.login_action, name='login_action'),  # name的值可以在html中关联{% url 'xxx' %} template tag
    ]
    

    2)修改sign/templates/sign/sign_in.html文件,

    <form action="{% url 'login_action' %}" method="post">

    修改为指向具有命名空间的详细视图,变更为:

    <form action="{% url 'sign:login_action' %}" method="post">

    3、HttpReponseDirect使用软编码链接

    硬编码链接:可以通过使用HttpResponseRedirect('/index/?page=2')直接获取第2页的文章列表

    HttpReponseDirect只支持hard coded urls(硬编码链接), 不能直接使用命名的URL,如使用HttpResponseDirect('blog:article_list‘)是错误的。

    在使用URL命名时,我们需要先通过URL反向解析方法reverse先对命名URL(article_list)进行解析,然后再使用HttpReponseRedirect定向(如下面的代码)。背后的逻辑是reverse('blog:article_list')='/index/'。

    def login_action(request):
        """执行 登录按钮 操作后的界面"""
        if request.method == 'POST':
            username = request.POST.get('username', '')  # 此处对应表单的form中的input的 name属性
            password = request.POST.get('password', '')
            if username == 'qwer' and password == 'qwer':
                return HttpResponseRedirect(reverse('sign:home'))  # 对路径重定向,成功登陆之后重新指向 /sign/home/ 页面
    

    链接:https://blog.csdn.net/weixin_42134789/article/details/81505963

    九、疑问

    Q1:db.sqlite3是什么?

    A1:链接:https://www.runoob.com/sqlite/sqlite-intro.html

    SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库一样,您不需要在系统中配置。就像其他数据库,SQLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SQLite 直接访问其存储文件。

    Q2:项目和应用区别?

    A2:链接:https://docs.djangoproject.com/zh-hans/3.0/intro/tutorial01/

    应用程序是执行某项操作的Web应用程序,例如Weblog系统,公共记录数据库或小型民意调查应用程序。

    项目是特定网站的配置和应用程序的集合。一个项目可以包含多个应用程序。一个应用程序可以在多个项目中。

    Q3:Pycharm提示“Unresolved attribute reference 'objects' for class 'UserModel'”

    A3:You need to enable Django support. Go to

    PyCharm -> Preferences -> Languages & Frameworks -> Django

    and then check Enable Django Support

    Q4:USE_TZ时区问题

    datetime.datetime.now()、datetime.datetime.utcnow()与django.util.timezone.now()的区别

    datetime.datetime.now():
    输出的永远是本地时间(naive time)与配置无任任何关系。

    datetime.datetime.utcnow():
    如果setting中配置USE_TZ=True则输出的是UTC时间(naive time);如果setting中配置USE_TZ=False,则该输出时间与datetime.datetime.now()完全相同。

    django.util.timezone.now():
    如果setting中配置USE_TZ=True则输出的是UTC时间(active time),如果配置USE_TZ=False,则与datetime.datetime.now()完全相同。

    相关文章

      网友评论

          本文标题:[原](06)Django-TestOps网站

          本文链接:https://www.haomeiwen.com/subject/uuqsactx.html