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

海康威视摄像头C#开发指南:从SDK对接到安全增强与高并发优化

一、海康威视SDK核心对接流程​

1. ​​开发环境准备​
  • ​官方SDK获取​​:从海康开放平台下载最新版SDK(如HCNetSDK.dllPlayCtrl.dll)。
  • ​依赖项安装​​:确保C++运行库(如vcredist_x86.exe)与SDK版本匹配。
  • ​SDK引用配置​​:将DLL文件置于bin目录,通过DllImport动态调用。
2. ​​关键API封装(C#示例)​

csharp

using System.Runtime.InteropServices; public class HikvisionSDK { [DllImport("HCNetSDK.dll")] public static extern bool NET_DVR_Init(); [DllImport("HCNetSDK.dll")] public static extern int NET_DVR_Login_V30( string sDVRIP, int wDVRPort, string sUserName, string sPassword, ref NET_DVR_DEVICEINFO_V30 lpDeviceInfo); // 定义设备信息结构体 [StructLayout(LayoutKind.Sequential)] public struct NET_DVR_DEVICEINFO_V30 { public byte[] sSerialNumber; public byte byAlarmInPortNum; public byte byAlarmOutPortNum; // ...其他字段按SDK文档补充 } }

3. ​​设备连接与视频流获取​

csharp

// 初始化SDK if (!HikvisionSDK.NET_DVR_Init()) { throw new Exception("SDK初始化失败"); } HikvisionSDK.NET_DVR_DEVICEINFO_V30 deviceInfo = new HikvisionSDK.NET_DVR_DEVICEINFO_V30(); int userId = HikvisionSDK.NET_DVR_Login_V30("192.168.1.64", 8000, "admin", "password", ref deviceInfo); if (userId < 0) { int errorCode = HikvisionSDK.NET_DVR_GetLastError(); throw new Exception($"登录失败,错误码:{errorCode}"); } // 启动实时预览 int realHandle = HikvisionSDK.NET_DVR_RealPlay_V40(userId, ref previewParams, null, IntPtr.Zero);

二、第三方库增强开发​

1. ​​视频流处理库​
  • ​Emgu CV/OpenCVSharp​​:用于视频分析(人脸识别、运动检测)
     

    csharp

    using Emgu.CV; using Emgu.CV.Structure; // 从海康SDK获取帧数据后处理 Mat frame = new Mat(height, width, DepthType.Cv8U, 3, ptrToImageData); CvInvoke.Imshow("Live Feed", frame);

2. ​​ONVIF协议集成​
  • ​使用ONVIF.Core库​​:标准化设备控制(PTZ、事件订阅)
     

    csharp

    var device = new DeviceClient(new Uri(onvifUri), "admin", "password"); var ptz = new PTZClient(device.GetServiceUri()); ptz.RelativeMove(profileToken, new PTZVector(0.1f, 0, 0), new PTZSpeed());

3. ​​WebSocket实时通知​
  • ​SignalR集成​​:向Web前端推送报警事件
     

    csharp

    hubContext.Clients.All.SendAsync("AlarmEvent", new { Time = DateTime.Now, Type = "Motion" });


​三、设备商协作深度策略​

1. ​​协议与接口标准化​
  • ​ISAPI接口调用​​:通过HTTP REST配置设备参数
     

    csharp

    var client = new RestClient("http://192.168.1.64/ISAPI/System/deviceInfo"); client.Authenticator = new HttpBasicAuthenticator("admin", "password"); var response = client.Execute(new RestRequest(Method.GET));

​四、高级功能实现​

1. ​​云台控制(PTZ)​
 

csharp

// 通过SDK控制云台方向与速度 [DllImport("HCNetSDK.dll")] public static extern bool NET_DVR_PTZControl_Other( int lRealHandle, uint dwPTZCommand, uint dwStop, uint dwSpeed); // 示例:向左转动,速度3级 const uint PAN_LEFT = 2; // 命令码参考SDK文档 HikvisionSDK.NET_DVR_PTZControl_Other(realHandle, PAN_LEFT, 0, 3);

2. ​​报警订阅与事件处理​
 

csharp

// 设置报警回调函数 [DllImport("HCNetSDK.dll")] public static extern int NET_DVR_SetDVRMessageCallBack_V31( AlarmCallbackDelegate cbMessage, IntPtr pUser); // 定义回调委托 public delegate void AlarmCallbackDelegate( int lCommand, IntPtr pAlarmInfo, int dwBufLen, IntPtr pUser); // 处理移动侦测报警 private static void OnAlarmEvent(int cmd, IntPtr alarmInfo, int len, IntPtr user) { if (cmd == 0x2100) // 移动侦测事件码 { var alarmData = Marshal.PtrToStructure<NET_DVR_ALARMINFO>(alarmInfo); Console.WriteLine($"报警时间:{alarmData.dwAlarmTime}"); } }


​五、多媒体处理扩展​

1. ​​音频采集与对讲​
 

csharp

// 启用音频流 var audioParam = new NET_DVR_AUDIOENC_CB_PARAM { cbAudioEnc = AudioDataCallback, // 音频数据回调 dwSampleRate = 8000, byAudioEncType = 0 // G.711A }; HikvisionSDK.NET_DVR_SetAudioEncCallBack(realHandle, ref audioParam); // 发送语音到设备(对讲) byte[] audioBuffer = File.ReadAllBytes("audio.g711"); HikvisionSDK.NET_DVR_VoiceComSendData(realHandle, audioBuffer, (uint)audioBuffer.Length);

2. ​​视频流媒体服务器集成​
  • ​使用SRS或Nginx RTMP​​:将海康RTSP流转发为RTMP/HLS
     

    bash

    ffmpeg -i "rtsp://admin:password@192.168.1.64/Streaming/Channels/1" -c:v copy -c:a aac -f flv "rtmp://localhost/live/stream1"


​六、协议扩展与国标支持​

1. ​​GB/T 28181国标协议对接​
 

csharp

// 注册到上级国标平台 var gbParam = new NET_DVR_GB28181_REGISTER_PARAM { sServerIP = "gb.example.com", wServerPort = 5060, sDeviceID = "34020000001320000001", byTransportMode = 0 // UDP }; HikvisionSDK.NET_DVR_GB28181_Register(userId, ref gbParam);

2. ​​ONVIF与SDK混合编程​
  • ​动态切换控制权​​:当SDK和ONVIF同时操作PTZ时,需加锁避免冲突
     

    csharp

    private readonly object ptzLock = new object(); public void SafePTZControl(Action action) { lock (ptzLock) { action.Invoke(); } }


​七、安全增强方案​

1. ​​OAuth 2.0设备认证​
 

csharp

// 使用海康ISAPI OAuth接口获取Token var authClient = new RestClient("https://open.hikvision.com/oauth/token"); var request = new RestRequest(Method.POST); request.AddParameter("client_id", "your_client_id"); request.AddParameter("client_secret", "your_secret"); request.AddParameter("grant_type", "client_credentials"); var token = authClient.Execute<OAuthResponse>(request).Data.access_token;

2. ​​视频流AES加密​
 

csharp

// 使用SDK的加密传输模式 var loginParam = new NET_DVR_USER_LOGIN_INFO { bUseEncrypt = true, // 启用加密 byEncryptType = 1 // AES-128 }; HikvisionSDK.NET_DVR_Login_V40(ref loginParam, out deviceInfo);


​八、故障排查与性能优化​

1. ​​高并发场景优化​
  • ​连接池管理​​:复用设备登录句柄,避免频繁登录/登出
     

    csharp

    public class DeviceConnectionPool { private ConcurrentDictionary<string, int> activeConnections = new(); public int GetConnection(string ip) { return activeConnections.GetOrAdd(ip, key => LoginDevice(key)); } }

2. ​​内存泄漏检测​
  • ​使用Diagnostic Tools​​:监控非托管内存泄漏
     

    csharp

    // 确保释放SDK资源 public void Release() { HikvisionSDK.NET_DVR_Logout(userId); HikvisionSDK.NET_DVR_Cleanup(); Marshal.FreeHGlobal(frameBuffer); // 显式释放非托管内存 }

3. ​​延迟问题定位​
  • ​帧时间戳分析​​:计算视频流端到端延迟
     

    csharp

    var receiveTime = DateTime.Now; var networkDelay = (receiveTime - frameTimestamp).TotalMilliseconds; if (networkDelay > 500) { AdjustBufferSize(realHandle, 2); // 增大缓冲 }


​九、设备管理最佳实践​

1. ​​批量配置工具​
  • ​通过ISAPI批量修改参数​​:
     

    csharp

    var batchUpdate = new RestRequest("/ISAPI/System/configuration", Method.PUT); batchUpdate.AddJsonBody(new { System = new { DeviceName = "Camera-{ID}", TimeZone = "GMT+08:00" } }); client.Execute(batchUpdate);

2. ​​固件升级自动化​
 

csharp

// 使用HTTP PUT上传固件文件 var upgradeRequest = new RestRequest("/ISAPI/System/update", Method.POST); upgradeRequest.AddFile("firmware", "Hikvision_V5.5.0.bin"); upgradeRequest.AddParameter("reboot", "true"); var response = client.Execute(upgradeRequest);


​十、第三方服务集成​

1. ​​AI分析服务对接​
 

csharp

// 将视频帧发送至TensorFlow Serving var tensorFrame = ConvertToTensor(frame); var client = new HttpClient(); var response = await client.PostAsJsonAsync( "http://ai-server:8501/v1/models/face_det:predict", new { inputs = tensorFrame }); var faces = ParseDetectionResult(response);

2. ​​云存储回放​
 

csharp

// 从海康NVR查询录像并上传至阿里云OSS var recordFiles = HikvisionSDK.NET_DVR_FindFile(userId, startTime, endTime); foreach (var file in recordFiles) { var stream = HikvisionSDK.NET_DVR_GetFileByName(userId, file.FileName); ossClient.PutObject("my-bucket", $"backup/{file.Name}", stream); }

 

相关文章:

海康威视摄像头C#开发指南:从SDK对接到安全增强与高并发优化

一、海康威视SDK核心对接流程​​ 1. ​​开发环境准备​​ ​​官方SDK获取​​&#xff1a;从海康开放平台下载最新版SDK&#xff08;如HCNetSDK.dll、PlayCtrl.dll&#xff09;。​​依赖项安装​​&#xff1a;确保C运行库&#xff08;如vcredist_x86.exe&#xff09;与S…...

大语言模型 14 - Manus 超强智能体 开源版本 OpenManus 上手指南

写在前面 Manus 是由中国初创公司 Monica.im 于 2025 年 3 月推出的全球首款通用型 AI 智能体&#xff08;AI Agent&#xff09;&#xff0c;旨在实现“知行合一”&#xff0c;即不仅具备强大的语言理解和推理能力&#xff0c;还能自主执行复杂任务&#xff0c;直接交付完整成…...

使用 LibreOffice 实现各种文档格式转换(支持任何开发语言调用 和 Linux + Windows 环境)[全网首发,保姆级教程,建议收藏]

以下能帮助你可以使用任何开发语言&#xff0c;在任何平台都能使用 LibreOffice 实现 Word、Excel、PPT 等文档的自动转换&#xff0c;目前展示在 ASP.NET Core 中为 PDF的实战案例&#xff0c;其他的文档格式转换逻辑同理。 &#x1f4e6; 1. 安装 LibreOffice &#x1f427;…...

CentOS Stream 9 中部署 MySQL 8.0 MGR(MySQL Group Replication)一主两从高可用集群

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《MySQL技术精粹》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、前言 1、MySQL 8.0 中的高可用方案 2、适用场景 二、环境准备 1、系统环境说明…...

软考中级软件设计师——计算机网络篇

一、计算机网络体系结构 1.OSI七层模型 1. 物理层&#xff08;Physical Layer&#xff09; 功能&#xff1a;传输原始比特流&#xff08;0和1&#xff09;&#xff0c;定义物理介质&#xff08;如电缆、光纤&#xff09;的电气、机械特性。 关键设备&#xff1a;中继器&#…...

RK3568 OH5.1 源码编译及问题

安装编译器和二进制工具 在源码根目录下执行prebuilts脚本&#xff0c;安装编译器及二进制工具。 bash build/prebuilts_download.sh在源码根目录执行如下指令安装hb编译工具&#xff1a; python3 -m pip install --user build/hb使用build.sh脚本编译源码 进入源码根目录&…...

【razor】回环结构导致的控制信令错位:例如发送端收到 SR的问题

一、razor的echo程序 根据对 yuanrongxi/razor 仓库的代码和 echo 测试程序相关实现的分析,下面详细解读 echo 程序中 RTCP sender report(SR)、receiver report(RR)回显的问题及项目的解决方式。 1. 问题背景 在 RTP/RTCP 体系下,SR(Sender Report)由发送端周期性发…...

leetcode hot100:三、解题思路大全:哈希(两数之和、字母异位词分组、最长连续序列)、双指针(移动零、盛最多水的容器、三数之和、接雨水)

哈希 两数之和 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案&#xff0c;并且你不能使用两次相同的元素。 你可以按任意顺序返…...

MySQL 8.0 OCP 1Z0-908 161-170题

Q161.Examine this command, which executes successfully: cluster.addInstance ( ‘:’,{recoveryMethod: ‘clone’ 1}) Which three statements are true? (Choose three.) A)The account used to perform this recovery needs the BACKUP_ ADMIN privilege. B)A target i…...

onlyoffice 源码 调试说明 -ARM和x86双模式安装支持

很多用户在调试onlyoffice源码最大的问题是如何搭建环境,这个难度很高,下面提供一键安装的方式,让普通用户也能快速调试源码。 OnlyOffice Document Server 基于源码运行的容器调试模式&#xff0c;凭借 Docker 容器化技术的核心优势&#xff0c;为开发者提供了跨平台、高兼容性…...

workflow:高效的流式工作架构

引言 workflow是sougou的一款开源框架 主要是以请求回应的模式解决各自网络/IO任务而发明的 一.workflow的任务流 1.workflow都封装了哪些任务流 以请求回应的模式来解释 ① 网络层 服务端 在服务端的request 相当于发送了一个获取客户端请求的请求&#xff0c;response相当…...

音视频之H.265/HEVC速率控制

H.265/HEVC系列文章&#xff1a; 1、音视频之H.265/HEVC编码框架及编码视频格式 2、音视频之H.265码流分析及解析 3、音视频之H.265/HEVC预测编码 4、音视频之H.265/HEVC变换编码 5、音视频之H.265/HEVC量化 6、音视频之H.265/HEVC环路后处理 7、音视频之H.265/HEVC熵编…...

jsmpeg+java+ffmpeg 调用摄像头RTSP流播放

原理就是这样&#xff0c;明白吧。本次用springboot netty起这个2个服务&#xff0c;执行拉代码执行即可 <!-- netty --><dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><version>4.1.68.Final</ver…...

深度剖析ZooKeeper

1. ZooKeeper架构总览 ZooKeeper 是一个分布式协调服务&#xff0c;广泛用于分布式系统中的配置管理、命名服务、分布式锁和领导选举等场景。以下是对 ZooKeeper 架构、通信机制、容错处理、数据一致性与可靠性等方面的详细剖析。 一、ZooKeeper 主从集群 ZooKeeper 采用 主从…...

Zookeeper 集群安装与脚本化管理详解

安装之前:先关闭所有服务器的防火墙&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; systemctl stop firewalld 关闭防火墙 systemctl disable firewalld 开机不启动防火…...

第10天-Python操作MySQL数据库全攻略:从基础连接到高级应用

一、环境准备 1. 安装MySQL驱动 bash 复制 下载 # 官方推荐驱动 pip install mysql-connector-python# 或使用PyMySQL(兼容性更好) pip install pymysql 2. 创建测试数据库 sql 复制 下载 CREATE DATABASE python_db; USE python_db;CREATE TABLE users (id INT AU…...

Spring Cloud Gateway深度解析:原理、架构与生产实践

文章目录 前言一、概述二、核心架构设计及设计原理2.1 分层架构模型网络层&#xff08;I/O模型&#xff09;核心处理层 2.2 核心组件协作流程路由定位阶段过滤器执行阶段 2.3 响应式编程模型实现Reactor上下文传递背压处理机制 2.4 动态路由设计原理2.5 异常处理体系2.6 关键路…...

Trae 04.22版本深度解析:Agent能力升级与MCP市场对复杂任务执行的革新

我正在参加Trae「超级体验官」创意实践征文&#xff0c;本文所使用的 Trae 免费下载链接&#xff1a;Trae - AI 原生 IDE 目录 引言 一、Trae 04.22版本概览 二、统一对话体验的深度整合 2.1 Chat与Builder面板合并 2.2 统一对话的优势 三、上下文能力的显著增强 3.1 W…...

股指期货模型,简单易懂的套利策略

在股指期货投资领域&#xff0c;有不少实用的模型和策略&#xff0c;今天咱们就用大白话来唠唠其中几个重要的概念。 一、跨期套利&#xff1a;合约间的“差价游戏” 跨期套利简单来说&#xff0c;就是投资者以赚取期货合约之间的价差为目的&#xff0c;在同一个期货品种的不…...

MySQL 故障排查与生产环境优化

目录 1. MySQL单实例故障排查 2. MySQL 主从故障排查 3. MySQL 优化 3.1 硬件方面 3.2 MySQL 配置文件 3.3 SQL 方面 1. MySQL单实例故障排查 &#xff08;1&#xff09; 故障现象1 ERROR 2002 (HY000): Cant connect to local MySQL server through socket /data/mysql…...

Java泛型 的详细知识总结

一、泛型的核心作用 类型安全&#xff1a;在编译期检查类型匹配&#xff0c;避免运行时的ClassCastException。代码复用&#xff1a;通过泛型逻辑统一处理多种数据类型。消除强制转换&#xff1a;减少显式的类型转换代码。 二、泛型基础语法 1. 泛型类/接口 定义&#xff1a…...

k8s 配置 Kafka SASL_SSL双重认证

说明 kafka提供了多种安全认证机制&#xff0c;主要分为SASL和SSL两大类。 SASL&#xff1a; 是一种身份验证机制&#xff0c;用于在客户端和服务器之间进行身份验证的过程&#xff0c;其中SASL/PLAIN是基于账号密码的认证方式。 SSL&#xff1a; 是一种加密协议&#xff0c;…...

电商虚拟户:重构资金管理逻辑,解锁高效归集与智能分账新范式

一、电商虚拟户的底层架构与核心价值 在数字经济浪潮下&#xff0c;电商交易的复杂性与日俱增&#xff0c;传统账户体系已难以满足平台企业对资金管理的精细化需求。电商虚拟户作为基于银行或持牌支付机构账户体系的创新解决方案&#xff0c;通过构建“主账户子账户”的虚拟账户…...

从混乱到高效:我们是如何重构 iOS 上架流程的(含 Appuploader实践)

从混乱到高效&#xff1a;我们是如何重构 iOS 上架流程的 在开发团队中&#xff0c;有一类看不见却至关重要的问题&#xff1a;环境依赖。 特别是 iOS App 的发布流程&#xff0c;往往牢牢绑死在一台特定的 Mac 上。每次需要发版本&#xff0c;都要找到“那台 Mac”&#xff…...

01 基本介绍及Pod基础

01 查看各种资源 01-1 查看K8s集群的内置资源 [rootmaster01 ~]# kubectl api-resources NAME SHORTNAMES APIVERSION NAMESPACED KIND bindings v1 …...

DAY31-文件的规范拆分和写法

知识点回顾 规范的文件命名规范的文件夹管理机器学习项目的拆分编码格式和类型注解 &#xff08;一&#xff09;文件拆分 思考&#xff1a;如何把一个文件&#xff0c;拆分成多个具有着独立功能的文件&#xff0c;然后通过import的方式&#xff0c;来调用这些文件。这样具有几个…...

[创业之路-369]:企业战略管理案例分析-9-战略制定-差距分析的案例之华为

一、综合案例 在战略制定中&#xff0c;华为通过差距分析明确战略方向&#xff0c;以应对市场挑战和实现长期发展目标。 以下为具体案例与分析&#xff1a; 1、案例背景 华为在通信设备领域崛起过程中&#xff0c;始终将差距分析作为战略制定的核心环节。面对国际竞争对手&…...

【华为鸿蒙电脑】首款鸿蒙电脑发布:MateBook Fold 非凡大师 MateBook Pro,擎云星河计划启动

文章目录 前言一、HUAWEI MateBook Fold 非凡大师&#xff08;一&#xff09;非凡设计&#xff08;二&#xff09;非凡显示&#xff08;三&#xff09;非凡科技&#xff08;四&#xff09;非凡系统&#xff08;五&#xff09;非凡体验 二、HUAWEI MateBook Pro三、预热&#xf…...

深入理解Redis Cluster:架构、原理与实践

Redis 是一个高性能的键值存储数据库&#xff0c;广泛应用于缓存、会话存储、消息队列等场景。随着数据量和并发量的增长&#xff0c;单机 Redis 可能面临性能瓶颈和单点故障问题。为了解决这些问题&#xff0c;Redis 提供了 Redis Cluster&#xff0c;一种分布式解决方案&…...

分析 redis 的 exists 命令有一个参数和多个参数的区别

在 redis 中&#xff0c;exists 命令是用来查询某个或多个 key 是否存在的&#xff0c;返回存在的 key 的个数。 由于 redis 是按照键值对方式存储数据的&#xff0c;于是一个 key 只能对应一组数据&#xff0c;那么上述的 key 的个数指的即是需要查询的 key 中有几个 key 是存…...

[概率论基本概念1]什么是经验分布

一、说明 描述一个概率模型&#xff0c;有密度函数很好描述。如果写不出密度函数&#xff0c;退而用分布函数也能完整刻画&#xff0c;因此&#xff0c;分布函数表示比密度函数表示更加宽泛普适。本片讲述经验分布拟合分布函数的基础概念。 二、经验分布直观解释 在统计学中…...

使用Java实现Navicat密码的加密与解密

在日常开发过程中&#xff0c;我们有时需要处理各种软件保存的凭据信息&#xff0c;比如数据库连接密码等。这篇文章将介绍如何使用Java对Navicat保存的数据库密码进行加密和解密。 一、背景介绍 Navicat是一款强大的数据库管理工具&#xff0c;支持多种数据库系统。为了保护…...

怎么样进行定量分析

本文章将教会你如何对实验结果进行定量分析&#xff0c;其需要一定的论文基础&#xff0c;文末有论文撰写小技巧&#xff0c;不要看基础原理的人可以直接调到文章末尾。 一、什么是定量分析 定量分析是一种基于数据和数学模型的分析方法&#xff0c;它在众多领域中发挥着至关…...

python学习day2

今天主要学习了变量的数据类型&#xff0c;以及如何使用格式化符号进行输出。 一、认识数据类型 在python里为了应对不同的业务需求&#xff0c;也把数据分为不同的类型。 代码如下&#xff1a; """ 1、按类型将不同的变量存储在不同的类型数据 2、验证这些…...

FreeMarker

概述&#xff1a;FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据&#xff0c; 并用来生成输出文本(HTML网页&#xff0c;电子邮件&#xff0c;配置文件&#xff0c;源代码等)的通用工具。 它不是面向最终用户的&#xff0c;而是一个Java类库&#xff0c;是一款程序…...

JDK 21新特性详解

JDK 21新特性详解&#xff1a;现代Java开发的重大更新 Java开发工具包(JDK)21作为最新的长期支持(LTS)版本&#xff0c;于2023年9月发布&#xff0c;带来了许多令人兴奋的新特性。作为Java开发者&#xff0c;了解这些新功能对于保持技术竞争力至关重要。本文将详细介绍JDK 21中…...

使用MCP驱动IDA pro分析样本

最近国外的牛人开发了一个ida pro的mcp server&#xff0c;项目的地址为mrexodia/ida-pro-mcp: MCP Server for IDA Pro&#xff0c;实现了通过自然对话来分析样本。 今天我们试用一下。 MCP Server for IDA Pro项目简介 这个mcp server提供下面这些工具&#xff0c;基本涵盖…...

Web前端开发:@media(媒体查询)

什么是媒体查询&#xff1f; 媒体查询是CSS3的一个功能&#xff0c;允许你根据设备的特性&#xff08;如屏幕宽度、设备方向、分辨率等&#xff09;应用不同的CSS样式。简单来说&#xff0c;就是让网页在不同设备上&#xff08;手机、平板、电脑&#xff09;自动调整布局和样式…...

psotgresql18 源码编译安装

环境&#xff1a; 系统&#xff1a;centos7.9 数据库&#xff1a;postgresql18beta1 #PostgreSQL 18 已转向 DocBook XML 构建体系&#xff08;SGML 未来将被弃用&#xff09;。需要安装 XML 工具链&#xff0c;如下&#xff1a; yum install -y docbook5-style-xsl libxsl…...

如何在VSCode中更换默认浏览器:完整指南

引言 作为前端开发者&#xff0c;我们经常需要在VSCode中快速预览HTML文件。默认情况下&#xff0c;VSCode会使用系统默认浏览器打开文件&#xff0c;但有时我们可能需要切换到其他浏览器进行测试。本文将详细介绍如何在VSCode中更换默认浏览器。 方法一&#xff1a;使用VSCo…...

Python Day26 学习

继续NumPy的学习 数组的索引 一维数组的索引 创建及输出 arr1d np.arange(10) # 数组: [0 1 2 3 4 5 6 7 8 9] arr1d array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]) 取出数组的第一个元素&#xff0c;最后一个元素 代码实现 arr1d[0] arr1d[-1] 取出数组中索引为3&#x…...

2025年PMP 学习二十一 14章 项目立项管理

2025年PMP 学习二十一 14章 项目立项管理 项目立项管理 项目建议 (Project Proposal)项目可行性分析 (Project Feasibility Analysis)项目审批 (Project Approval)项目招投标 (Project Tendering)项目合同谈判和签订 (Project Contract Negotiation and Signing) 文章目录 20…...

Ubuntu开机自启服务

一、准备启动脚本 在你的项目文件夹&#xff08;例如 /home/ubuntu/Plant_Diease_Recongnization_Server_1&#xff09;中创建一个启动脚本 run_ui_main.sh&#xff1a; #!/usr/bin/env bash # run_ui_main.sh&#xff1a;激活 yolov8 环境并启动 ui_main.py# 设置 Anaconda/…...

使用Docker部署React应用与Nginx

这个教程将帮助您使用Docker部署一个带有React的Nginx容器&#xff0c;并通过卷(volumes)将本地代码绑定到Docker容器中。这种设置非常适合开发环境&#xff0c;因为它允许您在本地编辑代码&#xff0c;而容器中的应用会自动更新。 步骤概述 创建Nginx配置文件创建Dockerfile…...

基于SpringBoot的小型民营加油站管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

Triton介绍和各平台支持情况分析

文章目录 &#x1f49e;Triton介绍&#x1f9e0; Triton 是什么&#xff1f;&#x1f50d; Triton 的核心特点&#x1f680; Triton 在 PyTorch 中的作用&#x1f4e6; Triton 的典型使用场景&#x1f9ea; 示例&#xff1a;Triton 编写的向量加法&#xff08;GPU 并行&#xf…...

HTTPS核心机制拆解

目录 引言 HTTPS和HTTP的区别 常见加密方式 数据摘要 数字证书与数据签名 HTTPS请求过程 结语 引言 HTTPS是什么&#xff1f;是一个应用层协议&#xff0c;在HTTP协议的基础上引入了一层加密层。为什么需要HTTPS&#xff1f;答案是显而易见的&#xff0c;要加密&#xf…...

我的食物信使女友

第一章&#xff1a;初识那是一个普通的周三下午&#xff0c;阳光透过咖啡馆的玻璃窗洒在木质的桌子上&#xff0c;空气中弥漫着咖啡的香气和轻柔的爵士乐。我坐在角落的一个位置&#xff0c;手中捧着一本已经翻了几十页的小说&#xff0c;但心思却完全不在文字上。我的生活就像…...

【D1,2】 贪心算法刷题

文章目录 不同路径 II整数拆分 不同路径 II 初始化的时候不能整列初始化为1&#xff0c;因为如果有障碍物&#xff0c;后面的都不能到达 也不能整列初始化为0&#xff0c;因为状态转移的时候第一行第一列都没有检查&#xff0c;因此不能部分初始化 整数拆分 需要考虑几种情况…...

C++多态的详细讲解

【本节目标】 1. 多态的概念 2. 多态的定义及实现 3. 抽象类 4. 多态的原理 5. 单继承和多继承关系中的虚函数表 前言 需要声明的&#xff0c;本博客中的代码及解释都是在 vs2013 下的 x86 程序中&#xff0c;涉及的指针都是 4bytes 。 如果要其他平台下&#xff0c;部…...