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

在 .NET 8 开发的WinForms 程序中展示程序版本号的几种方式

在这里插入图片描述

前言

欢迎关注dotnet研习社,今天我们讨论一个Winform开发中的一个常见的需求内容“关于程序的版本号显示”。

在 WinForms 桌面应用程序开发中,向用户显示当前程序的版本号是一个常见的需求,尤其是在产品发布、更新提示或技术支持场景中尤为重要。在.NET 8 中已全面采用 SDK 风格项目,相比旧的 .NET Framework 项目,版本号的设置和读取方式更加规范和现代化。本文将介绍在 WinForms 应用中显示程序版本号的几种常见方式,并附上示例代码,供大家参考和选择。


☑ 项目准备

确保我们的 .csproj 是 SDK 风格,并配置版本号:

<Project Sdk="Microsoft.NET.Sdk.WindowsDesktop"><PropertyGroup><OutputType>WinExe</OutputType><TargetFramework>net8.0-windows</TargetFramework><UseWindowsForms>true</UseWindowsForms><!-- 版本信息设置 --><Version>1.2.3</Version><FileVersion>1.2.3.0</FileVersion><AssemblyVersion>1.2.0.0</AssemblyVersion><InformationalVersion>1.2.3-beta</InformationalVersion></PropertyGroup></Project>

✅ 示例 1:窗体标题栏显示版本号(使用 Application.ProductVersion

示例代码:

public partial class MainForm : Form
{public MainForm(){InitializeComponent();this.Text = $"我的程序 - 版本 {Application.ProductVersion}";}
}

说明:

在这里插入图片描述

  • 输出示例:我的程序 - 版本 1.2.3-beta
  • 适用于:简洁快速展示,适合主界面。

✅ 示例 2:Label 中显示版本号(使用 AssemblyVersion

示例代码:

using System.Reflection;public partial class MainForm : Form
{public MainForm(){InitializeComponent();var version = Assembly.GetExecutingAssembly().GetName().Version;Label lblVersion = new Label{Text = $"程序集版本:{version}",AutoSize = true,Location = new Point(20, 20)};this.Controls.Add(lblVersion);}
}

说明:

在这里插入图片描述

  • 输出示例:程序集版本:1.2.0.0
  • 适用于:开发或内部测试查看版本绑定。

✅ 示例 3:状态栏中显示版本号(使用 FileVersionInfo

示例代码:

在窗体中添加了 StatusStripToolStripStatusLabel 控件,命名为 statusStrip1toolStripStatusLabel1

using System.Diagnostics;public partial class MainForm : Form
{public MainForm(){InitializeComponent();var info = FileVersionInfo.GetVersionInfo(Application.ExecutablePath);toolStripStatusLabel1.Text = $"文件版本:{info.FileVersion}";}
}

说明:

在这里插入图片描述

  • 输出示例:文件版本:1.2.3.0
  • 适用于:状态栏、底部信息区。

✅ 示例 4:AboutBox 显示版本号(使用 Application.ProductVersion

添加步骤:

在窗体中添加了 menuStriptoolStripMenuItem 控件,命名为 menuStrip1toolStripMenuItem1

  1. 添加 → 新建项 → “关于框(About Box)”
  2. AboutBox1.cs 修改版本号设置:
partial class AboutBox1 : Form
{public AboutBox1(){InitializeComponent();this.Text = String.Format("关于 {0}", AssemblyTitle);this.labelProductName.Text = AssemblyProduct;this.labelVersion.Text = String.Format("版本 {0}", AssemblyVersion);this.labelCopyright.Text = AssemblyCopyright;this.labelCompanyName.Text = AssemblyCompany;this.textBoxDescription.Text = AssemblyDescription;}#region 程序集特性访问器public string AssemblyTitle{get{object[] attributes = Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyTitleAttribute), false);if (attributes.Length > 0){AssemblyTitleAttribute titleAttribute = (AssemblyTitleAttribute)attributes[0];if (titleAttribute.Title != ""){return titleAttribute.Title;}}return System.IO.Path.GetFileNameWithoutExtension(Assembly.GetExecutingAssembly().CodeBase);}}public string AssemblyVersion{get{return Assembly.GetExecutingAssembly().GetName().Version.ToString();}}public string AssemblyDescription{get{object[] attributes = Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyDescriptionAttribute), false);if (attributes.Length == 0){return "";}return ((AssemblyDescriptionAttribute)attributes[0]).Description;}}public string AssemblyProduct{get{object[] attributes = Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyProductAttribute), false);if (attributes.Length == 0){return "";}return ((AssemblyProductAttribute)attributes[0]).Product;}}public string AssemblyCopyright{get{object[] attributes = Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyCopyrightAttribute), false);if (attributes.Length == 0){return "";}return ((AssemblyCopyrightAttribute)attributes[0]).Copyright;}}public string AssemblyCompany{get{object[] attributes = Assembly.GetExecutingAssembly().GetCustomAttributes(typeof(AssemblyCompanyAttribute), false);if (attributes.Length == 0){return "";}return ((AssemblyCompanyAttribute)attributes[0]).Company;}}#endregion
}
  1. 调用方式:
private void toolStripMenuItem1_Click(object sender, EventArgs e)
{new AboutBox1().ShowDialog();
}

在这里插入图片描述

✅ 示例 5:读取外部版本文件(CI 自动生成 version.txt

准备版本文件:

项目发布后输出目录含有 version.txt 内容如:

1.2.3+build.12345

示例代码:

public partial class MainForm : Form
{public MainForm(){InitializeComponent();string versionFile = Path.Combine(AppContext.BaseDirectory, "version.txt");string buildVersion = File.Exists(versionFile) ? File.ReadAllText(versionFile).Trim() : "Unknown";Label lbl = new Label{Text = $"构建版本:{buildVersion}",AutoSize = true,Location = new Point(20, 50)};this.Controls.Add(lbl);}
}

在这里插入图片描述

✅ 示例 6:统一封装 VersionHelper 工具类

using System.Reflection;
using System.Diagnostics;public static class VersionHelper
{public static string AssemblyVersion =>Assembly.GetExecutingAssembly().GetName().Version?.ToString() ?? "Unknown";public static string FileVersion =>FileVersionInfo.GetVersionInfo(Application.ExecutablePath).FileVersion ?? "Unknown";public static string ProductVersion =>Application.ProductVersion ?? "Unknown";
}

调用方式:

Label lbl = new Label
{Text = $"程序集版本:{VersionHelper.AssemblyVersion}\n文件版本:{VersionHelper.FileVersion}",AutoSize = true,Location = new Point(20, 80)
};
this.Controls.Add(lbl);

在这里插入图片描述

对比总结

方式编号获取方式来源(csproj 或程序集)示例输出推荐用途特点说明
Application.ProductVersion<InformationalVersion>(或 <Version>1.2.3-betaUI显示(标题栏、关于框、Label)默认最直观,获取产品版本,强烈推荐
Assembly.GetExecutingAssembly().GetName().Version<AssemblyVersion>1.2.0.0内部模块依赖、调试获取程序集绑定版本,不一定展示给用户
FileVersionInfo.FileVersion<FileVersion>1.2.3.0状态栏、日志、故障排查Windows 文件属性中可见的“文件版本”
FileVersionInfo.ProductVersion<InformationalVersion>(或 <Version>1.2.3-beta技术支持、版本详情和 Application.ProductVersion 一致
读取 version.txt、嵌入资源等CI/CD 或 Git 自动生成1.2.3+g123abc内部构建版本控制灵活但需配合构建脚本或 CI 工具
自定义 AboutBox 显示可组合 ①~⑤自由定制标准“关于”窗口常用于商业软件,集中展示版本、版权等

🎯 推荐选择指南

  • 开发初期快速显示:使用 Application.ProductVersion
  • 需要对比程序集版本绑定:使用 AssemblyVersion
  • 需要展示文件详细版本(如系统托盘右键):使用 FileVersionInfo
  • 需要区分构建版本(多环境发布):结合 CI 写入 version.txt
  • 面向最终用户展示:统一写入 AboutBox,使用封装工具类读取版本

相关文章:

在 .NET 8 开发的WinForms 程序中展示程序版本号的几种方式

前言 欢迎关注dotnet研习社&#xff0c;今天我们讨论一个Winform开发中的一个常见的需求内容“关于程序的版本号显示”。 在 WinForms 桌面应用程序开发中&#xff0c;向用户显示当前程序的版本号是一个常见的需求&#xff0c;尤其是在产品发布、更新提示或技术支持场景中尤为…...

[特殊字符] Spring Cloud 微服务项目中 common 模块依赖导致网关启动失败的排查与解决

在进行微服务开发时&#xff0c;我们通常会抽取一个 common 公共模块&#xff0c;封装一些通用配置类、工具类、拦截器、常用组件依赖等&#xff0c;供多个微服务共享使用。 但近期在实际开发中&#xff0c;出现了一个典型问题&#xff1a;在 Gateway 网关模块中引入 common 后…...

Java SpringMVC 和 MyBatis 整合关键配置详解

目录 一、数据源配置二、MyBatis 工厂配置三、Mapper 扫描配置四、SpringMVC 配置五、整合示例实体类Mapper 接口Mapper XML 文件Service 类控制器JSP 页面六、总结在 Java Web 开发中,SpringMVC 和 MyBatis 是两个常用框架。SpringMVC 负责 Web 层的请求处理和视图渲染,MyBa…...

24.(vue3.x+vite)引入组件并动态挂载(mount)

示例截图 组件代码: <template><div><div>{{message }}</div>...

Linux 软件包|服务管理

rpm 指令备注rpm -qa查看已安装软件&#xff0c;可以结合grep过滤查找rpm -e firefox卸载firefoxrpm -ivh firefox-115.12.0-1.el7.centos.i686.rpm安装gcc&#xff08;只能离线安装&#xff09; yum 能够从指定的服务器自动下载 RPM 包并且安装 指令备注yum list列出所有可…...

前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)

前端实现本地文件上传与预览&#xff08;PDF格式展示&#xff09;不走后端接口 实现步骤 第一步&#xff1a;文件选择 使用前端原生input上传本地文件&#xff0c;或者是el-upload组件实现文件选择功能&#xff0c;核心在于文件渲染处理。&#xff08;input只不过可以自定义样…...

TestNG接口自动化

第一章、 Rest assured接口测试框架 一、概述 接口自动化的框架&#xff0c;主要是用来做接口自动化测试&#xff0c;返回的报文都是JSON 语法比较简单&#xff0c;只需要掌握常用的方法 用例运行的速度非常快 断言的机制 Json 封装相关方法&#xff0c;jsonpath&#xff0c;x…...

Parasoft C++Test软件单元测试_实例讲解(指针类型的处理)

系列文章目录 Parasoft C++Test软件静态分析:操作指南(编码规范、质量度量)、常见问题及处理 Parasoft C++Test软件单元测试:操作指南、实例讲解、常见问题及处理 Parasoft C++Test软件集成测试:操作指南、实例讲解、常见问题及处理 进阶扩展:自动生成静态分析文档、自动…...

ngx_http_keyval_module动态键值管理

一、模块安装与验证 检查模块是否可用 nginx -V 2>&1 | grep --color -o ngx_http_keyval_module如果看到 ngx_http_keyval_module&#xff0c;说明模块已编译进 NGINX。 若未找到&#xff0c;请联系你的 NGINX 供应商&#xff0c;获取商业版或重新编译并启用该模块&am…...

面试篇:Spring MVC

基础概念 什么是Spring MVC&#xff1f; Spring MVC 是 Spring Framework 提供的一个基于 Servlet 的 Web 框架&#xff0c;属于 MVC&#xff08;Model-View-Controller&#xff09;架构的一种实现。它通过 DispatcherServlet 作为前端控制器&#xff0c;对请求进行分发和调度…...

C++初阶-string类的模拟实现3

目录 1.string::find(char ch,size_t pos0) const的模拟实现 2.string::find(const char* str,size_t pos0) const的模拟实现 3.string::size() const和string::capacity() const的模拟实现 4.string::operator[] (size_t pos)和string::operator[] (size_t pos) const的模拟…...

接口出现 请求参数格式错误 的解决方法

目录 前言1. 问题所示2. 原理分析3. 解决方法前言 🤟 找工作,来万码优才:👉 #小程序://万码优才/r6rqmzDaXpYkJZF 爬虫神器,无代码爬取,就来:bright.cn Java基本知识: java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)【Java项目】实战CRUD的功能整理…...

MYSQL时间函数、group by 和partition by的区别、组内编号leetcode学习

mysql时间函数 select now(); --当前时间 select current_date() --当前日期 select current_timestamp --同now()select date(2025-04-14 12:34:56) --提取日期部分&#xff1a;2025-04-14 select datediff(2025-4-14,2025-04-10) 日期相差四天 select date_sub(2024-04-14,…...

OpenCV 的 CUDA 模块中用于将一个多通道 GpuMat 图像拆分成多个单通道图像的函数split()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 cv::cuda::split 是 OpenCV CUDA 模块中的一个函数&#xff0c;用于将一个多通道的 GpuMat 图像拆分成多个单通道的 GpuMat 图像。这个函数是 CP…...

吴恩达机器学习笔记:单变量线性回归

通过一个例子来开始&#xff1a;这个例子是预测住房价格的&#xff0c;我们要使用一个数据集&#xff0c;数据集包含俄勒冈州波特兰市的住房价格。根据不同房屋尺寸所售出的价格&#xff0c;画出我的数据集。比方说&#xff0c;如果房子是 1250 平方尺大小&#xff0c;你要告诉…...

UI自动化测试框架:PO 模式+数据驱动

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 1. PO 设计模式简介 什么是 PO 模式&#xff1f; PO&#xff08;PageObject&#xff09;设计模式将某个页面的所有元素对象定位和对元素对象的操作封装成…...

NestJS 知识框架

一、核心概念 1. 架构基础 基于 Express/Fastify 的 Node.js 框架 采用模块化设计 使用 TypeScript 构建&#xff08;也支持 JavaScript&#xff09; 借鉴 Angular 的设计理念 2. 主要组件 模块 (Module): 应用的基本组织单元 控制器 (Controller): 处理 HTTP 请求 服务…...

Porting Linux to a new processor architecture, part 1: The basics

Although a simple port may count as little as 4000 lines of code—exactly 3,775 for the mmu-less Hitachi 8/300 recently reintroduced in Linux 4.2-rc1—getting the Linux kernel running on a new processor architecture is a difficult process. Worse still, the…...

Dagster Pipes系列-1:调用外部Python脚本

本文是"Dagster Pipes教程"的第一部分&#xff0c;介绍如何通过Dagster资产调用外部Python脚本并集成到数据管道中。首先&#xff0c;创建Dagster资产subprocess_asset&#xff0c;利用PipesSubprocessClient资源执行外部脚本external_code.py&#xff0c;实现跨进程…...

北京傲云源墅——区域价值腾飞的高端之选

在北京这座繁华都市中&#xff0c;房产的价值往往与区域的发展潜力息息相关。而傲云源墅项目&#xff0c;正位于极具价值的孙河墅区&#xff0c;这片土地正发生着令人瞩目的蝶变。近年来&#xff0c;孙河区域的崛起引人注目。2025 年 3 月&#xff0c;北京朝阳区平房乡黄杉木店…...

扩展:React 项目执行 yarn eject 后的 package.json 变化详解及参数解析

扩展&#xff1a;React 项目执行 yarn eject 后的 package.json 变化详解及参数解析 什么是 yarn eject&#xff1f;React 项目执行 yarn eject 后的 package.json 变化详解1. 脚本部分 Scripts 被替换2. 新增构建依赖 dependencies&#xff08;部分&#xff09;3. 新增 Babel …...

编写一个处理txt的loader插件,适用于wbepack

处理txt的webpack的loader插件 编写一个处理txt的loader插件&#xff0c;适用于wbepack 编写一个处理txt的loader插件&#xff0c;适用于wbepack 实现一个处理txt的插件&#xff0c;给文本每行前后添加**** module.exports function txtLoader(content) {// 确保 Loader 是异…...

高速边坡监测成本高?自动化如何用精准数据省预算?

高速边坡自动化监测解决方案 一、边坡监测的概述 1.1 边坡监测的背景 我国山地丘陵约占国土面积的65%&#xff0c;且地质地貌复杂&#xff0c;气候类型多样&#xff0c;构成活动频繁&#xff0c;自然灾害隐患多&#xff0c;分布广。而且近年来由于高速公路边坡滑坡灾害引发的事…...

SysAid On-Prem XML注入漏洞复现(CVE-2025-2776)

免责申明: 本文所描述的漏洞及其复现步骤仅供网络安全研究与教育目的使用。任何人不得将本文提供的信息用于非法目的或未经授权的系统测试。作者不对任何由于使用本文信息而导致的直接或间接损害承担责任。如涉及侵权,请及时与我们联系,我们将尽快处理并删除相关内容。 前…...

WEB安全--RCE--webshell bypass2

继WEB安全--RCE--webshell bypass的补充&#xff1a; 六、PHP反序列化 webshell&#xff1a; <?php $s unserialize(a:2:{i:0;O:8:"stdClass":1:{s:1:"a";i:1;}i:1;r:2;}); $c "123"; $arr get_declared_classes(); $i0;for($i;$i<c…...

Spark处理过程-转换算子和行动算子

&#xff08;一&#xff09;RDD的处理过程 RDD经过一系列的“转换”操作&#xff0c;每一次转换都会产生不同的RDD&#xff0c;以供给下一次“转换”操作使 用&#xff0c;直到最后一个RDD经过“行动”操作才会真正被计算处理。 1.延迟。RDD中所有的转换都是延迟的&…...

​Spring Boot 配置文件敏感信息加密:Jasypt 实战

​​ 目录 ​​ ​1. 为什么需要加密配置文件&#xff1f;​​ ​2. Jasypt 快速集成​ ​2.1 在xml文件中添加 Maven 依赖​ ​2.2 生成加密字符串​​ ​编辑 ​编辑 ​3. 安全最佳实践​ ​4. 常见问题​ ​Q1&#xff1a;加密后启动报错&#xff1f;​​ ​Q2&…...

c++STL-vector的模拟实现

cSTL-vector的模拟实现 vector的模拟实现基本信息构造函数析构函数返回容量&#xff08;capacity&#xff09;返回元素个数&#xff08;size&#xff09;扩容&#xff08;reserve和resize&#xff09;访问&#xff08;[]&#xff09;迭代器&#xff08;**iterator**&#xff09…...

【Python 变量类型】

Python 是一种动态类型语言&#xff0c;变量类型在运行时自动确定&#xff0c;无需显式声明。以下是 Python 中核心变量类型的分类与用法详解&#xff1a; 一、基本数据类型 1. 数值类型 整数 (int) 支持正负数、零和二进制/八进制/十六进制表示&#xff1a; a 42 b 0o52 #…...

2.2 微积分的解释

第一阶段&#xff1a;曲直转化的数学革命 原始困境&#xff1a; 几何局限&#xff1a;古希腊几何仅能计算矩形/三角形等直线图形面积现实需求&#xff1a;17世纪弹道轨迹、行星轨道等曲线相关计算需求激增关键矛盾&#xff1a;直线数学工具&#xff08;如毕达哥拉斯定理&…...

如何使用Selenium?

Selenium 是一个用于 Web 自动化测试 的开源工具套件&#xff0c;支持多种浏览器和编程语言。它最初是为测试 Web 应用而设计&#xff0c;但也被广泛用于 网页数据抓取 和 自动化操作。 Selenium 的核心组件 Selenium WebDriver 直接控制浏览器&#xff0c;模拟用户操作&…...

SVN 中文路径访问报错(权限已正确分配)

问题&#xff1a;SVN 中文路径访问报错&#xff08;权限已正确分配&#xff09; 原因&#xff1a; 1、URL特殊字符未转义 路径中包含空格、中文括号()等特殊符号&#xff0c;未进行URL编码 中文括号()示例&#xff1a;(设计)需转为%28%E8%AE%BE%E8%AE%A1%29&#xff0c;空格需…...

【Python 基础语法】

Python 基础语法是编程的基石&#xff0c;以下从核心要素到实用技巧进行系统梳理&#xff1a; 一、代码结构规范 缩进规则 使用4个空格缩进&#xff08;PEP 8标准&#xff09;缩进定义代码块&#xff08;如函数、循环、条件语句&#xff09; def greet(name):if name: # 正确缩…...

讲讲git 和svn

讲讲git 和svn 目录Git到底是什么&#xff1f;它该怎末用&#xff1f;核心概念基础操作1. 仓库的创建2. 文件的提交工作流程3. 分支管理4. 远程仓库操作 进阶操作实际应用建议**基本用法****常用命令的帮助示例****帮助文档的结构****替代方法****练习建议****核心概念****与Gi…...

运用数组和矩阵对数据进行存取和运算——NumPy模块 之四

目录 NumPy模块介绍 3.4 NumPy 数组重塑与转置 3.4.1 操作机制的理论逻辑 3.4.2 一维数组的重塑 3.4.3 多维数组的重塑 3.4.4 数组的转置操作 3.4.5 知识点总结与课程回顾 3.4.6 课后练习题 NumPy模块介绍 NumPy 是 Python 科学计算领域的重要基石&#xff0c;与当前 “躺吃旅行…...

机器学习第六讲:向量/矩阵 → 数据表格的数学表达,如Excel表格转数字阵列

机器学习第六讲&#xff1a;向量/矩阵 → 数据表格的数学表达&#xff0c;如Excel表格转数字阵列 资料取自《零基础学机器学习》。 查看总目录&#xff1a;学习大纲 关于DeepSeek本地部署指南可以看下我之前写的文章&#xff1a;DeepSeek R1本地与线上满血版部署&#xff1a;…...

服务器多JAR程序运行与管理指南

在同一台服务器上同时运行多个JAR程序是完全可以的&#xff0c;但需要注意以下几点以确保稳定性和性能&#xff1a; 关键注意事项 端口冲突 如果JAR程序是网络服务&#xff08;如Web应用&#xff09;&#xff0c;确保每个程序监听不同的端口&#xff08;例如&#xff1a;8080、…...

vue实现进度条带指针

效果最终 function calculatePointerPosition(value) {if (value < 2.6) return 12.5; // 非常差位置if (value < 5.1) return 37.5; // 较差位置if (value < 7.1) return 62.5; // 良好位置return 90; // 非常满意位置 }function getStatusText(value) {if (valu…...

【C++】智能指针

前言 上文我们学到了C11的异常&#xff0c;了解到了C与C语言处理错误的区别&#xff0c;异常的特点在于抛出与接收。【C11】异常-CSDN博客 本文我们来学习C中的下一个功能&#xff1a;智能指针 1.智能指针的使用场景 在上文我们知道了抛异常的知识&#xff0c;抛异常的“抛”这…...

Adobe Acrobat pro在一份PDF中插入空白页

在Adobe Acrobat pro中先打开我们的PDF文件&#xff1b; 用鼠标点击需要插入空白页处的上一页&#xff1b; 然后如下图操作&#xff1a; 默认会在光标处的下一页插入一张空白页&#xff0c;你也可以修改插入页的页码或者向前一页插入...

Oracle adg环境下调整redo日志组以及standby日志组大小

1.在adg环境中&#xff0c;调整redo日志组大小以及standby日志组大小主要思路如下&#xff1a; a、先备库增加standby redo 删除老standby redo, b、然后主库增加redo删除老redo, c、备库增加新redo删除老redo, d、最后主库增加standby redo。 #主库 [oracleDB196 ~]$ sql / a…...

Nlog适配达梦数据库进行日志插入

前言 原来使用的是SQLServer数据库&#xff0c;使用Nlog很流畅&#xff0c;没有什么问题。现在有个新项目需要使用麒麟操作系统和达梦数据库&#xff0c;业务流程开发完成之后发现Nlog配置文件中把数据库连接内容修改之后不能执行插入操作。 原Nlog.config配置 <?xml ve…...

记一次redis未授权被种挖矿

#挖矿程序 /etc/httpgd /etc/nnt.sh #大小问 #定时任务名为root /var/spool/cron/root 内容&#xff1a;*/50 * * * * sh /etc/nnt.sh >/dev/null 2>&1 定时任务只有所有者可以写&#xff0c;且chmod修改权限失败。 #先查看定时任务的拓展属性&#xff0c;不可变(i…...

Docker私有仓库实战:官方registry镜像实战应用

抱歉抱歉&#xff0c;离职后反而更忙了&#xff0c;拖了好久&#xff0c;从4月拖到现在&#xff0c;在学习企业级方案Harbor之前&#xff0c;我们先学习下官方方案registry&#xff0c;话不多说&#xff0c;详情见下文。 注意&#xff1a;下文省略了基本认证 TLS加密&#xff…...

LeetCode 热题 100_只出现一次的数字(96_136_简单_C++)(哈希表;哈希集合;排序+遍历;位运算)

LeetCode 热题 100_只出现一次的数字&#xff08;96_136_简单_C&#xff09; 题目描述&#xff1a;输入输出样例&#xff1a;题解&#xff1a;解题思路&#xff1a;思路一&#xff08;哈希表&#xff09;&#xff1a;思路二&#xff08;哈希集合&#xff09;&#xff1a;思路三…...

基于FastAPI框架的日志模块设计

以下是一个基于FastAPI框架设计的日志模块&#xff0c;结合SQLite数据库实现增删改查功能的完整实现方案&#xff1a; 1. 项目结构 your_project/ ├── app/ │ ├── logs/ # 日志模块目录 │ │ ├── models.py # 数据库模型定义 │ │ …...

网页禁止粘贴的解决方法(以学习通网页为例)

网页禁止粘贴的解决方法&#xff08;以学习通网页为例&#xff09; 学数据挖掘&#xff0c;学习通过作业的简答题要英文做答还竟然不能复制粘贴&#xff0c;受不了了 下面给出解决办法 1.想着是网页JS的问题&#xff0c;既然不能直接粘贴&#xff0c;那就在源码里面修改 2.于…...

Linux常用命令详解(下):打包压缩、文本编辑与查找命令

一、打包压缩命令 在Linux系统中&#xff0c;打包与压缩是文件管理的核心操作之一。不同的工具适用于不同场景&#xff0c;以下是最常用的命令详解&#xff1a; 1. tar命令 作用&#xff1a;对文件进行打包、解包、压缩、解压。 语法&#xff1a; tar [选项] [压缩包名] […...

前端面经 计网 http和https区别

HTTP 超文本传输 忒点&#xff1a; 支持CS 客户/服务器模式 方便快捷 简单 允许传输任意类型的数据 在报文头中的Content-Type中声明 无连接&#xff0c;一次连接仅处理一个请求 无状态 不保留上一次的状态 HTTPS 解决HTTP明文传输 在HTTP基础上增加SSL协议 HTTP版本 …...

mac一键安装gpt-sovit教程中,homebrew卡住不动的问题

mac一键安装gpt-sovit教程 仅作为安装过程中解决homebrew卡住问题的记录 资源地址 https://www.yuque.com/baicaigongchang1145haoyuangong/ib3g1e/znoph9dtetg437xb#mlAoP 下载一键包 下载后并解压&#xff0c;找到install for mac.sh&#xff0c;终端执行bash空格拖拽in…...