当前位置: 首页 > news >正文

Django回顾【二】

目录

一、Web框架

二、WSGI协议

三、 Django框架

1、MVC与MTV模型

2、Django的下载与使用

补充

3、启动django项目

补充

5、 Django请求生命周期

四、路由控制

1、路由是什么?

2、如何使用

3、path详细使用

4、re_path详细使用

5、反向解析

6、路由分发

五、视图层

1、格式

2、响应对象(本质上都是HttpResponse)

3、 CBV和FBV

4、关于类中self是谁的问题

5、上传文件


一、Web框架

Web框架(Web framework)是一种开发框架,用来支持动态网站、网络应用和网络服务的开发。这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方法。web框架已经实现了很多功能,开发人员使用框架提供的方法并且完成自己的业务逻辑,就能快速开发web应用了。浏览器和服务器的是基于HTTP协议进行通信的。也可以说web框架就是在以上十几行代码基础张扩展出来的,有很多简单方便使用的方法,大大提高了开发的效率。

即别人帮咱们写了一些基础代码 -------》我们只需要在固定的位置写固定的代码 ------》就能实现一个web应用

二、WSGI协议

最简单的Web应用就是先把HTML用文件保存好,用一个现成的HTTP服务器软件,接收用户请求,从文件中读取HTML,返回。

如果要动态生成HTML,就需要把上述步骤自己来实现。不过,接受HTTP请求、解析HTTP请求、发送HTTP响应都是苦力活,如果我们自己来写这些底层代码,还没开始写动态HTML呢,就得花个把月去读HTTP规范。

正确的做法是底层代码由专门的服务器软件实现,我们用Python专注于生成HTML文档。因为我们不希望接触到TCP连接、HTTP原始请求和响应格式,所以,需要一个统一的接口协议来实现这样的服务器软件,让我们专心用Python编写Web业务。这个接口就是WSGI。

基于这个协议的web服务器

  • wsgiref:Django框架默认就用它-------》性能低,并发量低-------》测试阶段使用
  • uwsgi:C语言写的
  • gunicorn:Python写的

协议到底怎么规定的:

  • web服务器后面的python框架一定是一个可调用的对象,必须接收两个参数(environ,start_response)
    • environ它是个字典------》里面全是http请求的东西

使用wsgiref写个web服务

from wsgiref.simple_server import make_serverdef mya(environ, start_response):print(environ)start_response('200 OK', [('Content-Type', 'text/html')])if environ.get('PATH_INFO') == '/index':with open('index.html','rb') as f:data=f.read()elif environ.get('PATH_INFO') == '/login':with open('login.html', 'rb') as f:data = f.read()else:data=b'<h1>Hello, web!</h1>'return [data]# 可调用对象---》能加括号执行的对象
if __name__ == '__main__':myserver = make_server('', 8011, mya) # 请求来了---》经过wsgiref---》调用后面的可调用对象# ---》传入两个参数(environ, start_response)print('监听8011')myserver.serve_forever()

三、 Django框架

1、MVC与MTV模型

所有Web框架其实都遵循MVC架构

1.1 MVC:把本来坨在一起的代码拆到不同的位置

MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的、松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求。

1.2 MTV

Django的MTV模式本质上和MVC是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django的MTV分别是值:

  • M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。
    • M就是原来的M
  • T 代表模板 (Template):负责如何把页面展示给用户(html)。
    • T就是原来的V
  • V 代表视图(View): 负责业务逻辑,并在适当时候调用Model和Template。
    • V+路由是原来的C

2、Django的下载与使用

在命令行输入:

  • pip uninstall django
  • pip3 install django==3.2.20
pip uninstall django  # 卸载
pip3 install django   # 如果不指定就会装最新版本

创建项目:

  • 命令创建:django-admin startproject 项目名
    • django-admin(会在python安装目录下的script文件夹多出一个可执行文件)
  • 使用pycharm创建
    • 本质也是在执行这个命令,编辑器帮咱们做了

目录结构:

补充

  • python 解释器安装完 -----》有几个重要的文件和文件夹
    • 根路径下  python.exe ----> 可以复制改名 -----》做多版本共存
    • scripts文件夹:pip命令在它下面,后期咱们会装 第三模块[可能会有可执行文件,可执行文件都放在这]
    • Lib:一堆文件夹中有py文件
      • python的解释器
        • 有些代码是用c写的    字典,列表
        • 有些代码是用python自己写的 :使用语言自己写自己:自举
      • 内置的模块自举的代码
      • 第三方包site-package---
  • 环境变量

环境变量(environment variables)一般是指在操作系统中用来指定操作系统运行环境的一些参数,如:临时文件夹位置和系统文件夹位置等。

环境变量是在操作系统中一个具有特定名字的对象,它包含了一个或者多个应用程序所将使用到的信息。

  • 环境变量的作用
    • 当要求系统(cmd)运行一个程序而没有告诉它程序所在的完整路径时,系统除了在当前目录(cmd当前的路径)下面寻找此程序外,还应到path中指定的路径去找。用户通过设置环境变量,来更好的运行进程。
    • 就是说,将一个程序的位置加入到环境变量后,回到命令窗口,不管此时的cmd在任何目录下,只要输入程序名(不区分大小写,不用带后缀.exe),这个程序就会启动。较之前的每次运行不同程序都要切换路径的方式,实在方便太多了。

3、启动django项目

python manage.py runserver 8001

这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到: 

补充

0.0.0.0和localhost和127.0.0.1有什么区别?

1、0.0.0.0
严格说来,0.0.0.0已经不是一个真正意义上的IP地址了。

它表示的是一个集合:所有 不清楚 的主机和目的网络。

“不清楚”:在本机的路由表里没有特定条目指明如何到达。对本机来说,它就是一个“收容所”,所有不认识的“三无”人员,一律送进去。如果在网络设置中设置了缺省网关,那Windows系统会自动产生一个目的地址为0.0.0.0的缺省路由。

用途:

  • 当一台主机还没有被分配一个IP地址的时候,用于表示主机本身。(DHCP分配IP地址的时候)
  • 用作默认路由,表示"任意IPV4主机”,即当路由表中没有找到完全匹配的路由的时候所对应的路由。
  • 用作服务端,表示本机上的任意IPV4地址。在服务端绑定端口的时候可以选择绑定到0.0.0.0,这样我的服务访问方就可以通过我的多个ip地址访问我的服务。
  • 用来表示目标机器不可用。
  • 监听0.0.0.0的端口,来监听本机中所有IP的端口。

2、127.0.0.1(一种本机保留的私有 IP)
本机地址,主要用于测试,即“我自己”。寻址这样一个地址,是不能把它发到网络接口的。除非出错,否则在传输介质上永远不应该出现目的地址为“127.0.0.1”的数据包。

127.0.0.1属于{127,}集合中的一个,而所有网络号为127的地址都被称之为环回地址,环回地址!== 127.0.0.1,它们是包含关系,即环回地址包含 127.0.0.1。

环回地址:所有发往该类地址的数据包都应该被loop back。所有发往目标IP为127.0.0.1的数据包都不会通过网卡发送到网络上,而是在数据离开网络层时将其回送给本机的有关进程。

用途:

  • 环回测试,通过使用ping 127.0.0.1 测试某台机器上的网络设备,操作系统或者TCP/IP实现是否工作正常。
  • DDos攻击防御:网站收到DDos攻击之后,将域名A记录到127.0.0.1,即让攻击者自己攻击自己。
  • 大部分Web容器测试的时候绑定的本机地址。
  • 一般会通过ping 127.0.0.1来测试某台机器上的网络设备是否工作正常。

3、localhost

相比127.0.0.1,localhost具有更多的意义。localhost是个域名,而不是一个ip地址。可修改。

用于指代 this computer 或者 this host,可以用它来获取运行在本机上的网络服务。

在大多数系统中,localhost被指向了 IPV4 的 127.0.0.1 和 IPV6 的 ::1,这就是把localhost与127.0.0.1等同的原因。

总结:

  • 0.0.0.0是一个特殊目的 IP 地址,称作不可路由 IP 地址,它的用途会被特殊规定。通常情况下,当我们把一个服务绑定到0.0.0.0,相当于把服务绑定到任意的 IP 地址。比如一台服务器上有多个网卡,不同网卡连接不同的网络,如果服务绑定到 0.0.0.0 就可以保证服务在多个 IP 地址上都可以用。
  • localhost指代的是本地计算机,用于访问绑定在 loopback 上的服务。localhost 是一个主机名,不仅仅可以指向 IPv4 的本地回环地址,也可以指向 IPv6 的本地回环地址 [::1]。
  • 127.0.0.1是本地回环地址(loopback),发送到 loopback 的数据会被转发到本地应用。

5、 Django请求生命周期

四、路由控制

1、路由是什么?

URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL与要为该URL调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于客户端发来的某个URL调用哪一段逻辑代码对应执行。即请求路径和要执行的视图函数的对应关系。

2、如何使用

  • 放在列表中:urlpatterns = [] ----> 列表中的数据,必须是 path或re_path执行完的结果
    • path:准确路径,精准匹配---》以后基本都是path
    • re_path:使用正则匹配---》就是原来的url---》使用非常少

3、path详细使用

path('admin/', login)
等价于:_path(route, view, kwargs=None, name=None)

第一个参数:准确路径,字符串

转换器: '<int:pk>'  '<str:name>' 

  • 127.0.0.1:8080/login/justin ----> path('login/<str:name>', admin.site.urls),
  • 视图函数中
    • def login(request,name) 

第二个参数: 视图函数的内存地址,不要加括号

  • 路由一旦匹配成功,就会执行你写的这个视图函数(request),并且会把request对象传入
  • 如果有分组的参数[有名,无名],或者转换器的参数,都会被传递到视图函数中作为参数
  • 总结:放要放视图函数地址-----》但是视图函数的参数:第一个是固定必须是request,后续的取决于写没写转换器,写没写有名无名分组

第三个参数:kwargs是给视图函数传递默认参数

第四个参数:路径的别名 -----》后期使用反向解析得到该路径

4、re_path详细使用

  • 跟path除了第一个参数不一样,其他完全一样
    • 第一个参数是:正则表达式
  • 后期用的很少,危险性大 -----》原来之所以支持正则的目的是为了分组出参数
  • path通过转换器能完成这个操作 ----》于是这个几乎不用

5、反向解析

在使用Django 项目时,一个常见的需求是获得URL 的最终形式,以用于嵌入到生成的内容中(视图中和显示给用户的URL等)或者用于处理服务器端的导航(重定向等)。人们强烈希望不要硬编码这些URL(费力、不可扩展且容易产生错误)或者设计一种与URLconf 毫不相关的专门的URL 生成机制,因为这样容易导致一定程度上产生过期的URL。

没有转换器的情况:

path('login/', login,name='login')
res = reverse('login')  # 当时定义路径传入的name参数对应的字符串

有转换器的情况:

path('login/<str:name>', login,name='login')
res = reverse('login',kwargs={name:lqz})  # 当时定义路径传入的name参数对应的字符串
生成这种路径:'login/lqz'1

6、路由分发

#主urls
from django.urls import path,re_path,include
from app01 import views
from app01 import urls
urlpatterns = [ # re_path(r'^app01/',include('app01.urls')),#行# re_path(r'^app01/&',include('app01.urls')),#不行# path('app01/',include('app01.urls')),#行 #path('app01/', include(urls)),
]

在app01里创建一个urls

from django.urls import path,re_path
from app01 import views
urlpatterns = [re_path(r'^test/(?P<year>[0-9]{2})/$',views.url_test),
]

五、视图层

views.py ----》这个文件目前写的是视图函数 

1、格式

def 视图函数(request):return 四件套

2、响应对象(本质上都是HttpResponse)

  • HttpResponse ----》字符串
  • render----》放个模板 ----》模板渲染是在后端完成
    • js代码是在客户端浏览器里执行的
    • 模板语法是在后端执行的
  • redirect  -----》重定向
    • 字符串参数不是空的
    • 状态码是3开头
  • JsonResponse---》json格式数据
    • return JsonResponse({name:kevin,age:19})
      • 本质是把传入的字典或列表(必须指定safe=False),使用json序列化得到json格式字符
        • 最终做成HttpResponse返回给前端
        • 如果想给json序列化的时候,传参数,必须使用json_dumps_params字典传入
      • 如果想往响应头中写数据 ----》需要传headers={'xx':'xx'}

JsonResponse源码分析

return JsonResponse({name:kevin,age:19})     
# 触发  JsonResponse的__init__--->{name:kevin,age:19}给了data
def __init__(self, data, encoder=DjangoJSONEncoder, safe=True,json_dumps_params=None, **kwargs):# 如果传入的是字典# safe是True,后面是False,条件不符合,内部就不会走if safe and not isinstance(data, dict):# isinstance(对象, 类) 判断这个对象,是不是这个类的对象raise TypeError('In order to allow non-dict objects to be serialized set the ''safe parameter to False.')if json_dumps_params is None: # 条件符合json_dumps_params = {}# kwargs是字典---》setdefault--》有则修改,无则新增kwargs.setdefault('content_type', 'application/json')# 核心---》把字典转成json格式字符串,赋值给datadata = json.dumps(data, cls=encoder, **json_dumps_params)# super().__init__ 调用父类的 __init__ 完成实例化---》HttpResponse的对象return HttpResponse(data,**kwargs)super().__init__(content=data, **kwargs)

3、 CBV和FBV

FBV(Function base view):基于函数的视图

CBV(Class base view):基于类的视图

CBV经典写法:

from django.views import View
class UserView(View):# 写方法---》跟请求方式同名的方法def get(self,request,*args,**kwargs)# 必须返回四件套
# 路由配置
path('index/', 视图类名.as_view()) # as_view是类的绑定方法

执行流程 ----》源码分析

path('index/', index), --->请求来了,路由匹配成功会执行 index(request,) 
path('index/', UserView.as_view()),
# 入口:路由 ---》as_view来开始
# 请求来了,路由匹配成功---》执行---》UserView.as_view()(request)
# 需要看as_view()执行结果是什么--》view--》代码如下:
def view(request, *args, **kwargs): # 方法,可以加括号调用return self.dispatch(request, *args, **kwargs)
# 本质就是在执行 view(request)
# 本质在执行---》self.dispatch(request, *args, **kwargs)
# 去类(UserViwe类中找,找不到,去父类View)中找dispatch,代码如下:
def dispatch(self, request, *args, **kwargs):
"""request当次请求的请求对象,取出请求方式【假设是get请求】,转成小写 'get'
http_method_names = ['get', 'post', 'put']
条件成立,执行if内部代码"""if request.method.lower() in self.http_method_names:"""getattr:反射 ---》通过字符串去对象中取属性或方法self是谁的对象? 是View这个类的对象,这个是视图类UserView的对象取出来的handler是UserView这个类的get方法"""handler = getattr(self, 'get')else:handler = self.http_method_not_allowed# handler是 UserView这个类的get方法"""get(request)---》触发UserView这个类的get方法---》真正执行原来视图函数的内容"""# 最终返回return handler(request, *args, **kwargs)

总结:

  • 写cbv,只需要在视图类中写跟请求方式同名的方法即可
  • 不同请求方式,就会执行不同的方法

4、关于类中self是谁的问题

class Animal:def run(self):# 这个self,是谁调用,就是谁print(type(self))  # <class '__main__.Person'># <class '__main__.Dog'>print(self.name, '走路')class Person(Animal):def __init__(self, name):self.name = nameclass Dog(Animal):def __init__(self, name, age):self.name = nameself.age = agep = Person('kevin')
p.run()  # kevin 走路dog = Dog('小奶狗', 6)
dog.run()  # 小奶狗 走路

总结:

self是谁调用。self就是谁,不能只看是哪个类

以后看到self.方法的时候,不要只从当前类,或父类中找,应该先确定当前self是谁,然后从这个对象的类根上开始找。

5、上传文件

  • 关于模板查找路径是配置文件中
TEMPLATES  --->'DIRS': [os.path.join(BASE_DIR, 'templates')]
  • python 
class FileView(View):def get(self,request):return render(request,'file.html')def post(self,request):# 拿出文件对象my_file=request.FILES.get('myfile')print(type(my_file)) 
# django.core.files.uploadedfile.InMemoryUploadedFile 
# 跟之前用的文件对象不一样,但是它应该继承了文件from django.core.files.uploadedfile import InMemoryUploadedFile# 1 保存  2 取出文件名字# my_file.save() # 找了一顿,没有,所以不能使用快捷保存方式,需要自己写保存print(my_file.name) # 3-回顾django.md# 自己写保存,放在项目根路径下with open(my_file.name,'wb') as f:for line in my_file:f.write(line)return HttpResponse('上传成功')
  • html 
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title></head>
<body>
<form action="" method="post" enctype="multipart/form-data"><input type="file" name="myfile"><br><input type="submit" value="提交">
</form>
</body>
</html>

相关文章:

Django回顾【二】

目录 一、Web框架 二、WSGI协议 三、 Django框架 1、MVC与MTV模型 2、Django的下载与使用 补充 3、启动django项目 补充 5、 Django请求生命周期 四、路由控制 1、路由是什么&#xff1f; 2、如何使用 3、path详细使用 4、re_path详细使用 5、反向解析 6、路由…...

[Ubuntu 18.04] RK3399搭建SSH服务实现远程访问

SSH(Secure Shell)是一种网络协议和软件,用于安全地远程登录到计算机并进行网络服务的加密通信。它提供了加密的认证和安全的数据传输,使得在不安全的网络中进行远程管理和访问变得更加安全。 以下是 SSH 服务的一些关键特点和用途: 安全认证:SSH 使用公钥/私钥加密技术…...

Linux进程间通信之共享内存

&#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;Linux &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 本博客主要内容讲解共享内存原理和相关接口的介绍&#xff0c;以及一个…...

lv11 嵌入式开发 RTC 17

目录 1 RTC简介 ​编辑2 Exynos4412下的RTC控制器 2.1 概述 2.2 特征 2.3 功能框图 3 寄存器介绍 3.1 概述 3.2 BCD格式的年月日寄存器 3.3 INTP中断挂起寄存器 3.4 RTCCON控制寄存器 3.5 CURTICCNT 作为嘀嗒定时器使用的寄存器 4 RTC编程 5 练习 1 RTC简介 RTC(…...

c语言指针详解(上)

目录 一、指针的基本概念和用法 二、指针运算 2.1 指针的自增和自减运算 2.2 指针的自增和自减运算 三、数组和指针 四、指针和函数 4.1 在函数中使用指针作为参数和返回值 4.1.1 使用指针作为函数参数 4.1.2 使用指针作为函数返回值 4.2 指针参数的传值和传引用特性 4.2.1 指针…...

如何删除mac苹果电脑上面的流氓软件?

在使用苹果电脑的过程中&#xff0c;有时候我们也会遇到一些不需要的软件。无论是因为不再需要&#xff0c;或者是为了释放磁盘空间&#xff0c;删除这些软件是很重要的。本文将为大家介绍怎样删除苹果电脑上的软件&#xff01; CleanMyMac X全新版下载如下: https://wm.make…...

WordPress(11)给文章添加预计阅读时长

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、文件配置二、代码块1.引入库2.配置 single.php三、效果图前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了…...

周周爱学习之快速排序

快速排序&#xff0c;顾名思义&#xff0c;快速排序是一种速度非常快的一种排序算法 平均时间复杂度为O(),最坏时间复杂度为O()数据量较大时&#xff0c;优势非常明显属于不稳定排序 1.算法描述 每一轮排序选择一个基准点&#xff08;pivot&#xff09;进行分区 让小于基准点…...

国产接口测试工具APIpost

说实话&#xff0c;了解APIpost是因为&#xff0c;我的所有接口相关的文章下&#xff0c;都有该APIpost水军的评论&#xff0c;无非就是APIpost是中文版的postman&#xff0c;有多么多么好用&#xff0c;虽然咱也还不是什么啥网红&#xff0c;但是不知会一声就乱在评论区打广告…...

MySQL电商管理系统练习题及答案

一 、表结构 用户表(user)&#xff1a;id(主键)、username、password、email、phone、age商品表(product)&#xff1a;id(主键)、name、price、stock、description订单表(order)&#xff1a;id(主键)、user_id(外键&#xff0c;关联用户表)、total_price、status、create_time…...

每日3道PWN(第二天)

ciscn_2019_n_1 参考&#xff1a; [BUUCTF-pwn]——ciscn_2019_n_1-CSDN博客 [BUUCTF]PWN5——ciscn_2019_n_1_ciscn_2019_n_4-CSDN博客 BUUCTF—ciscn_2019_n_1 1-CSDN博客 checksec一下 64位栈溢出 按f5查看main函数&#xff0c;双击可疑函数 发现含有命令执行的且发现fl…...

SAP STMS传输请求

一、概述 一般SAP项目上都会有六套系统&#xff0c;分别是&#xff1a; 测试环境-DEV系统 主要由100&#xff1a;沙盘系统&#xff1a;用于业务顾问配置 200&#xff1a;开发系统&#xff1a;用于开发ABAP写代码 300&#xff1a;测试系统&#xff1a;主要是单元测试、顾问自己…...

L1-009:N个数求和

目录 ⭐题目描述⭐ ⭐分析 ⭐程序代码 运行结果 ⭐文案分享⭐ ⭐题目描述⭐ 本题的要求很简单&#xff0c;就是求N个数字的和。麻烦的是&#xff0c;这些数字是以有理数分子/分母的形式给出的&#xff0c;你输出的和也必须是有理数的形式。 输入格式&#xff1a; 输入第一行给出…...

当发送“Hello,World”时,channel发生了什么?

一、Netty概述 1.Netty是什么&#xff1f; Netty 是一个异步的、基于事件驱动的网络应用框架&#xff0c;用于快速开发可维护、高性能的网络服务器和客户端。 2.Netty的地位怎么样&#xff1f; Netty 在 Java 网络应用框架中的地位就好比&#xff1a;Spring 框架在 JavaEE …...

服务器运行情况及线上排查问题常用命令

一、top命令 指令行&#xff1a; top返回&#xff1a; 返回分为两部分 &#xff08;一&#xff09;系统概览&#xff0c;见图知意 以下是几个需要注意的参数 1、load average&#xff1a; 系统负载&#xff0c;即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分…...

Hadoop学习笔记(HDP)-Part.18 安装Flink

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …...

LeetCode56. 合并区间

&#x1f517;:【贪心算法&#xff0c;合并区间有细节&#xff01;LeetCode&#xff1a;56.合并区间-哔哩哔哩】 class Solution { public:vector<vector<int>> merge(vector<vector<int>>& intervals) {if(intervals.size()0){return intervals;…...

解决typescript报错:找不到名称xxx

现象&#xff1a; 原因&#xff1a;在同时导入默认导出和命名导出时&#xff0c;默认导出必须放在命名导出之前 下面的就是原始文件&#xff1a; 默认导出指&#xff1a; export default导出类型&#xff0c; import时无需大括号 命名导出指&#xff1a; 仅有export关键字…...

UVM中封装成agent

在验证平台中加入monitor时&#xff0c;看到driver和monitor之间的联系&#xff1a;两者之间的代码高度相似。其本质是因为二者 处理的是同一种协议&#xff0c;在同样一套既定的规则下做着不同的事情。由于二者的这种相似性&#xff0c;UVM中通常将二者封装在一起&#xff0c;…...

OSI七层模型与TCP/IP四层模型

一、OSI七层模型简述 OSI 模型的七层是什么&#xff1f;在 OSI 模型中如何进行通信&#xff1f;OSI 模型有哪些替代方案&#xff1f; TCP/IP 模型关于专有协议和模型的说明 二、七层模型详解&#xff08;DNS、CDN、OSI&#xff09; 状态码DNS nslookup命令 CDN whois命令 …...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

VTK如何让部分单位不可见

最近遇到一个需求&#xff0c;需要让一个vtkDataSet中的部分单元不可见&#xff0c;查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行&#xff0c;是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示&#xff0c;主要是最后一个参数&#xff0c;透明度…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

九天毕昇深度学习平台 | 如何安装库?

pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子&#xff1a; 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...

蓝桥杯 冶炼金属

原题目链接 &#x1f527; 冶炼金属转换率推测题解 &#x1f4dc; 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V&#xff0c;是一个正整数&#xff0c;表示每 V V V 个普通金属 O O O 可以冶炼出 …...

中医有效性探讨

文章目录 西医是如何发展到以生物化学为药理基础的现代医学&#xff1f;传统医学奠基期&#xff08;远古 - 17 世纪&#xff09;近代医学转型期&#xff08;17 世纪 - 19 世纪末&#xff09;​现代医学成熟期&#xff08;20世纪至今&#xff09; 中医的源远流长和一脉相承远古至…...

GruntJS-前端自动化任务运行器从入门到实战

Grunt 完全指南&#xff1a;从入门到实战 一、Grunt 是什么&#xff1f; Grunt是一个基于 Node.js 的前端自动化任务运行器&#xff0c;主要用于自动化执行项目开发中重复性高的任务&#xff0c;例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...

免费数学几何作图web平台

光锐软件免费数学工具&#xff0c;maths,数学制图&#xff0c;数学作图&#xff0c;几何作图&#xff0c;几何&#xff0c;AR开发,AR教育,增强现实,软件公司,XR,MR,VR,虚拟仿真,虚拟现实,混合现实,教育科技产品,职业模拟培训,高保真VR场景,结构互动课件,元宇宙http://xaglare.c…...

Vite中定义@软链接

在webpack中可以直接通过符号表示src路径&#xff0c;但是vite中默认不可以。 如何实现&#xff1a; vite中提供了resolve.alias&#xff1a;通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...