简单聊聊加密和加签的关系与区别

news2024/11/15 4:25:51

大家好,我是G探险者。

平时我们在项目上一定都听过加密和加签,加密可能都好理解,知道它是保障的数据的机密性,那加签是为了保障啥勒?它和加密有啥区别?

带着这个疑问,我们就来聊聊二者的区别。

加密(Encryption)和加签名(Signing)这两种技术在确保数据安全和完整性方面发挥着关键作用。虽然这两种技术常被提及,但它们各自的功能和应用却有着明显的差异。

1.加密:保护数据内容的机密性

加密是一种通过将数据转换成不可读形式的方法,以防止未授权的访问。这一过程涉及使用密钥(Key)将原始数据(明文)转换为加密后的数据(密文)。

  • 目的: 保护数据的机密性,确保只有授权的接收方能够阅读数据内容。
  • 常用算法: RSA、ECC(Elliptic Curve Cryptography)等。
  • 特点: 非对称加密通常用于加密小量数据,如加密其他密钥或密钥交换,因为它相比对称加密来说计算量更大。

加密分为两类:

对称加密: 使用相同的密钥进行数据的加密和解密。例如,AES(Advanced Encryption Standard)是一种常用的对称加密算法。

非对称加密: 使用一对密钥,其中公钥用于加密,私钥用于解密。RSA(Rivest-Shamir-Adleman)算法是非对称加密的典型例子。

2. 加签名:验证数据来源和完整性

加签名是一种用来验证数字信息完整性和来源真实性的技术。通过使用私钥生成签名,然后使用相应的公钥进行验证。这个过程确保了数据在传输过程中没有被篡改,并且证实了数据来源的合法性。

  • 目的: 验证数据的完整性和来源的真实性,确保数据在传输过程中未被篡改,并验证发送方的身份。
  • 密钥使用: 签名是使用发送方的私钥生成的,任何人都可以使用发送方的公钥来验证签名,但只有发送方才能生成这个签名。
  • 常用算法: RSA、DSA(Digital Signature Algorithm)、ECDSA(Elliptic Curve Digital Signature Algorithm)等。
  • 特点: 加签名不对数据本身进行加密,而是生成一个小的、基于原始数据的数字指纹(通常通过哈希函数产生)。

3. 加密与加签名的关系和区别

虽然加密和加签名在保护信息安全方面共同作用,但它们的目的和应用有着本质的不同。

特性/操作加密 (Encryption)加签名 (Signing)
目的保护数据的机密性。验证数据的完整性和来源的真实性。
工作方式对称加密使用同一密钥进行加解密,非对称加密使用公钥加密和私钥解密。使用私钥生成签名,使用公钥验证签名。
密钥使用对称加密中同一密钥用于加密和解密;非对称加密中使用一对密钥,公钥加密,私钥解密。私钥用于生成签名,公钥用于验证签名。
数据可见性加密后的数据不可读,只有拥有密钥的人能解密查看原始数据。签名不影响数据的可读性,任何人都可以读取数据,但只有签名者才能生成有效签名。
安全目标防止未授权访问和阅读数据内容。确保数据未被篡改,并验证数据来源的真实性。
应用场景保护数据传输过程中的隐私(如加密邮件、文件、网络数据等)。确认数据的合法来源和完整性(如软件更新验证、文档签名、身份认证等)。
典型使用敏感数据的存储和传输,如个人信息、商业秘密等。软件分发、电子商务交易、数字合同等场景,确保数据和交易的安全性。

4. 小结

  • 加密 侧重于保护数据内容的机密性,使得数据内容仅对授权用户可见。
    公钥加密,私钥解密:在非对称加密中,发送方使用接收方的公钥对数据进行加密,只有拥有对应私钥的接收方能够解密。这确保了只有特定的接收者能够访问加密数据。

  • 加签名则侧重于验证数据的完整性和来源的真实性,确保数据未被篡改且来源可靠。
    私钥加签,公钥验签:在数字签名的过程中,发送方使用自己的私钥对数据(或其哈希值)进行加签。任何人都可以使用发送方的公钥来验证签名,以确认数据的完整性和发送方的身份。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Python】Fastapi swagger-ui.css 、swagger-ui-bundle.js 无法加载,docs无法加载,redocs无法使用

使用fastapi的时候,swagger-ui.css 、swagger-ui-bundle.js、redoc.standalone.js 有时候无法加载(国内环境原因或者是局域网屏蔽),此时就需要自己用魔法下载好对应文件,然后替换到fastapi里面去。 fastapi里面依靠这…

redis运维(十九)redis 的扩展应用 lua(一)

一 redis 的扩展应用 lua redis如何保证原子操作 说明:引入lua脚本,核心解决原子性问题 ① redis为什么引入lua? lua脚本本身体积小,启动速度快 ② redis引入lua的优势 小结: 类似自定义redis命令 ③ redis中如何使用lua ④ EVAL 说明&#…

《算法通关村——数论问题解析》

《算法通关村——数论问题解析》 辗转相除法 辗转相除法又叫做欧几里得算法,是公元前 300 年左右的希腊数学家欧几里得在他的著作《几何原本》提出的。最大公约数(greatest common divisor,简写为gcd),是指几个数的共有的因数之中最大的一个…

csv文件添加文件内容和读取

append content to file import numpy as np acc_listnp.array([0.97,0.92,0.93,0.89]) # 注意这个地方添加文件不需要特别声明是什么文件 file open("result.csv", "a") print("{:.2f}, {:.2f}".format(acc_list.mean(), acc_list.std()), f…

leetcode刷题日志-167.两数之和II-输入有序数组

给你一个下标从 1 开始的整数数组 numbers &#xff0c;该数组已按 非递减顺序排列 &#xff0c;请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] &#xff0c;则 1 < index1 < index2 < numbers.…

浏览器没收到返回,后端也没报错,php的json_encode问题bug

今天网站遇到个问题&#xff0c;后端返回异常&#xff0c;但是浏览器状态码200&#xff0c;但是看不到结果。经过排查发现&#xff0c;我们在返回结果的时候使用了json_encode返回给前端&#xff0c;结果里面的字符编码异常&#xff0c;导致json_encode异常&#xff0c;但是php…

ComfyUI搭建使用教程

ComfyUI 是一个基于节点流程式的stable diffusion AI 绘图工具WebUI&#xff0c; 你可以把它想象成集成了stable diffusion功能的substance designer&#xff0c; 通过将stable diffusion的流程拆分成节点&#xff0c;实现了更加精准的工作流定制和完善的可复现性。但节点式的工…

系列二、Spring整合单元测试

一、概述 Spring中获取bean最常见的方式是通过ClassPathXmlApplicationContext 或者 AnnotationConfigApplicationContext的getBean()方式获取bean&#xff0c;那么在Spring中如何像在SpringBoot中直接一个类上添加个SpringBootTest注解&#xff0c;即可在类中注入自己想要测试…

pytest-pytest-html测试报告这样做,学完能涨薪3k

在 pytest 中提供了生成html格式测试报告的插件 pytest-html 安装 安装命令如下&#xff1a; pip install pytest-html使用 我们已经知道执行用例的两种方式&#xff0c;pytest.main()执行和命令行执行&#xff0c;而要使用pytest-html生成报告&#xff0c;只需要在执行时加…

飞翔的小鸟小游戏

主类 package APP;import 框架.GameFrame;public class GameApp {public static void main(String[] args) {//游戏的入口new GameFrame();} }场景实物 package 框架;import 图导.Constant; import 图导.GameUtil;import java.awt.*; import java.awt.image.BufferedImage; …

VR模拟仿真技术为司法科普建设注入更多的智慧和力量

虚拟现实(VR)技术已经逐渐渗透到各个领域&#xff0c;包括司法领域&#xff0c;在法学院教学中&#xff0c;VR虚拟现实和web3d开发技术的兴起&#xff0c;让司法教育也突破传统教授式、演练式的教学模式&#xff0c;通过VR特有的沉浸式展示特点&#xff0c;实现了真实法庭效果的…

飞书如何接入ChatGPT-打造个人智能问答助手实现无障碍交流

目录 前言 环境列表 1.飞书设置 2.克隆feishu-chatgpt项目 3.配置config.yaml文件 4.运行feishu-chatgpt项目 5.安装cpolar内网穿透 6.固定公网地址 7.机器人权限配置 8.创建版本 9.创建测试企业 10. 机器人测试 总结 前言 在飞书中创建chatGPT机器人并且对话&am…

目标检测算法 - YOLOv4

文章目录 1. 简介2. YOLOv4整体结构3. Backbone4. Neck 1. 简介 YOLOv4是YOLOv3的改进版。YOLOv4并不是原YOLO项目的作者。发表于CVPR2020。 改进&#xff1a; 主干特征提取网络&#xff1a;Darknet53 -> CSPDarknet53特征金字塔&#xff1a;SPP&#xff0c;PAN分类回归层…

TikTok shop印尼重启电商征程:与当地平台合作开启新篇章!——站斧浏览器

经历了一个半月的间隔&#xff0c;TikTok Shop成功重返印度尼西亚市场。据国际媒体报道&#xff0c;TikTok计划通过与印尼本地电子商务平台的合作&#xff0c;重启其在该国的电商业务。 Temmy Satya Permana&#xff0c;印尼合作社和中小企业部的官员&#xff0c;证实了这一重…

【LeetCode刷题】--59.螺旋矩阵II

59.螺旋矩阵II class Solution {public int[][] generateMatrix(int n) {int[][] res new int[n][n];int count 1;int left 0,right n-1,top 0,bottom n -1;while(left < right && top < bottom){for(int col left;col < right;col){ //从左往右res[to…

[MySQL] MySQL 表的增删查改

本篇文章对mysql表的增删查改进行了详细的举例说明解释。对表的增删查改简称CRUD : Create(创建), Retrieve(读取)&#xff0c;Update(更新)&#xff0c;Delete&#xff08;删除&#xff09;。其中重点是对查询select语句进行了详细解释&#xff0c;并且通过多个实际例子来帮助…

leetcode刷题之用栈实现队列(C语言版)

leetcode刷题之用栈实现队列&#xff08;C语言版&#xff09; 一、题目描述二、题目要求三、题目解析Ⅰ、typedef structⅡ、MyQueue* myQueueCreateⅢ、void myQueuePush(MyQueue* obj, int x)Ⅳ、int myQueuePeek(MyQueue* obj)Ⅴ、int myQueuePop(MyQueue* obj)Ⅶ、bool myQ…

Charles 网络抓包工具详解与实战指南

文章目录 导读软件版本Charles基本原理核心功能下载及安装界面介绍网络包展示 常用场景介绍PC 端网络抓包移动端网络抓包PC 端配置手机端配置 开启 SSL 代理PC 端和移动端 CA 证书安装Charles 直接安装Charles 下载 CA 文件手动安装 常用操作请求重发请求改写、动态改写断点&am…

C# Winform使用log4net记录日志

写在前面 Log4Net是从Java的log4j移植过来的&#xff0c;功能也与log4j类似&#xff0c;可以把日志信息输出到文件、数据库、控制台、Windows 事件日志、远程系统日志服务等不同的介质或目标。 Log4Net配置选项丰富灵活&#xff0c;并且可在运行时动态更新配置并应用&#xf…

Sui第七轮资助:八个项目共获得超过50万美元的资助

今日&#xff0c;Sui基金会宣布了本月获得资助的项目方&#xff0c;他们将获得超过50万美元的资助金&#xff0c;用于构建项目&#xff0c;推动Sui的采用和发展。要获得资助&#xff0c;项目必须提交提案&#xff0c;详细说明他们正在构建的内容、预算明细、关键里程碑、团队经…