【Django实战一】创建新项目

一、新建Project

bash 复制代码
django-admin startproject 项目名称

二、创建应用

1、创建应用

bash 复制代码
python manage.py startapp 应用名称

应用创建后,项目的根目录下会生成对应应用名称的文件夹

2、注册应用

新创建的应用需要在settings.py中的INSTALLED_APPS中注册该应用

bash 复制代码
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    '项目名称',
]

3、创建视图、定义路由

在新增app下的views.py中添加一个视图函数

言归正传,在view.py下添加一个视图逻辑

python 复制代码
from django.http import JsonResponse
def hello(request):
    data = {
        "code" : 0,
        "msg" : "hello"
    }
    print(data["msg"])
    return JsonResponse(data)

然在urls.py中声明该视图,为其分配请求路径

python 复制代码
from django.contrib import admin
from django.urls import path
from base import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('hello',views.hello) #这样,当我们向localhost:8000/hello 请求数据时,即可返回hello
]

需要注意的是,以函数形式来编辑逻辑(FBV )与以类形式来编辑逻辑(CBV )时,urls.py上的路径与函数的对应关系是不一样的。

1)使用FBV写:

python 复制代码
from django.shortcuts import render, HttpResponse, redirect

def back_hello(request):
    return HttpResponse('大家好!')
python 复制代码
urlpatterns = [
    url(r'^admin/', admin.site.urls),
]

2)使用CBV写:

python 复制代码
from django.views import View    # 基于类的形式来写试图上的业务逻辑的时候,定义的类需要  继承 django 中的View类  !!!!!!!
class BackHello(View):
    def get(self, request):
        return HttpResponse("get请求的时候!get大家好!")

    def post(self, request):
        return HttpResponse("post请求的时候!post大家好!")
python 复制代码
urlpatterns = [
    url(r'^test/', views.BackHello.as_view()),
]

【本文部分内容参考】

  1. Django框架------基础之视图系统(View.py)
相关推荐
世界尽头与你21 小时前
详解 MySQL 数据库索引实现机制 - B 树和 B + 树
数据库·mysql·索引
德彪稳坐倒骑驴21 小时前
MySQL Oracle面试题
数据库·mysql·oracle
数据知道21 小时前
PostgreSQL 核心原理:什么场景下开启 JIT 能提升性能?(JIT 编译)
数据库·postgresql
吕司21 小时前
MySQL库的操作
数据库·mysql·oracle
LaughingZhu21 小时前
Product Hunt 每日热榜 | 2026-02-05
大数据·数据库·人工智能·经验分享·搜索引擎·产品运营
逃逸线LOF21 小时前
mysql本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止
数据库
Remember_9931 天前
MySQL 索引详解:从原理到实战优化
java·数据库·mysql·spring·http·adb·面试
dishugj1 天前
【Oracle】 rac的一些问题以及解决方案
数据库·oracle
Ronin3051 天前
日志打印和实用 Helper 工具
数据库·sqlite·rabbitmq·文件操作·uuid生成
eWidget1 天前
面向信创环境的Oracle兼容型数据库解决方案
数据库·oracle·kingbase·数据库平替用金仓·金仓数据库