深入学习和理解Django视图层:处理请求与响应

news2025/1/10 17:16:17

title: 深入学习和理解Django视图层:处理请求与响应
date: 2024/5/4 17:47:55
updated: 2024/5/4 17:47:55
categories:

  • 后端开发

tags:

  • Django
  • 请求处理
  • 响应生成
  • 模板渲染
  • 表单处理
  • 中间件
  • 异常处理

在这里插入图片描述

第一章:Django框架概述

1.1 什么是Django?

Django是一个高级的Python Web框架,它鼓励快速开发和干净、实用的设计。它由Wall Street Journal的程序员在2005年开发,用于他们的新闻网站。自那时起,Django已经成为全球范围内广泛使用的Web框架之一。

Django的核心理念是“快速开发”和“稳健的防御”,它通过以下特点实现这一点:

  • 快速开发:Django提供了一套丰富的功能,如内置的admin界面、模板引擎和数据库迁移系统,这些功能可以帮助开发者快速构建复杂的应用程序。
  • 稳健的防御:Django内置了许多安全功能,如防止常见Web攻击(如XSS、CSRF、SQL注入等)的防护措施,以及严格的用户权限管理系统。

1.2 Django的核心组件

Django框架由多个紧密集成的组件组成,这些组件协同工作,提供了一个完整的Web应用程序开发环境。以下是Django的核心组件及其作用:

  • 模型(Models) :模型是Django框架的基石,它们代表数据库中的表。通过定义模型,Django自动创建数据库结构,并提供了操作数据库的接口。
  • 视图(Views) :视图是Django处理HTTP请求的逻辑部分。它们接收来自路由器的请求,处理请求,并返回响应。视图负责业务逻辑,并与模型交互以获取数据。
  • 模板(Templates) :模板是用于生成HTML页面的文本文件。它们允许开发者将数据(由视图提供)插入到HTML中,从而创建动态的Web内容。Django提供了一个强大的模板语言,用于在模板中处理数据和逻辑。
  • 路由器(URL Router) :路由器将URL路径映射到Django视图上。它定义了应用程序的结构,并处理用户的URL请求,将其传递给相应的视图进行处理。

这些组件共同工作,形成了一个强大的体系结构,使Django成为构建复杂Web应用程序的理想选择。在下一章中,我们将深入探讨Django的视图层,了解它是如何处理请求和生成响应的。

第二章:Django视图层基础

2.1 视图函数的定义和作用

在Django中,视图函数是处理Web应用程序逻辑的关键部分。视图函数负责接收HTTP请求对象,并返回HTTP响应对象。视图函数通常定义在views.py文件中,可以通过URL路由器映射到特定的URL路径上。

视图函数的定义通常如下所示:

from django.http import HttpResponse

def my_view(request):
    # 处理请求逻辑
    return HttpResponse("Hello, World!")

在上面的例子中,my_view是一个简单的视图函数,它接收一个request参数,代表HTTP请求对象。在函数内部,可以根据请求对象的内容进行逻辑处理,然后通过HttpResponse对象返回一个HTTP响应。

视图函数的作用包括但不限于:

  • 处理用户请求:接收用户的HTTP请求,从请求中获取数据并进行处理。
  • 生成响应:根据请求处理的结果生成HTTP响应,可以是HTML页面、JSON数据等。
  • 业务逻辑处理:执行特定的业务逻辑,如数据查询、计算等。
  • 路由映射:将URL请求映射到对应的视图函数上。

2.2 类视图的概念和用法

除了使用函数来定义视图外,Django还提供了类视图的概念。类视图是基于类的视图,通过继承Django提供的类视图基类,可以更方便地组织视图逻辑。

使用类视图的示例:

from django.views import View
from django.http import HttpResponse

class MyView(View):
    def get(self, request):
        # 处理GET请求逻辑
        return HttpResponse("Hello, World!")

在上面的例子中,MyView是一个简单的类视图,继承自View类。类视图中,我们可以通过定义类方法来处理不同类型的HTTP请求,如get()方法用于处理GET请求,post()方法用于处理POST请求等。

类视图的优点包括:

  • 代码复用:可以通过继承和重写类方法来实现代码复用。
  • 可读性:类视图将相关的请求处理逻辑组织在一个类中,提高了代码的可读性和可维护性。
  • 内置功能:Django提供了许多内置的类视图,如ListViewDetailView等,用于快速构建常见的视图功能。

类视图和函数视图在功能上是等效的,开发者可以根据个人喜好和项目需求选择使用哪种方式来编写视图。

第三章:处理请求

3.1 请求对象的属性和方法

在Django中,请求对象(HttpRequest)是一个包含了HTTP请求信息的对象,可以通过视图函数中的request参数来访问。请求对象包含了许多属性和方法,常用的包括:

  • request.method:获取请求的HTTP方法,如GET、POST等。
  • request.GET:包含GET请求参数的字典。
  • request.POST:包含POST请求参数的字典。
  • request.FILES:包含文件上传的数据。
  • request.path:获取请求的路径部分。
  • request.META:包含请求的元数据,如请求头信息。
  • request.COOKIES:包含请求中的cookie数据。
  • request.session:包含与当前会话相关的数据。
  • request.user:表示当前登录用户的对象。

除了上述属性外,请求对象还包含其他一些方法和属性,用于获取请求的信息、处理请求数据等。

3.2 请求处理流程

在Django中,请求处理的流程如下:

  1. 中间件处理:当请求到达Django应用时,会先经过中间件的处理。中间件可以对请求进行预处理、后处理或者拦截请求。常见的中间件包括身份验证、日志记录、跨域处理等。
  2. URL路由匹配:Django会根据项目中定义的URL路由规则,将请求的URL路径映射到对应的视图函数或类视图上。URL路由器会根据URL配置文件(如urls.py)中的规则进行匹配。
  3. 视图函数调用:匹配到对应的视图函数后,Django会调用该视图函数来处理请求。视图函数接收请求对象作为参数,根据请求的方法(GET、POST等)和参数进行逻辑处理,最终生成HTTP响应对象。
  4. HTTP响应返回:视图函数生成HTTP响应对象后,Django会将该响应返回给客户端,完成请求-响应循环。

整个请求处理流程中,中间件起到了预处理和后处理的作用,URL路由器负责将请求分发到对应的视图函数,视图函数则处理具体的业务逻辑并生成响应。这样的分层设计使得Django应用具有良好的可扩展性和可维护性。

第四章:生成响应

4.1 响应对象的属性和方法

在Django中,响应对象(HttpResponse)用于表示HTTP响应,包含了服务器返回给客户端的信息。常用的响应对象属性和方法包括:

  • response.status_code:获取响应的HTTP状态码,如200、404等。
  • response.content:获取响应的内容,通常是字节流或字符串。
  • response.charset:获取响应内容的字符集。
  • response.headers:获取响应的头部信息。
  • response.set_cookie():设置cookie信息。
  • response.delete_cookie():删除cookie信息。
  • response.write():向响应内容中写入数据。
  • response.flush():刷新响应内容。

除了上述属性和方法外,响应对象还包含其他一些方法,用于设置响应的内容、状态码、头部信息等。

4.2 响应处理流程

在Django中,响应处理的流程如下:

  1. 视图函数生成响应:在视图函数中,通过构造HttpResponse对象或其子类(如JsonResponse)来生成HTTP响应。视图函数可以设置响应的内容、状态码、头部信息等。
  2. 响应传递:生成的响应对象会被Django传递给中间件,中间件可以对响应进行处理或者添加额外的信息。
  3. 响应返回给客户端:最终,Django会将响应对象返回给客户端,客户端根据响应的内容和状态码进行处理。常见的响应状态码包括200(OK)、404(Not Found)、500(Internal Server Error)等。

视图函数根据业务逻辑生成响应对象,并通过该对象返回给客户端,完成了请求-响应循环。响应处理流程中,视图函数起到了生成响应的作用,而中间件则可以对响应进行进一步处理或者添加额外的信息。这样的设计使得Django应用能够灵活地处理各种请求,并返回相应的响应给客户端。

第五章:模板渲染

5.1 模板语言基础

Django模板语言(Django Template Language)是一种用于在HTML模板中插入动态内容的语言。其基础语法包括:

  • 变量:使用{{ variable }}语法表示变量,可以在模板中输出变量的值。
  • 标签:使用{% tag %}语法表示标签,用于控制模板的逻辑,如for循环、if条件判断等。
  • 过滤器:可以在变量输出时使用过滤器,如{{ variable|filter }},用于对变量进行格式化或处理。

示例:

<!DOCTYPE html>
<html>
<head>
    <title>{{ title }}</title>
</head>
<body>
    <h1>Hello, {{ user }}!</h1>
    
    <ul>
        {% for item in items %}
            <li>{{ item|upper }}</li>
        {% endfor %}
    </ul>
</body>
</html>

在上面的示例中,{{ title }}{{ user }}是变量,{% for %}是标签,|upper是过滤器。

5.2 模板渲染流程

模板渲染是将动态数据填充到模板中,生成最终的HTML页面的过程。在Django中,模板渲染的流程如下:

  1. 视图函数准备数据:在视图函数中,准备需要传递给模板的数据,可以是单个变量、字典、列表等。
  2. 构造上下文:将数据封装在上下文(Context)对象中,传递给模板引擎。
  3. 加载模板:模板引擎根据视图函数指定的模板路径,加载对应的模板文件。
  4. 渲染模板:模板引擎将上下文中的数据填充到模板中,生成最终的HTML页面。
  5. 返回响应:最终,视图函数将渲染好的HTML页面封装在HttpResponse对象中返回给客户端。

整个模板渲染流程中,视图函数起到了准备数据和指定模板的作用,模板引擎负责将数据填充到模板中并生成HTML页面,最终将HTML页面返回给客户端。这样的设计使得前端页面与后端数据逻辑分离,提高了代码的可维护性和可复用性。

第六章:表单处理

6.1 表单定义和验证

在Django中,定义表单类是通过继承forms.Formforms.ModelForm来实现的。表单类定义了表单的字段以及相应的验证规则。

表单类定义示例:
from django import forms

class MyForm(forms.Form):
    name = forms.CharField(label='Name', max_length=100)
    email = forms.EmailField(label='Email')
    message = forms.CharField(label='Message', widget=forms.Textarea)
表单验证过程:
  1. 在视图函数中实例化表单类:form = MyForm(request.POST)
  2. 调用表单的is_valid()方法进行表单数据验证。
  3. 如果表单数据有效,可以通过form.cleaned_data获取经过清洗后的数据。
  4. 如果表单数据无效,可以通过form.errors获取错误信息,将错误信息传递给模板以便显示给用户。

6.2 表单渲染和处理

表单渲染:
  1. 在模板中使用{{ form.as_p }}{{ form.as_ul }}{{ form.as_table }}来渲染表单字段。
  2. 可以通过{{ form.field_name }}来渲染单个字段,以及{{ form.field_name.errors }}来显示字段的错误信息。
表单处理:
  1. 在GET请求时,渲染空白表单供用户填写。
  2. 在POST请求时,根据用户提交的数据实例化表单对象。
  3. 调用表单的is_valid()方法进行验证,如果表单数据有效,处理数据;如果无效,返回带有错误信息的表单给用户重新填写。
  4. 在处理数据时,可以通过form.cleaned_data获取经过清洗后的数据,进行进一步处理。

示例视图函数:

from django.shortcuts import render
from .forms import MyForm

def my_view(request):
    if request.method == 'POST':
        form = MyForm(request.POST)
        if form.is_valid():
            # 处理有效的表单数据
            return render(request, 'success.html')
    else:
        form = MyForm()
    
    return render(request, 'my_template.html', {'form': form})

在上面的示例中,MyForm是自定义的表单类,my_view是处理表单的视图函数,根据请求的方法渲染空白表单或处理用户提交的表单数据。

第七章:上下文处理

7.1 上下文对象的概念

在Django中,上下文(Context)是将数据从视图传递给模板的一种方式。它是一个字典,其中键是模板中的变量名,值是这些变量的值。视图函数通过render()render_to_response()方法将上下文传递给模板,模板则使用这些数据进行渲染。

在视图中,通常使用context参数或return render(request, 'template.html', {'key': 'value', ...})这样的方式来设置上下文:

def my_view(request):
    data = {'name': 'John', 'age': 30}
    return render(request, 'template.html', context=data)

7.2 上下文处理器的定义和用法

Django的上下文处理器(Context Processors)是用于在视图无需显式设置上下文时自动添加或修改上下文的。它们是注册在Django设置中的函数,处理函数会在每次视图执行时被调用,可以修改传递给模板的默认上下文。

要定义一个上下文处理器,首先在settings.py中添加到TEMPLATESOPTIONS部分的context_processors列表:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'yourapp.context_processors.custom_processor',
            ],
        },
    },
]

然后,定义一个处理函数,例如:

from django.conf import settings
from django.template import Context, RequestContext

def custom_processor(request):
    # 在这里添加或修改要添加到上下文的键值对
    if settings.DEBUG:
        context = {'is_debug': True}
    else:
        context = {}
    
    # 如果需要使用RequestContext,确保添加到模板
    return RequestContext(request, context)

这个处理器会在每次请求时自动添加is_debug键到上下文,如果DEBUG设置为True。如果不需要RequestContext,则直接返回context字典。

第八章:中间件

8.1 中间件的概念和作用

中间件(Middleware)是Django框架中一种插件式的机制,用于在处理视图函数前后对请求和响应进行预处理和后处理。中间件可以在请求到达视图函数之前对请求进行处理,也可以在视图函数处理完响应后对响应进行处理。

中间件的作用包括但不限于:

  • 在处理请求前进行身份验证、权限检查等操作。
  • 在处理响应前对数据进行处理,如压缩、加密等。
  • 记录请求日志、性能监控等。
  • 在异常处理中对错误进行处理或重定向。

8.2 中间件的实现和应用

要编写和注册中间件,首先需要创建一个中间件类,实现process_request(处理请求前)、process_view(处理视图前)、process_response(处理响应后)等方法中的一个或多个。

class CustomMiddleware:
    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        # 在处理请求前的逻辑
        response = self.get_response(request)
        # 在处理响应后的逻辑
        return response

然后,在settings.py中的MIDDLEWARE设置中注册中间件类:

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'yourapp.middleware.CustomMiddleware',
]

中间件在请求-响应处理中的应用场景包括:

  • 认证和授权:在请求到达视图前进行用户身份验证和权限检查。
  • 日志记录:记录请求信息、响应时间等用于监控和分析。
  • 异常处理:捕获异常并返回自定义错误页面或信息。
  • 缓存控制:在响应中添加缓存控制头。
  • 响应处理:对响应进行处理,如添加额外的数据或修改响应内容。
  • 安全控制:在请求到达前进行安全检查,如跨站请求伪造(CSRF)保护等。

第九章:异常处理

9.1 异常的分类和处理

在Django中,异常通常分为两类:系统异常(由Django框架抛出)和自定义异常(由开发者定义)。系统异常是由Django框架在执行过程中遇到的错误,例如Http404PermissionDenied。自定义异常通常用于表示应用的业务逻辑错误。

捕获和处理异常

在Django中,异常处理通常通过视图函数中的try-except块来完成。系统异常可以通过Django的异常处理机制自动捕获和处理,而自定义异常需要开发者自己捕获并处理。

from django.http import HttpResponse
from django.views.generic import View

class MyView(View):
    def get(self, request, *args, **kwargs):
        try:
            # 视图逻辑
            pass
        except SystemExit as e:
            # 系统退出异常处理
            return HttpResponse("SystemExit: " + str(e))
        except Exception as e:
            # 其他异常处理
            return HttpResponse("Exception: " + str(e))
设置异常处理器

Django默认提供了一个异常处理器django.views.exception.handler,它会在视图函数中发生异常时被调用。开发者可以通过设置settings.py中的EXCEPTION_HANDLER来自定义异常处理器。

# settings.py

EXCEPTION_HANDLER = 'yourapp.utils.custom_exception_handler'

yourapp/utils.py中定义自定义异常处理器:

# utils.py

from django.http import HttpResponse
from django.views.exception import handler

def custom_exception_handler(exc, context):
    # 获取默认的异常处理器结果
    response = handler(exc, context)
    
    # 自定义处理逻辑
    if response is not None:
        response.content = "Custom Exception Content"
    
    return response

9.2 自定义异常处理

自定义异常处理可以让开发者根据特定的业务需求来处理异常。在Django中,自定义异常通常继承自django.core.exceptions.AppException或直接继承自Exception

# yourapp/exceptions.py

class CustomException(Exception):
    pass

在视图函数中使用自定义异常:

# views.py

from django.http import HttpResponse
from .exceptions import CustomException
from django.views.generic import View

class MyView(View):
    def get(self, request, *args, **kwargs):
        raise CustomException("This is a custom exception")

在异常处理器中捕获并处理自定义异常:

# utils.py

from django.http import HttpResponse
from django.views.exception import handler
from .exceptions import CustomException

def custom_exception_handler(exc, context):
    if isinstance(exc, CustomException):
        # 自定义异常处理逻辑
        return HttpResponse("Custom Exception Handled")
    
    response = handler(exc, context)
    return response

通过这种方式,开发者可以更好地控制异常的处理流程,提高应用的稳定性和用户体验。

附录A:Django最佳实践

AD: 一个覆盖广泛主题工具的高效在线平台(amd794.com)

  1. 代码规范

    • 命名约定:遵循PEP8(Python编码风格指南),如模型类名以CamelCase命名,函数名以snake_case命名。
    • 分模块:将代码划分为逻辑清晰的模块,如views.py, models.py, forms.py等。
    • Django模板:使用模板继承和模板标签提高复用性和可维护性。

AD: 漫画首页

  1. 性能优化

    • 查询优化:使用select_relatedprefetch_related减少数据库查询次数。
    • 缓存:使用django.core.cache或第三方缓存库(如Memcached或Redis)。
    • 分页:对于大量数据,使用分页功能,限制每页显示的数据量。
    • 静态文件处理:将静态文件(如CSS, JS, 图片)托管在CDN或使用collectstatic命令。

AD: 专业的搜索引擎

  1. 安全防范

    • CSRF保护:确保启用了CSRF保护,使用{% csrf_token %}标签。
    • 密码安全:使用get_password_hashcheck_password处理用户密码。
    • 输入验证:对用户输入进行验证,使用Django的ModelFormforms模块。
    • XSS和SQL注入防护:使用safeescape模板过滤器,以及django.middleware.csrf.CsrfViewMiddleware
  2. 可维护性

    • 文档:为代码编写清晰的注释,使用django.contrib.comments或自定义评论系统。
    • 代码审查:定期进行代码审查,遵循DRY(Don’t Repeat Yourself)原则。
    • 错误处理:使用try/except处理可能的错误,提供有用的错误消息。
  3. 部署

    • 设置环境变量:使用环境变量管理配置,如DJANGO_SETTINGS_MODULE
    • 使用部署工具:如Gunicorn, uWSGI, Nginx等。
    • 日志记录:启用详细的日志记录,使用logging模块。
  4. 持续集成/持续部署(CI/CD) :使用工具如Jenkins, Travis CI或GitHub Actions自动化构建和部署过程。

遵循这些最佳实践可以帮助你开发出更加健壮、高效和安全的Django应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1643036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

音视频开发之旅——实现录音器、音频格式转换器和播放器(PCM文件转换为WAV文件、使用LAME编码MP3文件)(Android)

本文主要讲解的是实现录音器、音频转换器和播放器&#xff0c;在实现过程中需要把PCM文件转换为WAV文件&#xff0c;同时需要使用上一篇文章交叉编译出来的LAME库编码MP3文件。本文基于Android平台&#xff0c;示例代码如下所示&#xff1a; AndroidAudioDemo Android系列&am…

OpenAI下周将发布ChatGPT搜索引擎,挑战谷歌搜索!

目前&#xff0c;多方位消息证实&#xff0c;OpenAI将会在5月9日上午10点公布该消息&#xff0c;大约是北京时间周五的凌晨2点。 5月3日&#xff0c;前Mila研究员、麻省理工讲师Lior S爆料&#xff0c;根据OpenAI最新的SSL证书日志显示&#xff0c;已经创建了search.chatgpt.c…

数据库开发关键之与DQL查询语句有关的两个案例

案例 案例1 条件分页查询 查看项目经理提供给我们的需求文档 模糊匹配的含义是 只要包含"张"就可以 use dduo;-- 按照需求完成员工管理的条件分页查询 根据输入条件 查询第一页的数据 每页展示10条记录 -- 输入条件&#xff1a; -- 姓名&#xff1a; 张 -- 年龄&…

基于Java+SpringBoot+Vue前后端分离音乐播放器系统设计与实现(有视频讲解)

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

统一大型语言模型和知识图谱:路线图

【摘要】 大型语言模型&#xff08;LLM&#xff09;&#xff0c;如ChatGPT和GPT4&#xff0c;由于其涌现能力和泛化性&#xff0c;正在自然语言处理和人工智能领域掀起新的浪潮。然而&#xff0c;LLM是黑箱模型&#xff0c;通常无法捕捉和获取事实知识。相反&#xff0c;知识图…

QQ音乐尽享海量高品质曲库,无广绿色版 PC端 v20.05.0

01 软件介绍 QQ音乐&#xff0c;作为一个在线音乐平台&#xff0c;它已经超越了传统音乐播放软件的界限&#xff0c;演变成为一个全面的音乐生态系统。该平台为用户提供了丰富的服务&#xff0c;包括无尽可能的音乐资源、定制化的个性推荐、卓越的高保真音乐体验和互动式的社交…

二叉树的迭代遍历 | LeetCode 144. 二叉树的前序遍历、LeetCode 94. 二叉树的中序遍历、LeetCode 145. 二叉树的后序遍历

二叉树的前序遍历&#xff08;迭代法&#xff09; 1、题目 题目链接&#xff1a;144. 二叉树的前序遍历 给你二叉树的根节点 root &#xff0c;返回它节点值的 前序 遍历。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,2,3]示例 2&#x…

分布式锁之-redis

什么是分布式锁&#xff1f; 即分布式系统中的锁。在单体应用中我们通过锁解决的是控制共享资源访问的问题&#xff0c;而分布式锁&#xff0c;就是解决了分布式系统中控制共享资源访问的问题。与单体应用不同的是&#xff0c;分布式系统中竞争共享资源的最小粒度从线程升级成了…

NumPy库与PyTorch库的异同点

目录 1.单位的创建和操作 1.创建 2.形状变换 2.数学和统计操作 1.矩阵乘法 2.广播 3.统计计算 3.GPU支持 4.在深度学习中的作用 5.应用范围 NumPy库为数组服务&#xff0c;PyTorch库为张量服务&#xff0c;这是最本质的区别。 1.单位的创建和操作 1.创建 NumPy:使…

SQL注入-基础知识

目录 前言 一&#xff0c;SQL注入是什么 二&#xff0c;SQL注入产生的条件 三&#xff0c;学习环境介绍 四、SQL注入原理 五&#xff0c;SQL中常用的函数 六&#xff0c;关于Mysql数据库 前言 在网络安全领域中&#xff0c;sql注入是一个无法被忽视的关键点&#xff0c…

matlab例题大全

1.第一章 1.1 注&#xff1a;plot函数为画图函数。例plot&#xff08;x1,y1,:,x2,y2,*&#xff09;; 1.2 注&#xff1a;root为求根函数。p为方程变量前面系数矩阵。 1.3 注&#xff1a; 2*x3y-1*z 2; 8*x2*y3*z 4; 45*x3*y9*z 23 求&#xff1a;x,y,z的值 注&#xf…

eNSP-浮动静态路由配置

ip route-static 192.168.1.0 24 192.168.3.2 preference 60 #设置路由 目标网络地址 和 下一跳地址 preference值越大 优先级越低 一、搭建拓扑结构 二、主机配置 pc1 pc2 三、配置路由器 1.AR1路由器配置 <Huawei>sys #进入系统视图 [Huawei]int g0/0/0 #进入接…

uniapp 微信开发工具上访问正常,真机调试一直跨域报错

微信小程序真机调试时&#xff0c;出现跨域问题&#xff0c;需要同时在后端设置多种允许跨域的设置&#xff1a; // 指定允许其他域名访问 header(Access-Control-Allow-Origin:*); // 响应类型 header(Access-Control-Allow-Methods:GET,POST,OPTION); // 响应头设置 header(…

使用Python爬取淘宝商品并做数据分析

使用Python爬取淘宝商品并做数据分析&#xff0c;可以按照以下步骤进行操作&#xff1a; 确定需求&#xff1a;确定要爬取的淘宝商品的种类、数量、关键词等信息。 编写爬虫程序&#xff1a;使用Python编写爬虫程序&#xff0c;通过模拟浏览器请求&#xff0c;获取淘宝商品的页…

redis 缓存一致性,缓存穿透,缓存雪崩,缓存击穿

1.缓存一致性&#xff1a; 缓存一致性就是通过各种方法保证缓存与数据库信息一种&#xff0c;其中最多的办法就是想尽一切办法对过期key进行清除&#xff0c;以保证redis和数据库信息一只&#xff0c;其中就包括了这篇文章中提到的内存淘汰策略&#xff0c;过期key的清除等等&…

Bookends for Mac:文献管理工具

Bookends for Mac&#xff0c;一款专为学术、研究和写作领域设计的文献管理工具&#xff0c;以其强大而高效的功能深受用户喜爱。这款软件支持多种文件格式&#xff0c;如PDF、DOC、RTF等&#xff0c;能够自动提取文献的关键信息&#xff0c;如作者、标题、出版社等&#xff0c…

深入理解网络原理3----TCP核心特性介绍(上)【面试高频考点】

文章目录 前言TCP协议段格式一、确认应答【保证可靠性传输的机制】二、超时重传【保证可靠性传输的机制】三、连接管理机制【保证可靠性传输的机制】3.1建立连接&#xff08;TCP三次握手&#xff09;---经典面试题3.2断开连接&#xff08;四次挥手&#xff09;3.3TCP状态转换 四…

Delta lake with Java--在spark集群上运行程序

昨天写了第一篇入门&#xff0c;今天看见有人收藏&#xff0c;继续努力学习下去。今天要实现的内容是如何将昨天的HelloDetlaLake 在spark集群上运行&#xff0c;。具体步骤如下 1、安装spark,我使用的是 spark-3.5.1-bin-hadoop3-scala2.13&#xff0c;去官网下载&#xff0c…

微服务----nacos配置及简单使用

目录 什么是nacos 项目在nacos上进行注册 注入nacos依赖 配置application.yml文件 nacos写入配置文件 首先&#xff0c;还是需要导入依赖 然后在nacos中编写配置文件 prod是我自定义的一个命名空间&#xff0c;在这里面进行配置文件编写~ 启动类上加上注解 编写Patt…

Java与Go:并发

在此之前&#xff0c;我们先要明白什么是并发&#xff1f;为什么要并发编程&#xff1f; 在计算机中&#xff0c;同一时刻&#xff0c;只能有一条指令&#xff0c;在一个CPU上执行 后面的指令必须等到前面指令执行完才能执行&#xff0c;就是串行。在早年CPU核心数还少的时候倒…