美文网首页
2、Django_创建第一个应用

2、Django_创建第一个应用

作者: 猪儿打滚 | 来源:发表于2019-09-26 14:22 被阅读0次
    Django的特点
    • 优点
      python语言、代码干净、整洁
      提供管理后台,可以快速开发
      复用度高,设计和使用上遵循DRY原则
      易于扩展复用的中间件
      内置安全框架
      丰富的第三方类库
    • 缺点
      单体应用 - 不易并行开发,单点扩展
      不适合非常小的几行代码的项目
      不适用于高并发的to C 项目
    一、安装
    • 官网下载安装包
      https://media.djangoproject.com/releases/2.2/Django-2.2.5.tar.gz;没用过,接下来的步骤自行百度
    • pip下载
      1.命令:pip isntall Django
      2.坑位:
      出现WARNING: Retrying (Retry(total=4, connect=None, read=None, redirect=None, status=None)) after connection broken by 'SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate
      解决方法:使用pip install 【需要下载的东西】-i http://pypi.douban.com/simple --trusted-host pypi.douban.com进行安装
    二、创建项目和运行
    • 命令行
      1.创建项目
    django -admin startproject 项目名
    

    2.运行项目

    $ python manage.py runserver
    $ python manage.py runserver ip:端口
    
    • Pycharm

      1.创建项目: create
    • 坑位
      出现Make sure that you use the Django version of 'pip' installed for your Python interpreter
      解决方法:切换到提示框所说的路径下,然后运行pip install Django -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
      然后再点击提示框的按钮
      结果:
      创建成功
    2.运行项目: 运行成功 3.访问localhost:8000: 访问
    三、语言和时间改成中文

    修改settings.py文件:

    # LANGUAGE_CODE = 'en-us'
    LANGUAGE_CODE = 'zh-hans'
    
    # TIME_ZONE = 'UTC'
    TIME_ZONE = 'Asia/Shanghai'
    
    结果: 中文
    四、目录结构和介绍
    目录结构
    • 最外层的Django_Test
      是项目的容器,Django并不关心它的名称,可以将它任意命名
    • manage.py
      可以让使用者使用各种方式管理Django项目的命令行工具。详情看:manage
    • 里面一层的Django_Test
      包含了项目,它是一个纯Python包。它的名字就是当前Django项目的名字,我们引用它内部任何东西时,使用的就是这个名字
    • Django_Test/__init__.py:Python基础的知识;一个空文件,用于告诉Python当前目录应该是一个Python包
    • Django_Test/settings.py:Django项目的配置文件。详情看:Django settings
    • Django_Test/urls.py:Django项目的URL声明,就好比网站的目录,注明了哪个url对应什么内容(页面)。详情看:URL调度器
    • Django_Test/wsgi.py:作为Django项目运行在WSGI兼容的web服务器上的入口,详情看:如何使用WSGI进行部署
    • Django_Test/view.py:自己创建的,MVT中的V:接收请求,逻辑处理,返回结果
    • templates:模板,放置返回给浏览器的html文件
    五、创建应用

    在Django中,每个应用对应一个Python包,并且遵循同样的约定。Django自带一个工具,可以帮助我们自动生成Django应用的基础目录结构,十分方便。

    • 项目和应用的区别
      应用:是一个专门做某件事情的网站应用程序,比如博客系统,或者公共记录的数据库,或者简单的投票程序。
      项目:是一个网站使用的配置和应用的集合。项目可以包含很多个应用。应用可以被很多个项目使用。

    • 现在要创建的应用,会创建在和Django_Test/Django_Test同级的目录,这样子它就可以作为顶级模块导入,而不是Django_Test的子模块
      1.先来到manage.py所处的目录下,然后执行命令:python manage.py startapp polls
      2.创建成功的polls应用:

      polls
      3.注册应用
      Django_Test/Django_Test/settings.py文件注册新增的应用polls
    # Application definition
    
    INSTALLED_APPS = [
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        
        # 注册子应用
        'polls.apps.PollsConfig'  # 大部分情况简写成'polls'
    ]
    

    4.编写第一个视图
    polls/views.py(管理视图,好比URL对应的内容)
    这里添加视图函数
    1.第一个参数requestsHttpRquest对象,包含前端用户的所有请求信息。
    2.返回值必须是一个HttpResponse对象或者子对象

    # 新增如下代码
    from django.shortcuts import render
    
    # Create your views here.
    from django.http import HttpResponse
    
    
    def index(request):
        return HttpResponse("hello, django.  You're at the polls index.")
    
    
    def login(request):
        # 可以通过request对象拿到请求的所有数据
        if request.method == 'GET':  # 大写
            return HttpResponse(" You're at the polls login.GET请求")
        elif request.method == 'POST':
            return HttpResponse(" You're at the polls login.POST请求")
        else:
            return HttpResponse(" You're at the polls login.其它请求")
    

    5.编写“目录”
    一个view创建后,如果想要起到效果,我们需要创建一个url去映射到这个视图。所以此时我们需要在该polls应用目录下创建一个url声明文件urls.py
    5.1.urls.py
    PS.实际上,一个项目往往会有多个app,那么Django是如何区分这些app的urlname的呢?这时候可以使用URL conf的命名空间。也就是在各个app的urls.py文件的开头,添加上一个app_name变量来指定该app的命名空间

    from django.urls import path
    
    from . import views
    
    ## 指定当前应用的命名空间
    app_name = 'polls'
    
    urlpatterns = [
        # url路径,所映射的view方法,对应的名称
        path(r'', views.index, name="index"),
        # 注意不需要/
        path(r'login', views.login, name="login"),
    ]
    

    6.在项目中绑定应用
    应用的内容创建完毕,接下来就需要到项目根目录的urls.py文件中去绑定所创建的应用的polls.urls模块
    Django_Test/Django_Test/urls.py:

    from django.contrib import admin
    from django.urls import include, path
    
    urlpatterns = [
        //  host后面的第一级路径、所映射应用的所有url都在该一级路径下
        path('polls/', include('polls.urls')),
        path('admin/', admin.site.urls) # 进入localhost:8000/admin会进入Django的admin管理页面
    ]
    
    • include()路由转发
      允许引用其它 URLconfs。每当 Django 遇到 :func:~django.urls.include 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。它的设计理念是即插即用,因为一个应用会有多个url和view,所以希望使用include()配置了一条以后,就能够访问该应用下的所有的路径,比如说"/polls/"、"/polls/login"
      什么时候使用include()
      除了admin.site.urls以外,匹配其它url时都应该使用include()

    还可以这样灵活使用include()进行路由转发

    ### 原来的路由配置
    from django.urls import path
    from . import views
    
    urlpatterns = [
        path('<page_slug>-<page_id>/history/', views.history),
        path('<page_slug>-<page_id>/edit/', views.edit),
        path('<page_slug>-<page_id>/discuss/', views.discuss),
        path('<page_slug>-<page_id>/permissions/', views.permissions),
    ]
    
    ### 优化后
    urlpatterns = [
        path('<page_slug>-<page_id>/', include([
            path('history/', views.history),
            path('edit/', views.edit),
            path('discuss/', views.discuss),
            path('permissions/', views.permissions),
        ])),
    ]
    

    7.访问
    http://127.0.0.1:8000/polls/

    polls/

    http://127.0.0.1:8000/polls/login

    polls/login,get请求
    六、path函数
    • path()有四个参数,其中两个必填参数:routeview,两个选填参数kwargsname
      1.route:是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求https://www.example.com/myapp/ 时,它会尝试匹配 myapp/ 。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/。
      2.view:当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest 对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。
      3.kwargs:任意个关键字参数可以作为一个字典传递给目标视图函数。
      4.name:给URL 取名能使我们在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许我们只改一个文件就能全局地修改某个 URL 模式。
      5.path函数官方文档
    七、类视图
    • 类视图的优点:
      1.代码可读性好
      2.类视图相对于函数视图有更高的复用性,其它类可以通过继承该视图类就可以使用它的方法
    • 例子:(把上面例子中的index修改成类视图)
      1./polls/views.py
    from django.http import HttpResponse
    
    from django.views import View
    
    
    class Index(View):
        """
        类视图,需继承View类
        """
    
        def get(self, request):
            return HttpResponse("hello, django.  You're at the polls index.==>GET")
    
        def post(self, request):
            return HttpResponse("hello, django.  You're at the polls index.==>POST")
    

    2.polls/urs.py

    from django.urls import path
    
    from . import views
    
    urlpatterns = [
        # 匹配类视图
        path(r'', views.Index.as_view(), name='index')
    ]
    
    结果: 类视图

    相关文章

      网友评论

          本文标题:2、Django_创建第一个应用

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