Django框架的项目结构详细解析

Django框架开发

创建项目的指令

  • $ django-admin startproject 项目名称

  • 如:

    • $ django-admin startproject mysite1
  • 运行

    $ cd mysite1
    $ python3 manage.py runserver
    # 或
    $ python3 manage.py runserver 5000  # 指定只能本机使用127.0.0.1的5000端口访问本机
    
    补充:
    Django 启动时报错,the port already in use
    原因是之前的进程没有正常退出
    解决方案:
    					1, ps aux|grep 'runserver'  过滤出之前启动的django进程
    					2,sudo kill -9 51246
    					
    					
    

Django项目的目录结构

  • 示例:

    $ django-admin startproject mysite1
    $ tree mysite1/
    mysite1/
    ├── manage.py
    └── mysite1
        ├── __init__.py
        ├── settings.py
        ├── urls.py
        └── wsgi.py
    
    1 directory, 5 files
    
  • 项目目录结构解析:

    • manage.py

      • 此文件是项目管理的主程序,在开发阶段用于管理整个项目的开发运行的调式
      • manage.py 包含项目管理的子命令, 如:
        • python3 manage.py runserver 启动服务
        • python3 manage.py startapp 创建应用
        • python3 manage.py migrate 数据库迁移
        • ...
    • mysite1 项目包文件夹

      • 项目包的主文件夹(默认与项目名称一致)
      1. __init__.py
        • 包初始化文件,当此项目包被导入(import)时此文件会自动运行
      2. wsgi.py
        • WSGI 即 Web Server Gateway Interface
        • WEB服务网关接口的配置文件,仅部署项目时使用
      3. urls.py
        • 项目的基础路由配置文件,所有的动态路径必须先走该文件进行匹配
      4. settings.py
        • Django项目的配置文件, 此配置文件中的一些全局变量将为Django框架的运行传递一些参数
        • setting.py 配置文件,启动服务时自动调用,
        • 此配置文件中也可以定义一些自定义的变量用于作用全局作用域的数据传递
  • settings.py 文件介绍

官网文档: https://docs.djangoproject.com/en/1.11/ref/settings/

  1. BASE_DIR

    • 用于绑定当前项目的绝对路径(动态计算出来的), 所有文件都可以依懒此路径
  2. DEBUG

    • 用于配置Django项目的启用模式, 取值:
      1. True 开发环境中使用。 调试模式(用于开发中)
      2. False 当前项目运行在生产环境中(不启用调试)
  3. ALLOWED_HOSTS

    • 设置允许访问到本项目的网络地址列表,取值:

      1. [] 空列表,表示只有请求头中host为127.0.0.1, localhost能访问本项目
      2. [’*’],表示任何请求头的host都能访问到当前项目
      3. [‘192.168.1.3’, ‘127.0.0.1’] 表示只有当前两个host头的值能访问当前项目
      • 注意:
        • 如果要在局域网其它主机也能访问此主机,启动方式应使用如下模式:
    • python3 manage.py runserver 0.0.0.0:5000 # 指定网络设备所有主机都可以通过5000端口访问(需加ALLOWED_HOSTS = ['*'])

  4. INSTALLED_APPS

    • 指定当前项目中安装的应用列表
  5. MIDDLEWARE

    • 用于注册中间件
  6. TEMPLATES

    • 用于指定模板的配置信息
  7. DATABASES

    • 用于指定数据库的配置信息
  8. LANGUAGE_CODE

    • 用于指定语言配置
    • 取值:
      • 英文 : "en-us"
      • 中文 : "zh-Hans"
  9. TIME_ZONE

    • 用于指定当前服务器端的时区
    • 取值:
      • 世界标准时间: "UTC"
      • 中国时区 : "Asia/Shanghai"
  10. ROOT_URLCONF

    • 用于配置根级 url 配置 ‘mysite1.urls’
    • 如:
      • ROOT_URLCONF = 'mysite1.urls'

注: 此模块可以通过 from django.conf import settings 导入和使用

URL 介绍

  • url 即统一资源定位符 Uniform Resource Locator

  • 作用:

    • 用来表示互联网上某个资源的地址
  • 说明:

    • 互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。
  • URL的一般语法格式为:

    protocol :// hostname[:port] / path [?query][#fragment]
    
  • 如:

    http://tts.tmooc.cn/video/showVideo?menuId=657421&version=AID201908#subject
    
  • 说明:

    • protocol(协议)
      • http 通过 HTTP 访问该资源。 格式 HTTP://
      • https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://
      • file 资源是本地计算机上的文件。格式: file:///
    • hostname(主机名)
      • 是指存放资源的服务器的域名系统(DNS) 主机名、域名 或 IP 地址。
    • port(端口号)
      • 整数,可选,省略时使用方案的默认端口;
      • 各种传输协议都有默认的端口号,如http的默认端口为80。
    • path(路由地址)
      • 由零或多个“/”符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。路由地址决定了服务器端如何处理这个请求
    • query(查询)
      • 可选,用于给动态网页传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。
    • fragment(信息片断)
      • 字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。
    • 注: [] 代表其中的内容可省略

视图函数(view)

  • 视图函数是用于接收一个浏览器请求并通过HttpResponse对象返回数据的函数。此函数可以接收浏览器请求并根据业务逻辑返回相应的内容给浏览器

  • 视图处理的函数的语法格式:

    def xxx_view(request[, 其它参数...]):
        return HttpResponse对象
    
  • 参数:

    • request用于绑定HttpRequest对象,通过此对象可以获取浏览器的参数和数据
  • 示例:

    • 视图处理函数 views.py

      # file : <项目名>/views.py
      from django.http import HttpResponse
      def page1_view(request):
          html = "<h1>这是第1个页面</h1>"
          return HttpResponse(html)
      

Django 中的路由配置

  • settings.py 中的ROOT_URLCONF 指定了主路由配置列表urlpatterns的文件位置

  • urls.py 主路由配置文件

    # file : <项目名>/urls.py
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        ...  # 此处配置主路由
    ]
    

    urlpatterns 是一个路由-视图函数映射关的列表,此列表的映射关系由url函数来确定

  1. url() 函数

    • 用于描述路由与视图函数的对应关系
    • 模块
      • from django.conf.urls import url
    • 语法:
      • url(regex, views, name=None)
      • 参数:
        1. regex: 字符串类型,匹配的请求路径,允许是正则表达式
        2. views: 指定路径所对应的视图处理函数的名称
        3. name: 为地址起别名,在模板中地址反向解析时使用

    每个正则表达式前面的r表示'\'不转义的原始字符串

  • 练习

    • 建立一个小网站:

      • 输入网址: http://127.0.0.1:8000, 在网页中输出 : 这是我的首页
      • 输入网址: http://127.0.0.1:8000/page1, 在网页中输出 : 这是编号为1的网页
      • 输入网址: http://127.0.0.1:8000/page2, 在网页中输出 : 这是编号为2的网页

      提示: 主页路由的正则是 r'^$'

      • 思考
        • 建立如上一百个网页该怎么办?
带有分组的路由和视图函数
  • 在视图函数内,可以用正则表达式分组 () 提取参数后用函数位置传参传递给视图函数

  • 一个分组表示一个参数,多个参数需要使用多个分组,并且使用个/隔开

    • 如:
      • http://127.0.0.1:8000/year/2018
      • http://127.0.0.1:8000/year/2019
      • http://127.0.0.1:8000/year/??? # 四位数字
带有命名分组的路由和视图函数
  • 在url 的正则表达式中可以使用命名分组(捕获分组)

  • 说明:

    • 在视图函数内,可以用正则表达式分组 (?P<name>pattern) 提取参数后用函数关键字传参传递给视图函数
  • 示例:

    • 路由配置文件

      # file : <项目名>/urls.py
      # 以下示例匹配
      # http://127.0.0.1:8000/person/xiaoming/20
      # http://127.0.0.1:8000/person/xiaohong/29
      # http://127.0.0.1:8000/person/xiaolan/9
      urlpatterns = [
          url(r'^admin/', admin.site.urls),
          url(r'^person/(?P<name>\w+)/(?P<age>\d{1,2})',views.person_view),
      ]
      
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要安装Django框架,可以按照以下步骤进行操作: 1. 首先,打开命令行模式,并使用pip工具来安装Django。可以使用以下命令进行安装: ``` pip install django ``` 2. 安装完成后,可以在Python交互模式下确认是否安装成功。在Python终端中输入以下代码导入Django,并使用`django.get_version()`来查看Django的版本号: ``` import django django.get_version() ``` 3. 创建Django项目。可以使用以下命令在指定位置创建一个Django项目: ``` django-admin startproject <project_name> ``` 这将在当前目录下创建一个名为`<project_name>`的文件夹,其中包含了Django项目的基本结构。 如果在运行过程中没有出现相应的界面,你可以尝试重新激活(activate)Django的路径,然后再次创建Django项目文件夹。 需要注意的是,在常规的Python环境下执行Django-admin命令前,可能需要将Python的scripts目录添加到环境变量里。这样可以确保系统能够正确找到Django-admin命令并执行。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Django框架安装及项目创建过程解析](https://download.csdn.net/download/weixin_38563176/13707683)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python django框架的安装](https://blog.csdn.net/weixin_44303465/article/details/88879375)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值