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

Servlet详解

一.Servlet生命周期

  • 初始化
  • 提供服务
  • 销毁

1.测试生命周期

package com.demo.servlet;import javax.servlet.*;
import java.io.IOException;public class LifeServlet implements Servlet {@Overridepublic void init(ServletConfig servletConfig) throws ServletException {System.out.println("Servlet init");}@Overridepublic void service(ServletRequest servletRequest, ServletResponse servletResponse)throws ServletException, IOException {System.out.println("Servlet service");}@Overridepublic void destroy() {System.out.println("Servlet destroy");}@Overridepublic ServletConfig getServletConfig() {return null;}@Overridepublic String getServletInfo() {return null;}
}

2.初始化:init()

(1)默认情况

  • 默认情况下,第一次被请求的时候初始化,初始化在整个生命中只有一次

在这里插入图片描述

(2)设置初始化时间

  • 某种原因,导致第一次请求时初始化很慢,这时就可以修改Servlet的初始化时间

  • 使用其值为大于等于0的整数时,该Servlet就会在服务器启动时初始化,初始化在整个生命中只有一次

在这里插入图片描述

3.提供服务:service()

  • 生命周期中会提供n次

在这里插入图片描述

4.销毁:destroy()

  • 服务器关闭时自动销毁,生命周期中只有一次

在这里插入图片描述

二.Servlet的映射路径

1.web.xml配置

(1)标签

  • 的子标签,用于给Servlet配置访问路径

(2)注意

  1. 路径最前面加上/,代表根目录
  2. 路径中可以出现文件夹的,如/user/test/urlServlet

(3)示例

  • http://localhost:8888/day02_war_exploded/user/test/lifeServlet
  • http://localhost:8888/day02_war_exploded/user/life.html

2.模块前端文件的访问路径

  1. 访问文件时,只需要关注自己创建的目录,自动生成的不管
  2. 访问Servlet时,照着url-pattern设置的值来找

3.Servlet3.0注解配置

(1)使用前提

  • Servlet3.0和JDK1.5及以后的版本才能使用

(2)使用

在这里插入图片描述

(3)注意

  • 同一个Servlet,要么使用web.xml文件配置,要么使用注解配置,但是不能使用两种方式同时配置

  • 注解中的参数有name、serviceName;若是只写name参数,可以省略key值,只写value;除此之外要写key-value的形式

三.Servlet请求对象

1.HttpServletRequest接口

  • 请求对象
  • 父接口:ServletRequest
  • 包含请求行,请求头和请求体

在这里插入图片描述

2.请求行

(1)包含

  • 请求方式
  • 请求的资源
  • 协议及其版本

(2)获取信息

    @Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {System.out.println(req.getMethod());System.out.println(req.getRequestURL());System.out.println(req.getRequestURI());System.out.println(req.getServerName());System.out.println(req.getServerPort());}

3.请求头

(1)获取信息

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {String value1 = req.getHeader("Host");System.out.println(value1);Enumeration<String> names = req.getHeaderNames();while (names.hasMoreElements()) {String name = names.nextElement();String value = req.getHeader(name);System.out.println(name+":"+value);}}

4.请求体

  • 就是请求的数据,也就是Servlet中获取的参数

(1)Servlet中获取请求的数据的方法

  • request.getParameter(“name属性的值”);返回值类型为String
  • request.getParameterValues(“name属性的值”);返回值类型为String[]

(2)示例

    @Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {String username = req.getParameter("username");String password = req.getParameter("password");String gender = req.getParameter("gender");String hobbies[] = req.getParameterValues("hobbies");System.out.println(username+","+password+","+gender+","+ Arrays.toString(hobbies));}

5.Servlet获取参数乱码问题

(1)问题

  • 中文乱码,Servlet的默认编码集是ISO-8859-1(纯英文)
  • 页面输入中文进行提交,会乱码

(2)解决方案

在这里插入图片描述

四.文件上传

  • 就是在指定的位置复制出一个跟源文件一模一样的文件

1.页面编写

  • 表单的method属性的值必须是pos
  • 表单上加上enctype,值为multipart/form-data

在这里插入图片描述

2.Servlet

  • 在Servlet上加上@MultipartConfig

在这里插入图片描述

3.Post方法编写

  • 不同浏览器上传文件的路径不一样
  • 绝对路径(不带盘符)
  • 文件名+文件类型后缀
    @Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {//设置请求体编码集req.setCharacterEncoding("utf-8");String username = req.getParameter("username");String password = req.getParameter("password");String gender = req.getParameter("gender");String hobbies[] = req.getParameterValues("hobbies");System.out.println(username+","+password+","+gender+","+ Arrays.toString(hobbies));//文件相关处理//获取用户提交的文件对象Part part = req.getPart("photo");//指定上传路径String path = "d://upload";//判断该路径是否存在File file = new File(path);if (!file.exists()) {//不存在则创建file.mkdirs();}//获取上传的文件的名字String fileName = part.getSubmittedFileName();//在指定位置创建指定文件part.write(path+"/"+fileName);}

五.Servlet响应对象

1.HttpServletResponse接口

  • 服务器响应对象
  • 父接口:ServletResponse
  • 包含响应行,响应头和响应体。

在这里插入图片描述

2.响应行

  • 包含协议及其版本,状态码

(1)状态码

状态码说明
1**请求已到达服务器,但未完成,需要再次请求
2**请求已到达服务器,并且已完成
3**服务器内部资源重定向
4**资源找不到
5**服务器内部异常,代码异常
200成功
404找不到,原因:路径有问题
500代码有问题,90%以上都是空指针

(2)设置状态码

   @Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {resp.setStatus(404);}

3.响应头

响应头keyvalue
Location这个头通常配合302状态码使用,它用于告诉浏览器你去找谁。
Server告诉浏览器,服务器的类型
Content-Encoding服务器通过这个头,告诉浏览器,回送的数据采用的压缩格式。
Content-Length0
Content-Languagezh-cn
Content-Type这个头用于告诉浏览器,回送数据的类型
Last-Modified这个头用于告诉浏览器,数据的最后修改时间
Transfer-Encoding用于通知浏览器,数据是以分块形式回送的
Cache-Controlno-cache 通知浏览器不要缓存
Refresh1;url=http://www.it315.org 隔多少秒以后,让当前页面去访问哪个地址(例如网页登陆成功后,跳回原来的界面,就是用的这个头)
Content-Dispositionattachment;filename=aaa.zip 和下载相关,通知浏览器以附件的形式下载服务器发送过去的数据
Set-CookieSS=Q0=5Lb_nQ; path=/search 和cookie相关的头
ETagW/“83794-1208174400000” 和cookie相关的头
Expires-1 通知浏览器是否缓存当前资源:如果这个头的值是一个以毫秒为单位值,则通知浏览器缓存资源到指定的时间点;如果值是0或-1,则通知浏览器禁止缓存
Pragmano-cache 通知浏览器是否缓存资源
Connectionclose/Keep-Alive 是否继续保持连接
DateTue, 11 Jul 2000 18:23:51 GMT 当前响应的时间

(1)Location的使用

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {resp.setStatus(302);resp.setHeader("location","http://www.baidu.com");}

(2)Refresh的使用

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {resp.setHeader("refresh","2;url=http://www.qidian.com");}

4.响应体

  • 响应的数据,会将HTML,text等信息返回给客户端。

(1)响应数据传递方式

  • 响应数据需要通过流来传递,response自带两个输出流
  • 这两个流不能同时使用
ServletOutputStream out = response.getOutputStream();//字节流PrintWriter out = response.getWriter();//字符流

(2)示例

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {resp.setContentType("text/html;charset=utf-8");PrintWriter out = resp.getWriter();out.print("<h1>今天天气不错</h1>");out.close();}

六.文件下载

1.创建下载文件的页面

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><a href="responseServlet">下载</a>
</body>
</html>

2.添加测试图片操作

  • 去除原来的 exploded

  • 重新添加exploded

在这里插入图片描述

3.Servlet编写代码

  • 下载的源文件直接放在src目录下
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {//告诉浏览器,以附件的形式打开数据resp.setHeader("Content-Disposition","attachment;filename=erha.png");//输入流读取文件//this.getClass().getClassLoader().getResourceAsStream("gouza.png")用于快速的获取src当中问文件对象流InputStream in = this.getClass().getClassLoader().getResourceAsStream("gouza.png");//输出流写文件ServletOutputStream out = resp.getOutputStream();//边读边写byte[] b = new byte[1024];int len = 0;while ((len = in.read(b)) != -1) {out.write(b,0,len);}out.close();in.close();}

七.请求转发与重定向

1.Servlet进行跳转的方式

跳转方式方法
请求转发request.getRequestDispatcher(“跳转的文件路径”).forward(request,response);
重定向response.sendRedirect(“跳转的文件路径”);

2.请求转发

在这里插入图片描述

(1)请求转发概述

  • 服务器行为,客户端不知道整个操作在服务器中到底处理了多少次,所以地址栏不会发生改变
  • 整个过程中只发送了一个请求,所以request对整个转发过程中所有的Servlet是共享的
  • 请求转发的是那种数据提交方式,那么第二个servlet也是该方式,出form表单和超链接

(2)创建FirstServlet

package com.demo.servlet;import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@WebServlet("/firstServlet")
public class FirstServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {System.out.println("进入FirstServlet");req.setAttribute("color","red");System.out.println(req.getAttribute("color"));req.getRequestDispatcher("secondServlet").forward(req,resp);}
}

(3)创建SecondServlet

package com.demo.servlet;import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@WebServlet("/secondServlet")
public class SecondServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {System.out.println("进入SecondServlet");System.out.println(req.getAttribute("color"));}
}

(4)index.html,点击测试跳转

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><a href="firstServlet">测试请求转发</a>
</body>
</html>

(5)结果

在这里插入图片描述

3.重定向

在这里插入图片描述

(1)重定向概述

  • 客户端行为,客户端向FirstServlet发送请求,FirstServlet给了客户端响应告诉客户端去找SecondServlet,客户端向SecondServlet发送请求
  • 地址栏会变,request不共享

(2)创建FirstServlet

package com.demo.servlet;import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@WebServlet("/firstServlet")
public class FirstServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {System.out.println("进入FirstServlet");req.setAttribute("color","red");System.out.println(req.getAttribute("color"));resp.sendRedirect("secondServlet");}
}

(3)创建SecondServlet

package com.demo.servlet;import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@WebServlet("/secondServlet")
public class SecondServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {System.out.println("进入SecondServlet");System.out.println(req.getAttribute("color"));}
}

(4)测试

在这里插入图片描述

4.请求转发与重定向的区别

请求转发重定向
发出位置服务器行为客户端行为
地址栏内容地址栏不会发生改变地址栏会发生改变
请求次数只有一次请求至少两次请求
request共享equest是共享的request不共享的
转发效率较低
发送范围只能在当前模块中进行可以跳转到其他模块的作用域容器对象:作用域里面的作为容器的对象

--------------------------------------------------------: |
| 发出位置 | 服务器行为 | 客户端行为 |
| 地址栏内容 | 地址栏不会发生改变 | 地址栏会发生改变 |
| 请求次数 | 只有一次请求 | 至少两次请求 |
| request共享 | equest是共享的 | request不共享的 |
| 转发效率 | 高 | 较低 |
| 发送范围 | 只能在当前模块中进行 | 可以跳转到其他模块的作用域容器对象:作用域里面的作为容器的对象 |

相关文章:

Servlet详解

一.Servlet生命周期 初始化提供服务销毁 1.测试生命周期 package com.demo.servlet;import javax.servlet.*; import java.io.IOException;public class LifeServlet implements Servlet {Overridepublic void init(ServletConfig servletConfig) throws ServletException {…...

遥遥领先,免费开源的django4-vue3前后端分离项目

星域后台管理系统前端介绍 &#x1f33f;项目简介 本项目前端基于当下流行且常用的vue3作为主要技术栈进行开发&#xff0c;融合了typescript和element-plus-ui&#xff0c;提供暗黑模式和白昼模式两种主题以及全屏切换&#xff0c;开发bug少&#xff0c;简单易学&#xff0c…...

行业安卓主板-基于RK3568/3288/3588的AI智能网络广告机/自动售货机/收银机解决方案(三)

广告机 智能网络广告机通过网络将音视频、图片、文档、网页等自由排版创建成节目发布到终端。可针对不同的终端统一管理&#xff0c;统一发布&#xff1b;针对应用场景的集中和分散&#xff0c;可以选用局域网管理和云服务器管理。 自动售货机 随着物联网、大数据、人工智能的…...

寻找二维数组的最大值和对应下标 | C语言代码

题目&#xff1a; 本题目要求读入M(最大为10)行N&#xff08;最大为15&#xff09;列个元素&#xff0c;找出其中最大的元素&#xff0c;并输出其行列值。 输入格式: 输入在第一行中给出行数m和列数n。接下来输入m*n个整数。 输出格式: 输出最大值的行号,列号,值。 输入样例…...

2311dC++连接与串

原文 extern(C)函数使用在装饰名中包括参数类型的C装饰名.但是,因为C没有像D的T[]内置切片类型,因此C没有有效的D切片装饰. 因此,无法编译以D切片为参数的extern(C)函数. 为此,可按结构转换切片: struct DSlice(T) {T* ptr;size_t length;T[] opIndex() > ptr[0 .. length]…...

macOS 下 starUML 软件激活方案

starUML每次打开都弹出提示其实挺烦的&#xff0c;于是研究了一下如何 po 解(激活)它。记录一下方法以便以后使用。 我觉得这个软件很好用&#xff0c;大型项目的所有图我都是用这个软件画的。 直接上步骤&#xff01;先关掉starUML 1、安装 asar&#xff0c;以便可以打开 asa…...

一文读懂从 CPU 多级缓存 缓存一致性协议(MESI)到 Java 内存模型

文章目录 CPU 多级缓存 & 缓存一致性协议&#xff08;MESI&#xff09;CPU 多级缓存缓存一致性协议&#xff08;MESI&#xff09;缓存行&#xff08;Cache line&#xff09;四种缓存状态缓存行状态转换多核协同示例网站体验 MESI优化和引入的问题Store Bufferes & Inva…...

MongoDB设置密码

关于为什么要设置密码 公司的测试服务器MongoDB服务对外网开放的&#xff0c;结果这几天发现数据库被每天晚上被人清空的了&#xff0c;还新建了个数据库&#xff0c;说是要支付比特币。查了日志看到有个境外的IP登录且删除了所有的集合。所以为了安全起见&#xff0c;我们给m…...

重生奇迹mu召唤师怎么加点?

召唤师在重生奇迹mu游戏里面是一个智力型的职业&#xff0c;所以智力自然就成为主要加点属性&#xff0c;但是此职业却又算是近身攻击&#xff0c;因为她的技能范围并不算远&#xff0c;而且还是呈现出一种半径趋势&#xff0c;一方面是攻击伤害&#xff0c;另一方面则是辅助造…...

第九章《搞懂算法:决策树是怎么回事》笔记

决策树算法是机器学习中很经典的一个算法&#xff0c;它既可以作为分类算法&#xff0c;也可以作为回归算法。 9.1 典型的决策树是什么样的 决策树算法是依据“分而治之”的思想&#xff0c;每次根据某属性的值对样本进行分类&#xff0c;然后传递给下个属性继续进行分类判断…...

jar包的精细化运营,Java模块化简介 | 京东云技术团队

图&#xff1a;模块化手机概念 一、什么是Java模块化 Java模块化&#xff08;module&#xff09;是Java9及以后版本引入的新特性。 官方对模块的定义为&#xff1a;一个被命名的&#xff0c;代码和数据的自描述集合。&#xff08; the module, which is a named, self-descri…...

「Verilog学习笔记」移位运算与乘法

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 分析 1、在硬件中进行乘除法运算是比较消耗资源的一种方法&#xff0c;想要在不影响延迟并尽量减少资源消耗&#xff0c;必须从硬件的特点上进行设计。根据寄存器的原理&a…...

静态、友好、内在:解析C++中的这些特殊元素和对象复制的优化

W...Y的主页 &#x1f60a; 代码仓库分享&#x1f495; &#x1f354;前言&#xff1a; 前面我们学习了C中关于类与对象的许多知识点&#xff0c;今天我们继续学习类与对象&#xff0c;最后再总结一下类与对象中的一些关键字内容&#xff0c;以及需要注意的细节。满满的干货…...

【RabbitMQ】 RabbitMQ 消息的延迟 —— 深入探索 RabbitMQ 的死信交换机,消息的 TTL 以及延迟队列

文章目录 一、死信交换机1.1 什么是死信和死信交换机1.2 死信交换机和死信队列的创建方式 二、消息的 TTL2.1 什么是消息的 TTL2.2 基于死信交换机和 TTL 实现消息的延迟 三、基于 DelayExchang 插件实现延迟队列3.1 安装 DelayExchang 插件3.2 DelayExchang 实现消息延迟的原理…...

CVE-2023-34040 Kafka 反序列化RCE

漏洞描述 Spring Kafka 是 Spring Framework 生态系统中的一个模块&#xff0c;用于简化在 Spring 应用程序中集成 Apache Kafka 的过程&#xff0c;记录 (record) 指 Kafka 消息中的一条记录。 受影响版本中默认未对记录配置 ErrorHandlingDeserializer&#xff0c;当用户将容…...

全局变量和局部变量在for循环的使用

imageloc字典作为全局变量&#xff0c;然后添加到全局的列表中&#xff0c;每次for循环都会将最新的元素改变之前for循环添加的元素。而imageloc字典作为局部变量&#xff0c;则不会影响。 import numpy as np originaljson [{"joints_vis": [1,1,1,1,1,1,1,1,1,1,…...

pytorch collate_fn测试用例

collate_fn 函数用于处理数据加载器(DataLoader)中的一批数据。在PyTorch中使用 DataLoader 时&#xff0c;通过设置collate_fn&#xff0c;我们可以决定如何将多个样本数据整合到一起成为一个 batch。在某些情况下&#xff0c;该函数需要由用户自定义以满足特定需求。 import …...

【qemu逃逸】HITB2017-babyqemu 2019数字经济-qemu

前言 由于本地环境问题&#xff0c;babyqemu 环境都没有起起&#xff0c;这里仅仅做记录&#xff0c;exp 可能不正确。 HITB2017-babyqemu 设备逆向 设备定位啥的就不说了&#xff0c;先看下实例结构体&#xff1a; 其中 dma_state 结构体如下&#xff1a; 这里看字段猜测…...

Docker Compose学习笔记

Docker Compose用来做什么&#xff1f; Docker Compose 是Docker官方的开源项目。 Compose is a tool for defining and running multi-container Docker applications. With Compose, you use a YAML file to configure your application’s services. Then, with a single …...

基于树 二叉树的回溯搜索算法(DPLL)

1&#xff09;全称&#xff1a;Davis-Putnam-Logemann-Loveland 2&#xff09;思想&#xff1a;基于树/二叉树的回溯搜索算法&#xff0c;主要基于两种策略。 单子句规则&#xff1a;如果一个CNF范式中存在单子句L&#xff08;含有一个文字的子句&#xff09;&#xff0c;取L为…...

TFT LCD屏幕硬件解析:从XPT2046触摸屏到背光控制的完整指南

TFT LCD屏幕硬件解析&#xff1a;从XPT2046触摸屏到背光控制的完整指南 在工业控制面板和医疗设备显示屏等专业领域&#xff0c;TFT LCD屏幕凭借其高精度显示和可靠触控性能成为首选方案。不同于消费级产品的通用设计&#xff0c;专业场景下的屏幕需要工程师深入理解从触摸采样…...

AI与数据库融合:从经典论文到前沿实践

1. AI与数据库融合的起源与演进 数据库和人工智能这两个看似独立的领域&#xff0c;其实早在计算机科学发展的初期就已经产生了交集。上世纪70年代&#xff0c;当关系型数据库理论刚刚确立时&#xff0c;研究者们就开始探索如何让数据库系统具备一定的"智能"。当时的…...

Mid-70激光雷达与相机无目标标定:从环境搭建到实战避坑

1. 为什么选择Ubuntu 16.04进行Mid-70标定 最近在给Livox Mid-70激光雷达做相机标定时&#xff0c;我踩了个大坑——在Ubuntu 22.04上折腾了整整两天都没搞定环境配置。后来才发现问题出在版本兼容性上&#xff1a;ROS Kinetic、Ceres 1.14.x和Eigen 3.2.92这几个关键组件在新系…...

springboot+vue基于web的电脑配件商城的设计系统

目录 同行可拿货,招校园代理 ,本人源头供货商系统功能模块划分技术架构设计要点特色功能实现路径安全防护措施扩展性考虑 项目技术支持源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作 同行可拿货,招校园代理 ,本人源头供货商 系统功能模块…...

从CMIP6到SCI论文:气候降尺度全流程实战(含偏差校正与未来预估)-GCM数据降尺度、泰勒图评估及XGBoost机器学习建模指南

做水文气象、气候学、地理遥感、生态环境等领域的科研人&#xff0c;是不是都逃不过这些噩梦&#xff1a;尺度鸿沟难跨越&#xff1a;GCM 粗网格&#xff08;>100km&#xff09;和流域 / 城市精细尺度&#xff08;<10km&#xff09;不匹配&#xff0c;动力降尺度成本太高…...

GD32F407定时器实战:1ms中断精准控制LED闪烁(附源码与调试技巧)

GD32F407定时器实战&#xff1a;1ms中断精准控制LED闪烁&#xff08;附源码与调试技巧&#xff09; 1. 嵌入式定时器的核心价值与应用场景 在嵌入式系统开发中&#xff0c;定时器如同系统的心跳&#xff0c;为各类周期性任务提供精准的时间基准。以智能家居中的温控系统为例&…...

Granite TimeSeries FlowState R1高可用部署架构:基于Kubernetes的容器化方案

Granite TimeSeries FlowState R1高可用部署架构&#xff1a;基于Kubernetes的容器化方案 如果你正在为时间序列预测模型的生产部署而头疼&#xff0c;担心服务不稳定、无法应对流量高峰&#xff0c;那么这篇文章就是为你准备的。今天&#xff0c;我们来聊聊如何把一个强大的时…...

打破系统壁垒:从 Android 到 macOS,打造全平台统一终端管理(MDM)方案

目录 什么是统一设备管理&#xff1f; 一、引言 二、为什么跨平台设备管理至关重要 三、统一设备管理平台的核心功能 3.1 多平台生态整合 3.2 全设备生命周期管理 3.3 统一策略配置 3.4 广泛的行业适用性 四、实施统一设备管理的优势 五、企业设备管理的未来趋势 六…...

专业安防怎么选?奥尔特云与普通摄像头核心性能对比

不少人认为安防摄像头只是“能录像、能看见”就够&#xff0c;选型无需太过考究&#xff0c;实则这是安防系统搭建的关键误区。安防系统的核心是精准感知、有效采集&#xff0c;而摄像头作为前端核心采集设备&#xff0c;是所有安防数据的源头。若源头的画面质量、感知能力不达…...

别再踩坑了!KubeKey离线安装K8s v1.26.12时,containerd镜像拉取失败的完整避坑指南

KubeKey离线部署K8s集群&#xff1a;containerd镜像拉取全流程避坑手册 第一次用KubeKey离线部署Kubernetes集群时&#xff0c;containerd镜像拉取失败的问题让我折腾了大半天。看着部署日志里反复出现的证书错误提示&#xff0c;才意识到离线环境下的镜像仓库配置远比想象中复…...