C#注册表技术及操作

目录

一、注册表基础

1.Registry和RegistryKey类 

(1)Registry类

(2)RegistryKey类

二、在C#中操作注册表

1.读取注册表中的信息 

(1)OpenSubKey()方法

(2)GetSubKeyNames()方法

(3)GetValueNames()方法

2.创建和修改注册表信息

(1)创建注册表信息

(2)修改注册表信息

3.删除注册表中的信息

(1)DeleteSubKey()方法

(2)DeleteSubKeyTree方法

(3)DeleteValue()方法 


        注册表是一个庞大的数据库系统,它记录了用户安装在计算机上的软件、硬件信息和每一个程序的相互关系。注册表中存放着很多参数,直接控制着整个系统的启动、硬件驱动程序的装载以及应用程序的运行。

        由于Windows 10系统本身的安全性问题,使用C#操作注册表时,可能会提示无法操作相应的注册表项,这时只需要为提示的注册表项添加everyone用户的读写权限即可

一、注册表基础

        Windows注册表包含Windows安装、用户喜好以及已安装软件和设备的所有配置信息的核心存储库。

1.RegistryRegistryKey类 

        NET Framework提供了访问注册表的类,比较常用的是Registry和RegistryKey类,这两个类都在Microsoft.Win32命名空间中。

(1)Registry类

        Registry类不能被实例化,它的作用只是实例化RegistryKey类,以便开始在注册表中浏览。Registry类是通过静态属性来提供这些实例的,这些属性共有7个:

属   性

说   明

ClassesRoot

定义文档的类型(或类)以及与那些类型关联的属性。该字段读取Windows注册表基项HKEY_CLASSES_ROOT

CurrentConfig

包含有关非用户特定的硬件的配置信息。该字段读取Windows注册表基项HKEY_CURRENT_CONFIG

CurrentUser

包含有关当前用户首选项的信息。该字段读取Windows注册表基项HKEY_CURRENT_USER

DynData

包含动态注册表数据。该字段读取Windows注册表基项HKEY_DYN_DATA

LocalMachine

包含本地计算机的配置数据。该字段读取Windows注册表基项HKEY_LOCAL_MACHINE

PerformanceData

包含软件组件的性能信息。该字段读取Windows注册表基项HKEY_PERFORMANCE_DATA

Users

包含有关默认用户配置的信息。该字段读取Windows注册表基项HKEY_USERS

        Registry类主要用于存储有关用户首选项的信息、存储本地计算机的配置信息、存储有关类型和类及其属性的信息、存储有关默认用户配置的信息、存储软件组件的性能信息、存储非用户特定的硬件信息、存储动态数据。

(2)RegistryKey类

        RegistryKey实例表示一个注册表项,这个类的方法可以浏览子键、创建新键、读取或修改键中的值。也就是说,该类可以完成对注册表项的所有操作。除了设置键的安全级别之外,RegistryKey类可以用于完成对注册表的所有操作。

        RegistryKey类的常用属性及说明:

属    性

说    明

Name

   检索项的名称

SubKeyCount

   检索当前项的子项数目

ValueCount

   检索项中值的计数

        RegistryKey类的常用方法及说明

方法

说 明

 Close

   关闭键

CreateSubkey

   创建给定名称的子键(如果该子键已经存在,就打开它)

DeleteSubkey

   删除指定的子键

DeleteSubkeyTree

   彻底删除子键及其所有的子键

DeleteValue

   从键中刑除一个指定的值

GetSubkeyNames

   返回包含子键名称的字符串数组

 GetValue

   返回指定的值

GetValueNames

   返回一个包含所有键值名称的字符申数组

OpenSubKey

   返回表示给定子键的 RegistryKey 实例引用

 SetValue

   设置指定

二、C#中操作注册表

        主要包括读取注册表中的信息删除注册表中的信息以及创建和删除注册表信息

1.读取注册表中的信息 

       读取注册表中的信息主要是通过RegistryKey类中的OpenSubKey()方法、GetSubKeyNames()方法和GetValueNames()方法实现的。

(1)OpenSubKey()方法

        OpenSubKey()方法用于检索指定的子项。

public RegistryKey OpenSubKey(string name)
☑ name:要以只读方式打开的子项的名称或路径。
☑ 返回值:请求的子项。如果操作失败,则为空引用。

        如果要打开的项不存在,OpenSubKey()方法将返回null引用,而不是引发异常。

(2)GetSubKeyNames()方法

        GetSubKeyNames()方法用于检索包含所有子项名称的字符串数组。

public string[]GetSubKeyNames()
返回值:包含当前项的子项名称的字符串数组。 

        如果当前项已被删除,或是用户没有读取该项的权限,将触发异常。

// 通过GetSubKeyNames()方法检索
// HKEY_LOCAL_MACHINE\SOFTWARE子键下包含的
// 所有子项名称的字符串数组
using Microsoft.Win32;

namespace _01
{
    public partial class Form1 : Form
    {
        private RichTextBox? richTextBox1;
        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // richTextBox1
            // 
            richTextBox1 = new RichTextBox
            {
                Dock = DockStyle.Fill,
                Location = new Point(0, 0),
                Name = "richTextBox1",
                Size = new Size(284, 241),
                TabIndex = 0,
                Text = ""
            };

            RegistryKey regkey = Registry.LocalMachine;
            RegistryKey? sys = regkey.OpenSubKey(@"SOFTWARE");
            foreach (string str in sys!.GetSubKeyNames())
            {
                richTextBox1.Text += str + "\n";
            }

            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(284, 241);
            Controls.Add(richTextBox1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "Form1";           
        }
    }
}

 

(3)GetValueNames()方法

        GetValueNames()方法用于检索包含与此项关联的所有值名称的字符串数组。

public string[]GetValueNames()
返回值:包含当前项的值名称的字符串数组。  

        如果没有找到此项的值名称,则返回一个空数组;如果在注册表项设置了一个具有默认值的名称为空字符串的项,则GetValueNames()方法返回的数组中包含该空字符串。

// 读取HKEY_LOCAL_MACHINE\SOFTWARE子键下的项目信息
// 利用对象的OpenSubKey()方法打开指定的键
using Microsoft.Win32;

namespace _02
{
    public partial class Form1 : Form
    {
        private ListBox? listBox1;
        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            listBox1 = new ListBox
            {
                Dock = DockStyle.Fill,
                FormattingEnabled = true,
                ItemHeight = 12,
                Location = new Point(0, 0),
                Name = "listBox1",
                Size = new Size(294, 271),
                TabIndex = 0
            };

            listBox1.Items.Clear();
            var regkey = Registry.LocalMachine;
            RegistryKey? sys = regkey.OpenSubKey(@"SOFTWARE");
            foreach (string str in sys!.GetSubKeyNames())
            {
                listBox1.Items.Add("子项名:" + str);
                RegistryKey? sikey = sys.OpenSubKey(str);  //打开子键
                foreach (string sVName in sikey!.GetValueNames())
                {
                    listBox1.Items.Add(sVName + sikey.GetValue(sVName));
                }
            }

            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(294, 271);
            Controls.Add(listBox1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "Form1";
        }
    }
}

 

2.创建和修改注册表信息

(1)创建注册表信息

        通过RegistryKey类的CreateSubKey()方法和SetValue()方法可以创建注册表信息,下面介绍这两种方法。

  • CreateSubKey()方法

        主要用于创建一个新子项或打开一个现有子项以进行写访问。 

public RegistryKey CreateSubKey (string subkey)
☑ subkey:要创建或打开的子项的名称或路径。
☑ 返回值:RegistryKey对象,表示新建的子项或空引用。如果为subkey指定了零长度字符串,则返回当前的RegistryKey对象。
  • SetValue()方法

        主要用于设置注册表项中的名称/值对的值。

public void SetValue (string name,Object value)
☑ name:要存储的值的名称。
☑ value:要存储的数据。

        SetValue()方法用于从非托管代码中访问托管类,不应从托管代码调用。

// 通过RegistryKey类的CreateSubKey()方法和SetValue()方法创建一个子键
using Microsoft.Win32;

namespace _03
{
    public partial class Form1 : Form
    {
        private Button? button1;

        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // button1
            // 
            button1 = new Button
            {                
                Location = new Point(12, 12),
                Name = "button1",
                Size = new Size(75, 23),
                TabIndex = 0,
                Text = "创建子键",
                UseVisualStyleBackColor = true
            };
            button1.Click += new EventHandler(Button1_Click);

            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(384, 211);
            Controls.Add(button1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "创建子键";
        }
        /// <summary>
        /// 在主键HKEY_LOCAL_MACHINE的HARDWARE键下创建一个名为MR的子键,
        /// 然后在这个子键下再创建一个名为测试的子键,
        /// 在测试子键下创建一个名为value、数据值是1234的键值
        /// </summary>
        private void Button1_Click(object? sender, EventArgs e)
        {
            try
            {
                RegistryKey? hklm = Registry.LocalMachine;
                RegistryKey? software = hklm.OpenSubKey("HARDWARE", true);
                RegistryKey? main1 = software!.CreateSubKey("MR");
                RegistryKey? ddd = main1.CreateSubKey("测试");
                ddd.SetValue("value", "1234");
                MessageBox.Show("创建成功");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
}

 

(2)修改注册表信息

        由于注册表中的信息十分重要,所以一般不要对其进行写的操作。也可能是这个原因,在.Net Framework中并没有提供修改注册表键的方法。而只是提供了一个危害性相对较小的SetValue()方法,通过这个方法,可以修改键值。在使用SetValue()方法时,如果它检测到指定的键值不存在,就会创建一个新的键值。 

// 将主键HKEY_LOCAL_MACHINE\HARDWARE\MR\测试
// 下名为value的键值的数据值修改为abcd
using Microsoft.Win32;

namespace _04
{
    public partial class Form1 : Form
    {
        private Button? button1;

        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // button1
            // 
            button1 = new Button
            {
                Location = new Point(197, 12),
                Name = "button1",
                Size = new Size(75, 23),
                TabIndex = 0,
                Text = "修改",
                UseVisualStyleBackColor = true
            };
            button1.Click += new EventHandler(Button1_Click);
            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(284, 111);
            Controls.Add(button1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "Form1";
        }

        private void Button1_Click(object? sender, EventArgs e)
        {
            try
            {
                RegistryKey? hklm = Registry.LocalMachine;
                RegistryKey? software = hklm?.OpenSubKey("HARDWARE", true);
                RegistryKey? dddw = software?.OpenSubKey("MR", true);
                RegistryKey? regkey = dddw?.OpenSubKey("测试", true);
                regkey?.SetValue("value", "abcd");
                MessageBox.Show("修改成功");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
}

3.删除注册表中的信息

        删除注册表中的信息主要通过RegistryKey类中的DeleteSubKey()方法、DeleteSubKeyTree()方法和DeleteValue()方法来实现。

(1)DeleteSubKey()方法

        DeleteSubKey()方法用于删除不包含任何子键的子键。 语法如下:

publie void DeleteSubKey (string subkey,bool throwOnMissingSubKey)
☑ subkey:要删除的子项的名称。
☑ throwOnMissingSubKey:如果值为true,在程序调用时,删除的子键不存在,则产生一个错误信息;如果值为false,在程序调用时,删除的子键不存在,也不产生错误信息,程序依然正确运行。 

        如果删除的项有子级子项,将触发异常。必须将子项删除后,才能删除该项。

// 通过RegistryKey类的DeleteSubKey()方法删除
// HKEY_LOCAL_MACHINE\HARDWARE\MR键下的测试子键
using Microsoft.Win32;

namespace _05
{
    public partial class Form1 : Form
    {
        private Button? button1;
        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // button1
            // 
            button1 = new Button
            {
                Location = new Point(118, 46),
                Name = "button1",
                Size = new Size(75, 23),
                TabIndex = 0,
                Text = "删除",
                UseVisualStyleBackColor = true
            };
            button1.Click += new EventHandler(Button1_Click);
            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(331, 99);
            Controls.Add(button1);
            Name = "Form1";
            Text = "Form1";
        }

        /// <summary>
        /// 打开"SOFTWARE"子键
        /// 打开MR子键
        /// 删除名称为测试的子键
        /// </summary>
        private void Button1_Click(object? sender, EventArgs e)
        {
            try
            {
                RegistryKey? hklm = Registry.LocalMachine;
                RegistryKey? software = hklm?.OpenSubKey("HARDWARE", true);
                RegistryKey? no1 = software?.OpenSubKey("MR", true);
                no1?.DeleteSubKey("测试", false);
                MessageBox.Show("删除成功");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
}

(2)DeleteSubKeyTree方法

        DeleteSubKeyTree()方法用于彻底删除指定的子键目录,包括删除该子键以及该子键以下的全部子键。由于此方法的破坏性非常强,所以在使用时要特别谨慎。语法如下:

public void DeleteSubKeyTree(sting subkey)
subkey:要彻底删除的子键名称。 

        当删除的项为null时,则触发异常。

// 通过DeleteSubKeyTree()方法将彻底删除
// HKEY_LOCAL_MACHINE\HARDWARE\MR键下的子键
using Microsoft.Win32;

namespace _06
{
    public partial class Form1 : Form
    {
        private Button? button1;
        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // button1
            // 
            button1 = new Button
            {
                Location = new Point(151, 12),
                Name = "button1",
                Size = new Size(121, 23),
                TabIndex = 0,
                Text = "彻底删除子键",
                UseVisualStyleBackColor = true
            };
            button1.Click += new EventHandler(Button1_Click);
            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(284, 111);
            Controls.Add(button1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "Form1";
        }
        /// <summary>
        /// 打开"SOFTWARE"子键
        /// 打开MR子键
        /// 删除名称为测试的子键
        /// </summary>
        private void Button1_Click(object? sender, EventArgs e)
        {
            try
            {
                RegistryKey? hklm = Registry.LocalMachine;
                //hklm.DeleteSubKey("aaa", false);
                RegistryKey? software = hklm.OpenSubKey("HARDWARE", true);
                RegistryKey? no1 = software?.OpenSubKey("MR", true);
                no1!.DeleteSubKeyTree("测试");
                MessageBox.Show("删除成功");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
}

(3)DeleteValue()方法 

        DeleteValue()方法主要用于删除指定的键值。语法如下:

publie void DeleteValue(string name)
name:要删除的值的名称。
如果在找不到指定值的情况下使用该值,又不想引发异常,可以使用DeleteValue(string name,bool throwOnMissingValue)重载方法。如果throwOnMissingValue参数为true时,将不引发异常。
// 通过DeleteValue方法删除
// HKEY_LOCAL_MACHINE\HARDWARE\MR\测试键下的名称为value的键值
using Microsoft.Win32;

namespace _07
{
    public partial class Form1 : Form
    {
        private Button? button1;
        public Form1()
        {
            InitializeComponent();
            Load += new EventHandler(Form1_Load);
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // button1
            // 
            button1 = new Button
            {
                Location = new Point(132, 12),
                Name = "button1",
                Size = new Size(75, 23),
                TabIndex = 0,
                Text = "删除键值",
                UseVisualStyleBackColor = true
            };
            button1.Click += new EventHandler(Button1_Click);
            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(6F, 12F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(219, 196);
            Controls.Add(button1);
            Name = "Form1";
            StartPosition = FormStartPosition.CenterScreen;
            Text = "Form1";
        }

        /// <summary>
        /// 打开"SOFTWARE"子键
        /// 打开MR子键,打开测试子键
        /// 删除名称为"value"的键值
        /// </summary>
        private void Button1_Click(object? sender, EventArgs e)
        {
            try
            {
                RegistryKey? hklm = Registry.LocalMachine;
                RegistryKey? software = hklm?.OpenSubKey("HARDWARE", true);
                RegistryKey? no1 = software?.OpenSubKey("MR", true);
                RegistryKey? no2 = no1?.OpenSubKey("测试", true);
                no2?.DeleteValue("value");
                MessageBox.Show("删除键值成功");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }    
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2-Spring

2-Spring 文章目录 2-Spring项目源码地址Spring概述Spring特点&#xff08;优点&#xff09;Spring相关学习网站基于Maven的Spring框架导入Spring的组成及拓展 Spring-IOC--原型理解IOC-原型--示例开发示例-常规开发示例-Set函数&#xff08;IOC原型&#xff09;开发示例-对比思…

Python-pdf工具自制(合并、拆分、删除)

pdf工具&#xff0c;之前写的合并工具有点麻烦&#xff0c;使用PyQt5库重写合并拆分和删除指定页面的程序 实现如图&#xff1a; 代码&#xff1a; import sysimport osfrom PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton, QVBoxLayout, QWidget, QFileDia…

新版Android Studio 正则表达式匹配代码注释,删除注释,删除全部注释,IntelliJ IDEA 正则表达式匹配代码注释

正则表达式匹配代码注释 完整表达式拼接Android Studio 搜索匹配【IntelliJ IDEA 也是一样的】 完整表达式拼接 (/*{1,2}[\s\S]?*/)|(//[\x{4e00}-\x{9fa5}].)|(<!-[\s\S]?–>)|(^\s\n)|(System.out.println.*) 表达式拆解&#xff0c;可以根据自己需求自由组合&#x…

【Dubbo3云原生微服务开发实战】「Dubbo前奏导学」 RPC服务的底层原理和实现

RPC服务 RPC服务介绍RPC通信模式RPC架构组成RPC技术要点RPC通信技术选项分析RPC实战开发6大基础组件基础组件之Guava基础组件之Hutools基础组件之ReflectionASM基础组件之FastJSON/FastJSON2基础组件之FST相比FastJSON的优势 基础组件之Commons-Codec RPC框架层面选项分析RPC组…

Cocos Creator:创建棋盘

Cocos Creator&#xff1a;创建棋盘 创建地图三部曲&#xff1a;1. 创建layout组件2. 创建预制体Prefab&#xff0c;做好精灵贴图&#xff1a;3. 创建脚本LayoutSprite.ts收尾工作&#xff1a; 创建地图三部曲&#xff1a; 1. 创建layout组件 使用layout进行布局&#xff0c;…

sensitive word 敏感词(脏词) 如何忽略无意义的字符?达到更好的过滤效果?

忽略字符 说明 我们的敏感词一般都是比较连续的&#xff0c;比如 傻帽 那就有大聪明发现&#xff0c;可以在中间加一些字符&#xff0c;比如【傻!#$帽】跳过检测&#xff0c;但是骂人等攻击力不减。 那么&#xff0c;如何应对这些类似的场景呢&#xff1f; 我们可以指定特…

【论文精读】REACT: SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS

REACT: SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS 前言ABSTRACT1 INTRODUCTION2 REACT: SYNERGIZING REASONING ACTING3 KNOWLEDGE-INTENSIVE REASONING TASKS3.1 SETUP3.2 METHODS3.3 RESULTS AND OBSERVATIONS 4 DECISION MAKING TASKS5 RELATED WORK6 CONCLUSI…

Ubuntu20.04使用cephadm部署ceph集群

文章目录 Requirements环境安装Cephadm部署Ceph单机集群引导&#xff08;bootstrap&#xff09;建立新集群 管理OSD列出可用的OSD设备部署OSD删除OSD 管理主机列出主机信息添加主机到集群从集群中删除主机 部署Ceph集群 Cephadm通过在单个主机上创建一个Ceph单机集群&#xff0…

★102. 二叉树的层序遍历

102. 二叉树的层序遍历 很巧妙的&#xff0c;又学习了一种层次遍历的方法&#xff0c;就是说根据当前的队列的长度去遍历&#xff0c;遍历的当前队列的长度就是该层次的节点个数。 /*** Definition for a binary tree node.* public class TreeNode {* int val;* Tr…

Flink 本地单机/Standalone集群/YARN模式集群搭建

准备工作 本文简述Flink在Linux中安装步骤&#xff0c;和示例程序的运行。需要安装JDK1.8及以上版本。 下载地址&#xff1a;下载Flink的二进制包 点进去后&#xff0c;选择如下链接&#xff1a; 解压flink-1.10.1-bin-scala_2.12.tgz&#xff0c;我这里解压到soft目录 [ro…

UniGui禁用缓存

今天有人问到如何禁用缓存&#xff0c;原因是引用了第三方js,css等文件&#xff0c;但是因为缓存的原因&#xff0c;修改后没有及时生效。 首先纠正一点&#xff0c;地址后加?不会禁用缓存 可以看到&#xff0c;后面即使加了&#xff1f;但仍然是from memory cache。对于浏览…

管理类联考——数学——真题篇——按知识分类——数据

文章目录 排列组合2023真题&#xff08;2023-05&#xff09;-数据分析-排列组合-组合-C运算-至少-需反面思考真题&#xff08;2023-08&#xff09;-数据分析-排列组合-相邻不相邻-捆绑法插空法-插空法注意空位比座位多1个&#xff0c;是用A&#xff1b;捆绑法内部排序用A&#…

ubuntu 20.04.6 server 服务器 下载与安装(配置静态IP)

下载地址&#xff1a;https://releases.ubuntu.com/20.04.6/ubuntu-20.04.6-live-server-amd64.iso 第一步&#xff1a; 准备U盘&#xff0c;使用软碟通将下载好的镜像写入到U盘中 软碟通网址&#xff1a;https://www.cn.ultraiso.net/xiazai.html 点击&#xff1a;文件 ->…

iOS——UIPickerView选择器

UIPickerView UIPickerView是 iOS 开发中常用的用户界面组件之一&#xff0c;用于在垂直方向上显示一个滚动的列表&#xff0c;用户可以通过滚动选择其中的一项。 UIPickerView的协议方法 UIPickerView和UItableView差不多&#xff0c;UIPickerView也要设置代理和数据源。UI…

JAVA+SSM+springboot+MYSQL企业物资库存进销存管理系统

。该系统从两个对象&#xff1a;由管理员和员工来对系统进行设计构建。主要功能包括首页、个人中心、员工管理、项目信息管理、仓库信息管理、供应商管理、项目计划管理、物资库存管理、到货登记管理、物资出库管理、物资入库管理等功能进行管理。本企业物资管理系统方便员工快…

Jenkins简单介绍

学习目标 知道jenkins应用场景能够安装部署jenkins服务器能够实现gitgithubjenkins手动构建能够实现gitgitlabjenkins自动发布系统 认识jenkins Jenkins是一个可扩展的持续集成引擎&#xff0c;是一个开源软件项目&#xff0c;旨在提供一个开放易用的软件平台&#xff0c;使软…

【SpringBoot】请求参数

1. BS 架构 BS架构&#xff1a;Browser/Server&#xff0c;浏览器/服务器架构模式。客户端只需要浏览器&#xff0c;应用程序的逻辑和数据都存储在服务端。 在SpringBoot进行web程序开发时&#xff0c;它内置了一个核心的Servlet程序 DispatcherServlet&#xff0c;称之为 核…

ARP欺骗攻击

一.大概原理 ARP&#xff1a;address solution protocol 地址解析协议 ARP是一种基于局域网的TCP/IP协议&#xff0c;arp欺骗就是基于此协议的漏洞来达成我们的目的的&#xff0c;局域网中的数据传输并不是用ip地址传输的&#xff0c;而是靠mac地址。 我们如果出于某种目的想…

HTML中表格的语法及使用(详解)

Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍HTML中表格的语法及详细使用以及部分理论知识 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主收将持续更新学习记录获&#xff0c;友友们有任何问题可以在评论区留…

学校安全检查系统

校园面积大、安全盲区多对学校安全管理带来诸多挑战&#xff1b;传统依靠人工纸质巡检记录存在漏检、管理难、联动差等诸多问题和缺点&#xff0c;巡检过程中很容易遗漏安全隐患的存续&#xff0c;从而导致安全事故的发生。 通过凡尔码平台模块化搭建学校安全管理系统&#xf…
最新文章