配置文件、request对象请求方法、Django连接MySQL、Django中的ORM、ORM增删改查字段、ORM增删改查数据

这篇具有很好参考价值的文章主要介绍了配置文件、request对象请求方法、Django连接MySQL、Django中的ORM、ORM增删改查字段、ORM增删改查数据。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、配置文件的介绍

1.注册应用的
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',
]


################中间件#############################################################
2.中间件
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
################中间件#############################################################
ROOT_URLCONF = 'day54_dj.urls' # 根路由的文件名

3.Django连接MySQL数据库的
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

LANGUAGE_CODE = 'zh-hans' 
TIME_ZONE = 'Asia/Shanghai'

配置文件settings.py

"""
Django settings for day54 project.

Generated by 'django-admin startproject' using Django 1.11.20.

For more information on this file, see
https://docs.djangoproject.com/en/1.11/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.11/ref/settings/
"""

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
# 固定盐
SECRET_KEY = 'k)_am7d@*mbelt*c*i84r$8^a%1#f7^_6cxa$esk47pa+a^tkm'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = []

# DEBUG = False
# ALLOWED_HOSTS = [*]


# Application definition
# 注册应用
from django.contrib import admin
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    
    'app01.apps.App01Config', # 全称
]

# 中间件
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    # 'django.middleware.csrf.CsrfViewMiddleware', # 用于验证
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

# 跟路由文件
ROOT_URLCONF = 'day54.urls'

# 模板
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        # 'DIRS': [BASE_DIR / 'templates'],
        'DIRS': [os.path.join(BASE_DIR, 'templates')]
        ,
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

#
WSGI_APPLICATION = 'day54.wsgi.application'


# Database
# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
# 连接数据库
DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # },
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'db17',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': 'root',
        'CHARSET': 'utf8'
    },
}


# Password validation
# https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators
# 验证认证
AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/1.11/topics/i18n/
# 英文
# LANGUAGE_CODE = 'en-us'
# 中文
LANGUAGE_CODE = 'zh-hans'
# 时区
# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/
# 静态文件的配置,访问静态文件的令牌,以后只要访问静态文件的路径,就要以  /static/  开头
STATIC_URL = '/static/'

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

# 动态解析路径


二、静态文件的配置

# 以登录功能为例

<form action="">
	action参数的三种情况:
    	1. 什么都不写,就是朝当前地址提交数据
        2. 要么全写:http://127.0.0.1:8000/login/?username=&password=
        3. 只写后缀
        	http://127.0.0.1:8000/login/
"""
	我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建
	我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹
	静态文件:
		网站使用的CSS文件
		网站使用的js文件
		网站使用图片
		网站使用的第三方库文件
			jQuery、bootstrap等
			
"""
1.可以针对不同的功能对static文件夹里面的文件进行拆分
css
js
img
...

注意:看起来是对的,但是不能访问到
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/js/bootstrap.min.js 

之前访问的地址都可以访问到,那是因为在后端开设了可以访问的接口(理由)
之所以现在访问不到刚才的地址,是因为在后端没有开设这样的一个可访问的接口(路由)

2.Django自动的帮我们写好了这样的接口

访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头
STATIC_URL = '/vxcvxcvxcvxcvcx/'  # 静态文件

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

3.动态解析路径
{% load static %}
<script src="{% static 'js/jquery.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>

三、request对象请求方法

request.method  # 请求方式 GET POST
print(request.POST) # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.POST.get('username'))  # ['jason'] # jason

print(request.GET)  # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.GET.get('username'))  # ['jason'] # jason

1.request的请求方法

在 Django 中,`request` 对象是在视图函数中作为参数传递的,它包含了客户端发起的 HTTP 请求信息,包括请求的方法。在视图函数中,你可以通过 `request.method` 属性获取请求方法。

常见的 HTTP 请求方法有以下几种:

1. GET:用于从服务器获取数据,通常用于请求页面或资源。
2. POST:用于向服务器提交数据,通常用于提交表单数据或执行某些操作。
3. PUT:用于更新服务器上的资源,通常用于更新已有数据。
4. DELETE:用于删除服务器上的资源,通常用于删除某个数据。

在 Django 中,通过检查 `request.method` 属性,你可以判断请求的方法,并根据不同的方法执行不同的操作。下面是一个示例:

from django.http import HttpResponse

def my_view(request):
    if request.method == 'GET':
        # 处理 GET 请求
        return HttpResponse("这是一个 GET 请求")
    elif request.method == 'POST':
        # 处理 POST 请求
        return HttpResponse("这是一个 POST 请求")
    elif request.method == 'PUT':
        # 处理 PUT 请求
        return HttpResponse("这是一个 PUT 请求")
    elif request.method == 'DELETE':
        # 处理 DELETE 请求
        return HttpResponse("这是一个 DELETE 请求")
    else:
        # 处理其他未知方法
        return HttpResponse("未知请求方法")

在上面的例子中,视图函数 `my_view` 根据不同的请求方法返回不同的响应内容。根据实际需求,你可以在视图函数中根据请求方法执行相应的逻辑和操作。

需要注意的是,要使用 `request` 对象,你需要在视图函数的参数列表中将它传递进来,例如:`def my_view(request):`。在 Django 中,视图函数的第一个参数通常是 `request` 对象,它包含了客户端发起的请求信息。

2.什么是request对象

在 Django 中,`request` 对象是一个包含了客户端发起的 HTTP 请求信息的对象。它是在 Django 视图函数中作为参数传递的,用于处理来自用户浏览器或其他客户端的请求。

`request` 对象包含了许多属性和方法,其中包括:

1. `request.method`: 获取请求的 HTTP 方法,例如 GET、POST、PUT、DELETE 等。
2. `request.GET`: 包含了 GET 请求参数的字典。可以通过 `request.GET.get('param_name')` 来获取具体的参数值。
3. `request.POST`: 包含了 POST 请求参数的字典。可以通过 `request.POST.get('param_name')` 来获取具体的参数值。
4. `request.FILES`: 包含了上传文件的信息,通常用于处理文件上传表单。
5. `request.path`: 获取请求的路径,例如 "/myapp/myview/"6. `request.path_info`: 获取请求的路径信息,例如 "/myapp/myview/",不包含查询参数。
7. `request.get_full_path()`: 获取请求的完整路径,包括路径和查询参数。
8. `request.is_secure()`: 判断请求是否使用了 HTTPS 安全协议。

除了上述属性和方法,`request` 对象还包含其他有关请求的信息,例如请求头信息、用户 IP 地址、会话信息等。你可以通过 `request` 对象来获取客户端发起的请求数据,从而根据请求数据做出相应的处理和响应。

在 Django 中,视图函数的第一个参数通常是 `request` 对象,例如:


from django.http import HttpResponse

def my_view(request):
    # 在这里可以根据 request 对象来处理请求和返回响应
    # ...
    return HttpResponse("Hello, World!")


通过使用 `request` 对象,你可以在视图函数中访问并处理客户端发起的请求数据,从而实现不同的业务逻辑和功能。

四、Django连接MySQL

1.默认情况sqlite3
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

2.连接MySQL
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

3.解决bug的思路:
	1. 就是print()
	2. 看是否有日志
	3. 看报错的信息去百度中搜索
	4. 问问别人

4.连接MySQL数据的时候可能报错的解决办法:
1. 如果解释器版本导致的问题,直接改源码base.py
	def get_new_connection(self, conn_params):
	    conn = Database.connect(**conn_params)
	    conn.encoders[SafeText] = conn.encoders[six.text_type]
	    先判断bytes是否存在于编码器中,如果在才执行操作
	    if bytes in conn.encoders: # 加上这句话
	        conn.encoders[SafeBytes] = conn.encoders[bytes]
	    return conn
	
	2. 解释器版本改为3.6的时候也会报错
	Django的底层默认使用的是mysqldb模块,这个模块兼容性很差
	我们还使用pymysql连接mysql,你要提前安装pymysql模块
	Did you install mysqlclient or MySQL-python?

	3.怎么解决这个问题:
	在项目的任意的__init__.py中加入下面两行代码
	*****************************************************************************
	import pymysql
	pymysql.install_as_MySQLdb()  # 猴子补丁
	以上这两行代码的意思就是把底层的mysqldb模块换成pymysql
	*****************************************************************************

	4. 除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块
	用了mysqlclient这个模块,就不用加上面那两句话了
	mysqlclient安装的时候可能会报各种错误
	
DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # }

    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'db9',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': 'root',
        'CHARSET': 'utf8'
    }
}

五、Django中的ORM

什么是ORM:对象映射模型
	以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查.

1.orm的书写位置:在models.py中书写
概念
	表				>>>>>     类名
	
	记录				>>>>>    对象
	
	字段				>>>>>    属性

2.创建出来一张表来
	所有的类必须继承models.Model
	class User(models.Model):  # 表名
	    # id int primary key auto_increment
	    id = models.AutoField(primary_key=True)
	    # username varchar(64)
	    username = models.CharField(max_length=64)
	    # password varchar(64)
	    password = models.CharField(max_length=64)
    
3.类写完之后,一定要做数据库迁移,真正的在数据库中生成表
********************************************************************************
    python36 manage.py makemigrations  它的作用是把数据库的迁移记录保存下来
    python36 manage.py migrate		   才是真正的把数据表创建出来
********************************************************************************

六、ORM增删改查字段

class Author(models.Model):
    '''如果创建的表中有主键字段,并且,主键字段的名字也叫id,那么,以后就可以直接省略id字段'''
    name = models.CharField(max_length=64)
    # password1 = models.CharField(max_length=128, null=True)
    # password1 = models.CharField(max_length=64, default='12')
    

七、ORM增删改查数据

如何做查询  select * from author where username = jack and password = 123
    objects:小组件,里面封装了很多的方法
    # res=models.Author.objects.filter(name=username, password=password).all() # 是and查询
    # res=models.Author.objects.filter(name=username, password=password) # 是and查询
    # res=models.Author.objects.filter(name=username).filter(password=password)# 是and查询
    # res=models.Author.objects.filter(name=username, password=password).first() # 是and查询

    res=models.Author.objects.create(name=username,password=password)
    # print(res)  # <QuerySet [<Author: Author object>]>  QuerySet对象以后可以点出来很多的方法
    # print(res)  # Author object  QuerySet对象以后可以点出来很多的方法
    # print(res[0].name)
    # print(res[0].password)
    # print(res.name)
    # print(res.password)

文章来源地址https://www.toymoban.com/news/detail-619270.html

到了这里,关于配置文件、request对象请求方法、Django连接MySQL、Django中的ORM、ORM增删改查字段、ORM增删改查数据的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Servlet API中使用Request对象获取HTTP协议请求内容

    在Servlet API中,定义了一个HttpServletRequest接口,它继承自ServletRequest接口,专门 用来封装HTTP请求消息。 由于HTTP请求消息分为请求行、请求头和请求体三部分,因此,在HttpServletRequest接口中定义了获取请求行、请求头和请求消息体的相关方法. Web服务器【tomcat】收到客户端的

    2024年02月11日
    浏览(51)
  • 【Jmeter】HTTP请求(HTTP Request) - 配置基本HTTP请求

    右击 Thread (线程组) 鼠标移至 Add (添加) → Sampler (取样器) 点击 HTTP Rrequest (HTTP请求头) 即可完成HTTP请求新建 进入 HTTP Rrequest (HTTP请求头) 页面 输入 Protocol (传输协议类型) ,不输入默认为HTTP请求 输入 Server Name or IP (服务器或IP地址) 输入 Port Number (端口号),没有端口号则不输入

    2024年02月14日
    浏览(43)
  • C#控制台连接Mysql数据库,有配置数据库连接字符串的配置文件

    实现功能 读取. .txt 中的配置文件,来初始化连接字符串 让连接字符串的配置文件不存在会主动创建默认的连接字符串 注意点: 需要引用Newtonsoft 使用mysql

    2024年02月10日
    浏览(58)
  • HTTP请求:requests的进阶使用方法浅析

    上篇文章讲解了requests模块的基础使用,其中有get、put、post等多种请求方式,使用data、json等格式做为请求参数,在请求体中添加请求头部信息的常见信息,如:headers、cookies,以及对请求响应的处理方法。接下来讲解一下requests的高级用法。 method:提交方式(get|post);

    2024年02月09日
    浏览(40)
  • 06-HTTP-Request获取请求头数据方法

    1、getHeader()方法用于获取指定名称的HTTP请求头的值。 getHeader()方法的参数为一个字符串,表示要获取的HTTP请求头的名称。方法返回一个字符串,表示该HTTP请求头的值。如果指定名称的HTTP请求头不存在,则返回null。 常见的HTTP请求头有: Accept:指定客户端可以接受哪些类型

    2024年02月16日
    浏览(45)
  • 小程序配置网络请求@escook/request-miniprogram

    由于平台限制,小程序项目不支持axios, 原生wx.request() API功能较为简单, 不支持拦截器 等功能。所以使用@escook/request-miniprogram第三方包发起网络数据请求 配置步骤: 官方文档:https://www.npmjs.com/package/@escook/request-miniprogram 1.找到项目路径,输入cmd进入命令行 2. 安装,输入

    2024年02月13日
    浏览(336)
  • 超完整的mysql安装配置方法(包含idea和navicat连接mysql,并实现建表)

    官网链接:https://dev.mysql.com/downloads/mysql/ 选择zip文件下载,直接解压到安装目录下就行,免安装 在根目录下新建my.ini文件,并将以下内容复制进去 注意: basedir路径要配置mysql的安装根目录,datadir路径也要自定义配置 1、找到系统属性,点击环境变量 2、配置用户变量,点击

    2024年02月03日
    浏览(44)
  • 学习记录: requests 不同请求方式传参和常用的方法

    requests.Request(url) 构造一个请求,支持以下各种方式 requests.get() 发送get请求 requests.post() 发送post请求 requests.head() 获取HTML的头部信息 requests.put() 发送put请求 requests.patch() 提交局部修改的请求 requests.delete() 提交删除请求 语法构造 requests.get(url,params=None) 参数说明 url:需要爬取的

    2024年02月09日
    浏览(40)
  • 【微信小程序】使用 wx.request 方法进行异步网络请求

    在微信小程序中,你可以使用 wx.request 方法进行异步网络请求,并将获取到的列表数据渲染到 UI 上。 首先,在页面的 data 中定义一个数组变量,用于存储获取到的列表数据,例如: 然后,在页面的生命周期函数 onLoad 或需要触发网络请求的函数中,使用 wx.request 方法发送异

    2024年02月16日
    浏览(59)
  • webstrom连接GitHub copilot提示错误:...request id: 3, error code: -32603(请求id:3,错误代码:-32603)

    2023.5.20--今天用webstorm登录github copilot 但是登陆不上  显示错误代码 登录页面显示不出。  (这是FanSky_Qs )的报错信息  和我的一样 但是他帖子中的改代理的方式我并不能使用。 关于Copilot登录不上问题解决办法(二)_FanSky_Qs的博客-CSDN博客 后来又花费了很多时间搜索信息

    2024年02月09日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包