5.3Django网络框架(3):HelloDjango

2024-05-27 01:18

本文主要是介绍5.3Django网络框架(3):HelloDjango,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文将带你从零开始创建一个Django项目,包含完整的MTV架构、创建子应用,及访问静态资源;
项目GitHub地址:https://github.com/ouyangsuo/HelloDjango;

@创建Django项目

  • 首先进入特定的虚拟开发环境,参考创建虚拟开发环境
  • 在终端cd到特定目录,执行:
django-admin.py startproject HelloDjango
  • 查看工程目录结构
sudo apt install tree
tree HelloDjango/

这里写图片描述

  • 工程的创建也可以在PyCharm中通过新建工程并选择DjangoProject来实现;

@工程目录说明
HelloDjango
_init_.py

  • 代表HelloDjango是一个包模块
  • 可以在其中做全局的初始化动作,例如:导入和初始化数据库

settings.py

  • Django项目的配置文件,包含但不限于如下配置:
  • 本项目引用的组件;
  • 已安装的应用;
  • 数据库配置;
  • 时间语言配置;
  • 静态文件访问地址和存储路径;

urls.py

  • 用于维护项目的URL路由映射(当客户端访问时由哪个函数进行响应);
  • 响应函数通常写在项目和子应用的views.py文件中;
  • 路由定义例如下图,表示当用户通过http://yourhost:port/home/发起 访问时,该请求通过views.py中的home函数进行响应(此处的views.py需要手动创建);
from HelloDjango import views
url(r'^home/$', views.home)

wsgi.py

  • 定义WSGI的接口信息;
  • 用于服务器部署;
  • 通常使用系统默认设置即可;
  • 项目部署将在后续章节中继续讲述;

manage.py

  • Django用于管理本项目的命令行工具,无需修改,功能包括但不限于:
  • 运行站点;
  • 进行数据迁移操作;

@创建子应用

  • 终端执行
python manage.py startapp MyApp
  • 在HelloDjango的settings.py中注册应用
# 配置应用
INSTALLED_APPS = [# 一堆默认的django应用...# 自定义的应用'MyApp',
]

@应用目录结构说明

  • _ init _.py:代表当前目录是一个包;
  • admin.py:管理站点模型的声明文件,默认为空;
  • apps.py:应用信息定义文件,在其中生成了AppConfig,该类用于定义应用名等数据;
  • models.py:添加模型层数据类文件;
  • views.py:定义URL相应函数(路由规则);
  • migrations包:自动生成,数据迁移文件;
  • tests.py:测试代码文件

@定义数据模型(Models)

  • 定义班级类,在MyApp目录下的models.py中插入如下代码
# 班级类
class Grade(models.Model):# 班级名称gname = models.CharField(max_length=10)# 开班日期gdate = models.DateTimeField()# 女生数量ggirlnum = models.IntegerField()# 男生数量gboynum = models.IntegerField()# 是否已逻辑删除该班级isDelete = models.BooleanField(default=False)# 定义班级的打印输出信息def __str__(self):return self.gname
  • 在models.py中定义学生类
# 学生类
class Students(models.Model):# 学生姓名sname = models.CharField(max_length=20)# 学生性别sgender = models.BooleanField(default=True)# 学生年龄sage = models.IntegerField()# 备注信息sinfo = models.CharField(max_length=20)# 是否已逻辑删除该学生isDelete = models.BooleanField(default=False)# 学生所属的班级sgrade = models.ForeignKey(Grade)

@执行数据迁移

  • 数据迁移的概念,就是将模型映射到数据库的过程;
  • 生成迁移文件(在MyApp下的migrations包中)
python manage.py makemigrations
  • 执行数据迁移
python mananger.py migrate
  • 迁移过后,框架为我们自动生成了库表,Django默认自带的数据库是SQLite数据库;
  • 数据库文件生成路径为工程根目录下的db.sqlite3;
  • 生成的数据表结构如图
    这里写图片描述

@生造一些数据

  • 生造班级数据如下
    这里写图片描述
  • 生造学生数据如下
    这里写图片描述

@创建页面(Templates)

  • 修改HelloDjango下的settings.py中的模板配置
TEMPLATES = [{...# 将模板页面放在根目录/templates目录下的'DIRS': [os.path.join(BASE_DIR, 'templates'),],...},
]
  • 修改settings.py中的模板配置中的静态资源配置
# 静态文件访问路由
STATIC_URL = '/static/'# 静态文件存储目录:根目录/static/
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static'),
]
  • 创建【根目录/static/img/】目录并丢入dameinv.jpg
  • 创建templates目录并在其中创建dameinv.html
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>大美女</title>
</head>
<body>
大美女来鸟~<br>{# 加载静态资源 #}
{% load static %}{# 加载图片位置 #}
<img src="{% static 'img/dameinv.jpg' %}" alt="我是大美女">
</body>
</html>

@定义路由映射(Views)

  • 在HelloDjango下的urls.py中插入如下代码
from HelloDjango import views
from MyApp.admin import site# 分发路由请求
urlpatterns = [# url(r'^admin/', admin.site.urls),url(r'^admin/', site.urls),# http://127.0.0.1:8000/请求交由HelloDjango下的views中的index函数处理url(r'^$',views.index),# http://127.0.0.1:8000/dameinv请求交由HelloDjango下的views中的dameinv函数处理url(r'^dameinv/',views.dameinv),# http://127.0.0.1:8000/myapp/xxx统统交由MyApp下的urls重新分发url(r'^myapp/',include('MyApp.urls'))
]
  • 在MyApp的urls.py中插入如下代码
# 定义路由映射
urlpatterns = [# 请求http://127.0.0.1:8000/myapp/,交由MyApp下的views.py中的welcome函数处理url(r'^$', views.welcome)
]

@定义路由处理函数(Views)

  • 在HelloDjango下的views中插入如下代码
# 处理http://127.0.0.1:8000/
def index(request):# 直接在页面输出内容return HttpResponse('Django:江中自有黄金屋,屋里把那代码撸,江中自有颜如玉,硬盘堆满几百G')# http://127.0.0.1:8000/dameinv/
def dameinv(request):# 渲染页面并呈现给用户return render(request,'dameinv.html')
  • 在MyApp下的views.py中插入如下代码
def welcome(request):# 查询所有学生students = Students.objects.all()# 构造数据字典data={'students':students}# 将数据丢给templates/welcome.html进行渲染并呈现给用户return render(request,'welcome.html',context=data)

@运行项目

  • 终端执行如下命令中的一条:
python manage.py runserver
python manage.py runserver [port]
python manage.py runserver [ip:port]
  • 默认使用8000端口;
  • ip指定为0.0.0.0的时候,匹配本机的全部ip;

@访问测试

  • 访问127.0.0.1:8002/
    这里写图片描述
  • 访问127.0.0.1:8002/dameinv/
    这里写图片描述
  • 访问127.0.0.1:8002/myapp/
    这里写图片描述

这篇关于5.3Django网络框架(3):HelloDjango的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1006119

相关文章

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Django序列化中SerializerMethodField的使用详解

《Django序列化中SerializerMethodField的使用详解》:本文主要介绍Django序列化中SerializerMethodField的使用,具有很好的参考价值,希望对大家有所帮... 目录SerializerMethodField的基本概念使用SerializerMethodField的

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解