龙芯3A6000_统信UOS_麒麟KYLINOS上创建密钥对加解密文件

2024-02-03 16:12

本文主要是介绍龙芯3A6000_统信UOS_麒麟KYLINOS上创建密钥对加解密文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文链接:龙芯3A6000|统信UOS/麒麟KYLINOS上创建密钥对加解密文件
大家好!在当今数字化时代,数据安全变得越来越重要。为了帮助大家更好地保护自己的数据,今天我为大家带来一篇关于在统信UOS和麒麟KYLINOS操作系统上创建和使用密钥对的实用指南。
密钥对,包括一个公钥和一个私钥,是确保数据安全传输和验证的重要工具。通过本文,您将学会如何在这两个操作系统中创建密钥对,并学习如何使用它们进行数据签名、验证和加密。
文章分为两个部分:

  1. 创建密钥对和数据签名 - 在文章的前半部分,我们将指导您如何创建一个密钥对,并使用私钥对一个文本文件(例如test.txt)进行两种不同方式的签名。接着,我们会展示如何进行签名验证,确保数据的完整性和来源的可靠性。
  2. 使用密钥对进行数据加密和解密 - 文章的后半部分将介绍一个具体的应用场景。我们将在主机A上创建密钥对,使用公钥对test.txt文件进行加密,然后将私钥导入到主机B上。在主机B上,我们将使用私钥对加密的test.txt文件进行解密,展示密钥对在数据安全中的实际应用。

1.查看系统信息

pdsyw@uos-PC:~/Desktop$ cat /etc/os-version 
pdsyw@uos-PC:~/Desktop$ uname -a

image.png

2.查看CPU信息

pdsyw@uos-PC:~/Desktop$ lscpu

image.png

  1. 更新源
pdsyw@pdsyw-PC:~/Desktop$ sudo apt-get update

image.png

4.安装gnupg

pdsyw@pdsyw-PC:~/Desktop$ sudo apt-get install gnupg

image.png

5.生成新的密钥对

pdsyw@pdsyw-PC:~/Desktop$ gpg --full-generate-key

image.png
image.png
image.png
image.png

6.创建test.txt文件

pdsyw@pdsyw-PC:~/Desktop$ vim test.txt
pdsyw@pdsyw-PC:~/Desktop$ cat test.txt

image.png

7.1.使用私钥对test.txt文件进行签名

pdsyw@pdsyw-PC:~/Desktop$ gpg --local-user pdsyw@pdsyw.cn --detach-sign test.txt

image.png

7.2.查看签名文件

pdsyw@pdsyw-PC:~/Desktop$ ls -ltr | grep test.txt
pdsyw@pdsyw-PC:~/Desktop$ cat test.txt.sig 

image.png

7.3.也可以创建一个同时包含原始内容和签名的文件

pdsyw@pdsyw-PC:~/Desktop$ gpg --local-user pdsyw@pdsyw.cn --clearsign test.txt
pdsyw@pdsyw-PC:~/Desktop$ ls -ltr | grep test.txt
pdsyw@pdsyw-PC:~/Desktop$ cat test.txt.asc 

image.png

8.1.验证签名的有效性

pdsyw@pdsyw-PC:~/Desktop$ gpg --verify test.txt.sig test.txt

image.png

8.2.验证包含签名文件的有效性

pdsyw@pdsyw-PC:~/Desktop$ gpg --verify test.txt.asc

image.png

9.使用公钥对文件进行加密

pdsyw@pdsyw-PC:~/Desktop$ gpg --encrypt --recipient 'pdsyw@pdsyw.cn' test.txt
pdsyw@pdsyw-PC:~/Desktop$ ls -ltr | grep test.txt
pdsyw@pdsyw-PC:~/Desktop$ cat test.txt.gpg 

image.png

10.列出所有的私钥

pdsyw@pdsyw-PC:~/Desktop$ gpg --list-secret-keys

image.png

11.导出私钥
image.png

pdsyw@pdsyw-PC:~/Desktop$ gpg --export-secret-keys -a pdsyw@pdsyw.cn > myprivatekey.asc
pdsyw@pdsyw-PC:~/Desktop$ ls -ltr myprivatekey.asc 

image.png

12.在另一台主机上导入私钥

pdsyw@pdsyw-PC:~/Desktop$ gpg --import myprivatekey.asc 

image.png

pdsyw@pdsyw-PC:~/Desktop$ gpg --import myprivatekey.asc 
pdsyw@pdsyw-PC:~/Desktop$ gpg --list-keys

image.png

13.使用私钥解密文件

pdsyw@pdsyw-PC:~/Desktop$ gpg --output test_decrypted --decrypt test.txt.gpg 
gpg: 由 3072 位的 RSA 密钥加密,标识为 BAB8A2CA04DF0F2A,生成于 2024-01-30“pdsyw (鹏大圣运维) <pdsyw@pdsyw.cn>”
pdsyw@pdsyw-PC:~/Desktop$ 
pdsyw@pdsyw-PC:~/Desktop$ cat test_decrypted 

image.png

通过本文的学习,您不仅能够掌握密钥对的创建和基本用法,还能了解到它们在实际应用中的重要性和便利性。无论是个人用户还是企业管理员,都能从中受益。
请大家不要忘记分享和转发这篇文章,点击关注我们的公众号,并点赞“在看”。我们将继续为您提供更多关于统信UOS和麒麟KYLINOS的安全操作和技巧教程。
非常感谢大家的阅读,期待在评论区看到您的反馈和交流!

这篇关于龙芯3A6000_统信UOS_麒麟KYLINOS上创建密钥对加解密文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/674695

相关文章

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

PHP7扩展开发之类的创建

本篇文章主要将如何在扩展中创建一个对象。创建的对象的过程,其实和一个小孩出生,成长的过程有些类似。 第一步,办准生证 生孩子第一步,先办准生证。声明我要生孩子了。对象创建的时候,如何办准生证呢?只要定义一个zend_class_entry变量即可。代码如下: zend_class_entry ce; zend_class_entry 是啥?可以认为它使一个原型,定义了一些对象应该有哪些东西

创建表时添加约束

查询表中的约束信息: SHOW KEYS FROM 表名; 示例: 创建depts表包含department_id该列为主键自动增长,department_name列不允许重复,location_id列不允许有空值。 create table depts(department_id int primary key auto_increment,department_name varcha

UML- 统一建模语言(Unified Modeling Language)创建项目的序列图及类图

陈科肇 ============= 1.主要模型 在UML系统开发中有三个主要的模型: 功能模型:从用户的角度展示系统的功能,包括用例图。 对象模型:采用对象、属性、操作、关联等概念展示系统的结构和基础,包括类图、对象图、包图。 动态模型:展现系统的内部行为。 包括序列图、活动图、状态图。 因为要创建个人空间项目并不是一个很大的项目,我这里只须关注两种图的创建就可以了,而在开始创建UML图