加密与安全_探索数字证书

文章目录

  • Pre
  • 概述
  • 使用keytool生成证书
  • 使用Openssl生成证书 (推荐)
  • 证书的吊销
  • 小结

在这里插入图片描述


Pre

PKI - 借助Nginx 实现Https 服务端单向认证、服务端客户端双向认证

PKI - 04 证书授权颁发机构(CA) & 数字证书

PKI - 数字签名与数字证书


概述

数字证书是一种重要的安全标准,它集成了多种密码学算法,以确保数据的安全性、完整性和可信度。在数字化信息传输中,

  • 摘要算法用于验证数据的完整性
  • 非对称加密算法用于加密和解密数据
  • 签名算法则用于验证数据的来源和确保抗否认性

将这些算法集合到一起,并依据一套完善的标准来管理,形成了数字证书的体系。

通过数字证书,用户可以实现数据加解密、身份认证和签名等多种功能。其中,最重要的作用之一是防止中间人攻击。这是通过采用链式签名认证来实现的。具体而言,数字证书的签发是通过根证书(Root CA)对下一级证书进行签名,依此类推,直到最终用户证书。由于根证书被内置于操作系统中,因此任何经过CA认证的数字证书都可以对其本身进行校验,从而确保证书的真实性和可信度,防止了伪造和篡改的可能性。

总的来说,数字证书不仅集成了多种密码学算法,实现了数据的安全传输和存储,还通过签名认证机制,确保了数字身份的真实性和完整性,有效地防范了网络攻击和信息泄露的风险。


使用keytool生成证书

keytool -storepass 123456 -genkeypair -keyalg RSA -keysize 1024 -sigalg SHA256withRSA -validity 3650 -alias mycert -keystore my.keystore -dname "CN=www.artisan.com, OU=sample, O=sample, L=BJ, ST=BJ, C=CN"

在这里插入图片描述

  • -storepass 123456: 指定密钥库的密码。密码为123456
  • -genkeypair: 生成密钥对,包括一个公钥和一个私钥。
  • -keyalg RSA: 指定生成密钥对时要使用的算法。使用RSA算法。
  • -keysize 1024: 指定生成的密钥的大小(以位为单位)。密钥的大小为1024位。
  • -sigalg SHA256withRSA: 指定用于签名密钥的算法和哈希算法。使用SHA256withRSA作为签名算法。
  • -validity 3650: 指定生成的证书的有效期限。证书有效期为3650天(大约10年)。
  • -alias mycert: 指定生成的密钥对的别名。别名为mycert
  • -keystore my.keystore: 指定生成的密钥对和证书存储在的密钥库文件的路径。密钥库文件为my.keystore
  • -dname "CN=www.artisan.com, OU=sample, O=sample, L=BJ, ST=BJ, C=CN": 指定用于生成证书的主题信息,包括通用名称(CN)、组织单位(OU)、组织(O)、城市(L)、省/州(ST)和国家(C)。主题信息为CN=www.sample.com, OU=sample, O=sample, L=BJ, ST=BJ, C=CN,表示通用名称为www.sample.com,组织单位为sample,组织为sample,城市为北京,省/州为北京,国家为中国。

执行上述命令,JDK会在当前目录创建一个my.keystore文件,并存储创建成功的一个私钥和一个证书,它的别名是mycert。
在这里插入图片描述

密钥库(key store)存储的数字证书可以用于加密、解密和签名等操作。

  1. 加密与解密:数字证书通常用于公钥加密和解密。发送方可以使用接收方的公钥加密数据,而接收方使用其相应的私钥来解密数据。这种方式确保了数据在传输过程中的安全性。

  2. 签名:数字证书也常用于数字签名。发送方使用自己的私钥对消息进行签名,接收方使用发送方的公钥验证签名。这种方式可以确保消息的完整性和真实性,同时也可以验证消息的发送者身份。

  3. 身份验证:数字证书还可用于身份验证。例如,在SSL/TLS握手过程中,服务器会将其数字证书发送给客户端,客户端可以验证服务器的身份,并使用服务器的公钥加密通信数据,以确保通信的安全性。

通过以上方法,数字证书在加密通信、数据完整性验证和身份认证等方面都发挥着重要作用,是安全通信的基础之一。


使用Openssl生成证书 (推荐)

请参考我的另外一篇博文: PKI - 数字签名与数字证书


证书的吊销

证书的吊销是指证书颁发机构(CA)在证书的有效期内,因某种原因取消了对该证书的信任。吊销证书是确保网络安全的重要步骤,因为它可以阻止使用已被证明不再可信的证书进行通信。以下是有关证书吊销的介绍:

  1. 原因

    • 私钥丢失或泄露:如果证书的私钥丢失或泄露,攻击者可能会使用它进行恶意行为,因此需要吊销证书。
    • 证书信息错误:如果证书中的信息(如主题名称、组织信息等)不正确,可能会导致信任问题,需要吊销证书。
    • 证书持有者不再信任:如果证书持有者不再被信任,可能会因其不当行为或其他原因而需要吊销证书。
    • 证书过期或无效:如果证书的有效期已过或由于其他原因导致证书无效,可能需要吊销证书。
  2. 吊销方法

    • 证书吊销列表 (CRL):CA 可以维护一个 CRL,列出所有已被吊销的证书。客户端可以定期检查此列表以确认证书的状态。
    • 在线证书状态协议 (OCSP):OCSP 允许客户端向 CA 查询证书的状态,以确定证书是否已被吊销。
    • CA 签发的 OCSP 响应:CA 可以提供签名的 OCSP 响应,证明特定证书的状态,而无需访问 CRL。
  3. 影响

    • 安全性提升:吊销证书可以防止使用失效或不可信的证书进行恶意活动,提升网络通信的安全性。
    • 信任维护:保持证书的有效性和可信任性有助于维护网络通信的信任关系。
    • 合规性要求:某些行业标准和法规要求及时吊销不再有效的证书,以符合合规性要求。

证书吊销是保障网络安全的重要机制之一,CA 和网络管理员应定期检查和管理吊销证书,以确保网络通信的安全性和可信任性。


小结

数字证书是一种用于在互联网上验证身份和加密通信的安全工具。以下是数字证书的总结:

  1. 定义

    • 数字证书是一种由权威机构颁发的电子文档,用于证明某个实体的身份信息,例如网站、个人或组织。
  2. 组成

    • 公钥:用于加密通信的密钥,可由任何人访问。
    • 私钥:用于解密通信的密钥,仅由证书持有者拥有。
    • 证书持有者信息:通常包括姓名、电子邮件地址等个人或组织信息。
    • 数字签名:由证书颁发者用其私钥加密的信息,用于验证证书的真实性和完整性。
  3. 作用

    • 身份验证:通过验证证书中的信息,可以确认通信方的身份。
    • 加密通信:使用证书中的公钥进行加密,确保通信的机密性。
    • 完整性保护:使用数字签名验证证书的完整性,防止篡改或伪造。
  4. 颁发机构

    • 数字证书由权威的证书颁发机构(CA)签发,例如VeriSign、DigiCert等。
  5. 类型

    • SSL/TLS 证书:用于网站加密通信,确保数据传输的安全性。
    • 代码签名证书:用于数字签名软件或应用程序,确保其来源可信。
    • 电子邮件证书:用于加密和签名电子邮件,保护邮件的安全性和隐私。
  6. 过期与更新

    • 数字证书有一定的有效期限,通常为数年。
    • 过期的证书需要更新,以确保持续的安全性和有效性。

数字证书在互联网通信中扮演着至关重要的角色,为用户提供了安全可靠的通信保障。

在这里插入图片描述

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

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

相关文章

java面试题(spring框架篇)(黑马 )

树形图: 一、Spring框架种的单例bean是线程安全吗? Service Scope("singleton") public class UserServiceImpl implements UserService{ } singleton:bean在每个Spring IOC容器中只有一个实例 protype:一个bean的定义可以有多个…

CPU iowait是什么意思

在linux系统,使用top命令时,可以看到cpu使用统计情况,有时我们会注意到iowait这一项非常高。我们直到,在cpu运行进程、线程时,遇到IO操作,因为IO读写通常比较慢,CPU通常可以阻塞线程&#xff0c…

【Web安全靶场】xss-labs-master 1-20

xss-labs-master 其他靶场见专栏 文章目录 xss-labs-masterlevel-1level-2level-3level-4level-5level-6level-7level-8level-9level-10level-11level-12level-13level-14level-15level-16level-17level-18level-19level-20 level-1 第一关没有进行任何限制,get请求…

pytorch_神经网络构建6

文章目录 强化学习概念实现qLearning基于这个思路,那么解决这个问题的代码如下 强化学习概念 强化学习有一个非常直观的表现,就是从出发点到目标之间存在着一个连续的状态转换,比如说从状态一到状态456,而每一个状态都有多种的行为&#xff…

全国青少年软件编程(Python)等级考试试卷(一级) 测试卷2021年12月

第 1 题 【 单选题 】 下面程序的运行结果是什么?( ) a10 b5 ca*b print(c) A :10 B :15 C :50 D :5 正确答案:C 试题解析: 第 2 题 【 单选题 】 与a>b and b>c等价的是?( ) A…

设计模式学习笔记 - 设计原则 - 1.单一职责原则

前言 前面我们提到过 SOLID 原则,实际上 SOLID 由 5 个设计原则组成,分别是:单一职责原则、开闭原则、里氏替换原则、接口隔离原则和依赖反转原则。它们分别对应 SLOID 中的 S、O、L、I、D 这 5 个英文字母。 今天来学习下 SOLID 原则中的第…

Libevent的使用及reactor模型

Libevent 是一个用C语言编写的、轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( event-driven),高性能;轻量级,专注于网络,不如 ACE 那么臃肿庞大;源代码相当精炼、易读…

【Java】Java 中的方法引用写法

概述 方法引用(MethodReference)是Lambda表达式的另一种格式,在某些场景下可以提高代码的可读性 使用条件 只可以替换单方法的Lambda表达式 什么意思呢 ? 例如下面这个Lambda表达式就不可以使用方法引用替换,因为…

100243. 将元素分配到两个数组中 I

说在前面 🎈不知道大家对于算法的学习是一个怎样的心态呢?为了面试还是因为兴趣?不管是出于什么原因,算法学习需要持续保持。 题目描述 给你一个下标从 1 开始、包含 不同 整数的数组 nums ,数组长度为 n 。 你需要通…

C语言 快速排序——qsort函数的介绍

qsort函数 1. 函数介绍2. 函数使用2.1 整型排序2.2 字符排序2.3 字符串排序2.4 结构体排序 3. 用冒泡思想模拟qsort函数 我们以往使用冒泡排序和选择排序等对数据进行排序时,有可能会遇到搞不清排序次数,运行时间过长等一些问题,并且这些排序…

aop监控spring cloud接口超时,并记录到数据库

引入pom <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0…

宝塔面板安装各种组件以及部署应用服务

在linux服务器安装宝塔面板 一、从宝塔官网下载exe安装包&#xff0c;安装命令从宝塔官网&#xff08;https://www.bt.cn/&#xff09;获取 yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh二、安…

自动驾驶加速落地,激光雷达放量可期(上)

1 激光雷达应用广泛&#xff0c;汽车有望成最大催化 激光雷达&#xff08;LiDAR&#xff09;是一种主动遥感技术&#xff0c;通过测定传感器发出的激光在传感器与目标物体之间的传播距离&#xff0c;来分析目标地物表面的反射能量大小、反射波谱的幅度、频率和相位等信息&#…

Vue项目如何进行优化?

Vue项目优化 1.移除控制台打印2.压缩图片3.CDN加速 1.移除控制台打印 可以使用插件自动去除&#xff0c;插件包括babel-plugin-transform-remove-console、uglifyjs-webpack-plugin、terser-webpack-plugin。最后选择了terser-webpack-plugin&#xff0c;脚手架vue-cli用这个插…

一文扫盲:订单管理系统,订单是公司生命线。

hello&#xff0c;我是贝格前端工场&#xff0c;本期给大家分享订单管理系统的知识点&#xff0c;欢迎老铁们点赞、关注&#xff0c;如有需求可以私信我们。 一、什么是订单管理系统 单管理系统是一种用于管理和处理订单的软件系统。它通常用于企业、电子商务平台、零售店等需…

高并发高可用--反向代理与负载均衡

高并发高可用架构是指能够应对大量并发请求并保持高度可用的系统架构。为了实现这一目标&#xff0c;通常会采用一系列技术和策略&#xff0c;包括负载均衡、缓存、分布式系统、冗余部署、容错处理等。 以下是一些构建高并发高可用架构的关键要点&#xff1a; 负载均衡&#…

GEE高阶应用python wxee 和eemont——MODIS 中生成NDVI 数据的月度时序影像

结合 wxee 和 eemont eemont概述 谷歌地球引擎是一种基于云的服务,用于矢量和栅格数据的地理空间处理。地球引擎平台拥有 JavaScript 和 Python API,可使用不同方法处理地理空间对象。谷歌地球引擎还提供了一个巨大的 PETABYTE 级栅格和矢量数据目录,用户可以在线处理这些…

技术小知识:面向对象和过程的区别 ⑤

一、思想区别 面相对象&#xff1a;始终把所有事情思考归类、抽离封装成对象来调用完成。 面向过程&#xff1a;直接平铺展开按顺序执行完成任务。 面向对象多了很多对象的创建、使用&#xff0c;销毁的过程资源消耗。是一种模块化编程思想。 https://www.cnblogs.com/kuangmen…

网络爬虫弹幕

1.分析网页&#xff0c;获取代码&#xff0c;提取时间 想要提取出弹幕所在的节点&#xff0c;我们要使用 Beautiful Soup 解析模块&#xff0c;需要从 bs4 中导入 BeautifulSoup 模块 创建一个 BeautifulSoup 对象&#xff0c;传入变量 xml 和解析器 lxml&#xff0c;将该对象赋…

Java自学day5

流程控制语句 流程控制语句:通过一些语句,控制程序的执行流程 顺序结构 顺序结构语句是Java程序默认的执行流程,按照代码的先后顺序,从上到下依次执行! package orderdemo;public class OrderDemo {public static void main(String[] args) {System.out.println("…