当前位置:首页 > 智能硬件 > 人工智能AI
[导读]   RSA算法   RSA公开密钥密码体制。所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥,是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体

  RSA算法

  RSA公开密钥密码体制。所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥,是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体制。

  在公开密钥密码体制中,加密密钥(即公开密钥)PK是公开信息,而解密密钥(即秘密密钥)SK是需要保密的。加密算法E和解密算法D也都是公开的。虽然解密密钥SK是由公开密钥PK决定的,但却不能根据PK计算出SK。

  正是基于这种理论,1978年出现了著名的RSA算法,它通常是先生成一对RSA 密钥,其中之一是保密密钥,由用户保存;另一个为公开密钥,可对外公开,甚至可在网络服务器中注册。为提高保密强度,RSA密钥至少为500位长,一般推荐使用1024位。这就使加密的计算量很大。为减少计算量,在传送信息时,常采用传统加密方法与公开密钥加密方法相结合的方式,即信息采用改进的DES或IDEA对话密钥加密,然后使用RSA密钥加密对话密钥和信息摘要。对方收到信息后,用不同的密钥解密并可核对信息摘要。

  RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作。RSA是被研究得最广泛的公钥算法,从提出到现今的三十多年里,经历了各种攻击的考验,逐渐为人们接受,截止2017年被普遍认为是最优秀的公钥方案之一。

  加密过程:

  A提取消息m的消息摘要h(m),并使用自己的私钥对摘要h(m)进行加密,生成签名s

  A将签名s和消息m一起,使用B的公钥进行加密,生成密文c,发送给B。

  解密过程:

  B接收到密文c,使用自己的私钥解密c得到明文m和数字签名s

  B使用A的公钥解密数字签名s解密得到H(m)。

  B使用相同的方法提取消息m的消息摘要h(m)

  B比较两个消息摘要。相同则验证成功;不同则验证失败。

  RSA加密过程简述

  A和B进行加密通信时,B首先要生成一对密钥。一个是公钥,给A,B自己持有私钥。A使用B的公钥加密要加密发送的内容,然后B在通过自己的私钥解密内容。

  数字签名的作用是保证数据完整性,机密性和发送方角色的不可抵赖性

  假设A要想B发送消息,A会先计算出消息的消息摘要,然后使用自己的私钥加密这段摘要加密,最后将加密后的消息摘要和消息一起发送给B,被加密的消息摘要就是“签名”。

  B收到消息后,也会使用和A相同的方法提取消息摘要,然后使用A的公钥解密A发送的来签名,并与自己计算出来的消息摘要进行比较。如果相同则说明消息是A发送给B的,同时,A也无法否认自己发送消息给B的事实。

  其中,A用自己的私钥给消息摘要加密成为“签名”;B使用A的公钥解密签名文件的过程,就叫做“验签”。

  RSA加密与解密代码

  /// 《summary》

  /// RSA 公钥加密

  /// 《/summary》

  /// 《param name=“content”》要加密的内容《/param》

  /// 《param name=“publickey”》公钥《/param》

  /// 《returns》《/returns》

  public staTIc string EncryptByPublicKey(string content, string publickey)

  {

  byte[] s = Convert.FromBase64String(publickey);

  AsymmetricKeyParameter publicKey = PublicKeyFactory.CreateKey(s);

  IBufferedCipher c = CipherUTIliTIes.GetCipher(“RSA/ECB/PKCS1Padding”);

  //公钥加密

  c.Init(true, publicKey);

  byte[] byteData = Encoding.UTF8.GetBytes(content);

  byteData = c.DoFinal(byteData, 0, byteData.Length);

  return Convert.ToBase64String(byteData);

  }

  /// 《summary》

  /// RSA加密

  /// 《/summary》

  /// 《param name=“content”》加密明文《/param》

  /// 《param name=“privatekey”》私钥《/param》

  /// 《returns》返回密文《/returns》

  public staTIc string RSAEncry(string content, string privatekey)

  {

  AsymmetricKeyParameter privateKey = PrivateKeyFactory.CreateKey(Convert.FromBase64String(privatekey));

  IBufferedCipher c = CipherUtilities.GetCipher(“RSA/ECB/PKCS1Padding”);

  //私钥加密

  c.Init(true, privateKey);

  byte[] byteData = Encoding.UTF8.GetBytes(content);

  byteData = c.DoFinal(byteData, 0, byteData.Length);

  return Convert.ToBase64String(byteData);

  }

  /// 《summary》

  /// RSA解密

  /// 《/summary》

  /// 《param name=“content”》密文《/param》

  /// 《param name=“privatekey”》私钥《/param》

  /// 《returns》明文《/returns》

  public static string RSADeEncry(string content, string privatekey)

  {

  try

  {

  MemoryStream bufferStream = new MemoryStream();

  byte[] bytData = Convert.FromBase64String(content);

  int inputLength = bytData.Length;

  AsymmetricKeyParameter privateKey = PrivateKeyFactory.CreateKey(Convert.FromBase64String(privatekey));

  IBufferedCipher cipher = CipherUtilities.GetCipher(“RSA/ECB/PKCS1Padding”);

  cipher.Init(false, privateKey);

  int offSet = 0;

  byte[] cache;

  int i = 0;

  while (inputLength - offSet 》 0)

  {

  if (inputLength - offSet 》 128)

  {

  cache = cipher.DoFinal(bytData, offSet, 128);

  }

  else

  {

  cache = cipher.DoFinal(bytData, offSet, inputLength - offSet);

  }

  bufferStream.Write(cache, 0, cache.Length);

  i++;

  offSet = i * 128;

  }

  byte[] decryptedData = bufferStream.ToArray();

  bufferStream.Close();

  return Encoding.UTF8.GetString(bufferStream.ToArray());

  }

  catch (Exception e)

  {

  return e.Message;

  }

  }

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

绕组系数、绕组宽度、绕线绝缘厚度、所有绕组的厚度等。此外,漏感还会受到工作频率的影响,随着工作频率的增大,漏感也会增大。

关键字: 变压器 漏感 整流电路

线性电源(Linear power supply)是先将交流电经过变压器降低电压幅值,再经过整流电路整流后,得到脉冲直流电,后经滤波得到带有微小波纹电压的直流电压。要达到高精度的直流电压,必须经过稳压电路进行稳压。

关键字: 线性电源 稳压 波纹电压

MC33035无刷直流电机控制器采用双极性模拟工艺制造,可在任何恶劣的工业环境条件下保证高品质和高稳定性。该控制器内含可用于正确整流时序的转子位置译码器。

关键字: 直流马达 控制电路 滤波器

可编程式直流电源是一种将控制电路、功率变换电路和开关稳压电路集成于一体的新型电源,具有体积小、重量轻、效率高、功能强等特点。

关键字: 可编程电源 直流电源 功率变换

随着科技的飞速发展,电子产品在我们日常生活中扮演着越来越重要的角色。而在这些电子产品中,接口作为连接设备与外部设备的桥梁,其重要性不言而喻。其中,Type-C接口作为一种新型的接口标准,因其独特的优势,逐渐成为了众多电子...

关键字: 电子产品 Type-C 接口

往复泵是一种重要的流体输送设备,广泛应用于化工、石油、制药、冶金等领域。其工作原理基于活塞在泵缸内的往复运动,通过改变泵缸内的容积来实现液体的吸入和排出。本文将详细阐述往复泵的工作原理、结构特点、性能参数以及应用领域,以...

关键字: 往复泵 泵缸 设备

液控单向阀,作为液压系统中的一种关键控制元件,在工程机械、冶金、化工、船舶等多个领域发挥着不可替代的作用。它利用控制液体对主阀芯进行开启和关闭操作,从而实现对液流方向的精确控制。本文将详细阐述液控单向阀的工作原理,包括其...

关键字: 液控单向阀 液压系统 控制元件

场效应管(Field Effect Transistor,简称FET)是一种重要的半导体器件,广泛应用于电子设备的各种电路中。它具有输入电阻高、噪声小、功耗低、动态范围大、易于集成、没有二次击穿现象、安全工作区域宽等优点...

关键字: 场效应管 半导体器件 电子设备

电子电路作为现代电子设备的重要组成部分,其稳定性和可靠性对于设备的正常运行至关重要。然而,在实际使用过程中,电子电路难免会出现各种故障,需要进行及时的维修。本文将详细介绍电子电路的维修方法,包括故障诊断、维修步骤、维修技...

关键字: 电子电路 现代电子设备 维修

随着科技的不断发展,颜色传感器在多个领域中的应用越来越广泛。TCS230作为一款高性能的颜色传感器,因其出色的性能和稳定性受到了广泛关注。本文将详细阐述TCS230颜色传感器的工作原理,包括其结构、功能特点以及颜色检测机...

关键字: 颜色传感器 TCS230 光电二极管
关闭
关闭