加密和解密算法的兩個實現

     最近一段時間,集團加強了資安方面的管理,所有敏感的配置字節都必須經過加密處理,把最近用到的幾個加解密類整理了一下,以做備忘.

    其實這兩個類實現的方法差不多,只是有些細微區別:

ContractedBlock.gifExpandedBlockStart.gif對稱加密演算法類 SymmetricMethodHelper
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

/// <summary>
/// 對稱加密演算法類
/// </summary>
public class SymmetricMethodHelper
{
    
private SymmetricAlgorithm mobjCryptoService;
    
private string Key;
    
/// <summary>
    
/// 對稱加密類的構造函數
    
/// </summary>
    public SymmetricMethodHelper()
    {
        mobjCryptoService = new RijndaelManaged();
        Key = "Guz(%&hj7x89H$yuBI0456FtmaT5&fvHUFCy76*h%(HilJ$lhj!y6&(*jkP87jH7";
    }

    
/// <summary>
    
/// 對稱加密類的構造函數
    
/// </summary>
    public SymmetricMethodHelper(string key)
    {
        mobjCryptoService = new RijndaelManaged();
        Key = key + "Guz(%&hj7x89H$yuBI0456FtmaT5&fvHUFCy76*h%(HilJ$lhj!y6&(*jkP87jH7";
    }

    
/// <summary>
    
/// 獲得密鑰
    
/// </summary>
    
/// <returns>密鑰</returns>
    private byte[] GetLegalKey()
    {
        
string sTemp = Key;
        mobjCryptoService.GenerateKey();
        
byte[] bytTemp = mobjCryptoService.Key;
        
int KeyLength = bytTemp.Length;
        
if (sTemp.Length > KeyLength)
            sTemp 
= sTemp.Substring(0, KeyLength);
        
else if (sTemp.Length < KeyLength)
            sTemp 
= sTemp.PadRight(KeyLength, ' ');
        
return ASCIIEncoding.ASCII.GetBytes(sTemp);
    }
    
/// <summary>
    
/// 獲得初始向量IV
    
/// </summary>
    
/// <returns>初試向量IV</returns>
    private byte[] GetLegalIV()
    {
        
string sTemp = "E4ghj*Ghg7!rNIfb&95GUY86GfghUb#er57HBh(u%g6HJ($jhWk7&!hg4ui%$hjk";
        mobjCryptoService.GenerateIV();
        
byte[] bytTemp = mobjCryptoService.IV;
        
int IVLength = bytTemp.Length;
        
if (sTemp.Length > IVLength)
            sTemp 
= sTemp.Substring(0, IVLength);
        
else if (sTemp.Length < IVLength)
            sTemp 
= sTemp.PadRight(IVLength, ' ');
        
return ASCIIEncoding.ASCII.GetBytes(sTemp);
    }
    
/// <summary>
    
/// 加密方法
    
/// </summary>
    
/// <param name="Source">待加密的串</param>
    
/// <returns>經過加密的串</returns>
    public string Encrypto(string Source)
    {
        
byte[] bytIn = UTF8Encoding.UTF8.GetBytes(Source);
        MemoryStream ms 
= new MemoryStream();
        mobjCryptoService.Key 
= GetLegalKey();
        mobjCryptoService.IV 
= GetLegalIV();
        ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor();
        CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);
        cs.Write(bytIn, 0, bytIn.Length);
        cs.FlushFinalBlock();
        ms.Close();
        
byte[] bytOut = ms.ToArray();
        
return Convert.ToBase64String(bytOut);
    }
    
/// <summary>
    
/// 解密方法
    
/// </summary>
    
/// <param name="Source">待解密的串</param>
    
/// <returns>經過解密的串</returns>
    public string Decrypto(string Source)
    {
        
byte[] bytIn = Convert.FromBase64String(Source);
        MemoryStream ms 
= new MemoryStream(bytIn, 0, bytIn.Length);
        mobjCryptoService.Key 
= GetLegalKey();
        mobjCryptoService.IV 
= GetLegalIV();
        ICryptoTransform encrypto 
= mobjCryptoService.CreateDecryptor();
        CryptoStream cs 
= new CryptoStream(ms, encrypto, CryptoStreamMode.Read);
        StreamReader sr 
= new StreamReader(cs);
        
return sr.ReadToEnd();
    }
}

 

 

ContractedBlock.gifExpandedBlockStart.gifCode
using System;
using System.Text;
using System.IO;
using System.Security.Cryptography;

public class EncryptUtil {
        
/// <summary>
        
/// Des加密
        
/// </summary>
        
/// <param name="clearText"></param>
        
/// <returns></returns>
        public static string DesEncrypt(string clearText) {
            
byte[] byKey = System.Text.ASCIIEncoding.UTF8.GetBytes(KEY_64);
            
byte[] byIV = System.Text.ASCIIEncoding.UTF8.GetBytes(IV_64);

            DESCryptoServiceProvider cryptoProvider 
= new DESCryptoServiceProvider();

            MemoryStream memStream 
= new MemoryStream();
            
//以寫模式 把數據流和要加密的數據流建立連接
            CryptoStream cryStream = new CryptoStream(memStream, cryptoProvider.CreateEncryptor(byKey, byIV), CryptoStreamMode.Write);

            
//將要加密的數據轉換為UTF8編碼的數組

            
byte[] clearTextArray = Encoding.UTF8.GetBytes(clearText);

            
//加密 並寫到 内存流memStream中

            cryStream.Write(clearTextArray, 
0, clearTextArray.Length);
            
//清空緩衝區
            cryStream.FlushFinalBlock();

            
//將8位無符號整數數組 轉換為 等效的System.String 的形式.
            return Convert.ToBase64String(memStream.ToArray());
        }

        
/// <summary>
        
/// Des解密
        
/// </summary>
        
/// <param name="data"></param>
        
/// <returns></returns>
        public static string DesDecrypt(string encryptedText) {
            
byte[] byKey = System.Text.ASCIIEncoding.UTF8.GetBytes(KEY_64);
            
byte[] byIV = System.Text.ASCIIEncoding.UTF8.GetBytes(IV_64);

            
//
            byte[] byteArray = Convert.FromBase64String(encryptedText);

            MemoryStream memStream 
= new MemoryStream();

            DESCryptoServiceProvider cryptoProvider 
= new DESCryptoServiceProvider();
            CryptoStream cryStream 
= new CryptoStream(memStream, cryptoProvider.CreateDecryptor(byKey, byIV), CryptoStreamMode.Write);

            cryStream.Write(byteArray, 
0, byteArray.Length);
            
//清空緩衝區
            cryStream.FlushFinalBlock();

            System.Text.Encoding encoding 
= new System.Text.UTF8Encoding();
            
//把字節數組轉換為 等效的System.String 的形式.
            return encoding.GetString(memStream.ToArray());
        }


        
/// <summary>
        
/// Des加密,功能同DesEncrypt相同
        
/// </summary>
        
/// <param name="clearText"></param>
        
/// <returns></returns>
        public static string DesEncode(string clearText) {
            
byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);
            
byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);

            DESCryptoServiceProvider cryptoProvider 
= new DESCryptoServiceProvider();

            MemoryStream memStream 
= new MemoryStream();
            CryptoStream cryStream 
= new CryptoStream(memStream, cryptoProvider.CreateEncryptor(byKey, byIV), CryptoStreamMode.Write);

            StreamWriter sw 
= new StreamWriter(cryStream);
            sw.Write(clearText);
            sw.Flush();
            cryStream.FlushFinalBlock();
            sw.Flush();
            
return Convert.ToBase64String(memStream.GetBuffer(), 0, (int)memStream.Length);

        }

        
/// <summary>
        
/// Des解密,功能同DesDecrypt相同
        
/// </summary>
        
/// <param name="encryptedText"></param>
        
/// <returns></returns>
        public static string DesDecode(string encryptedText) {
            
byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);
            
byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);

            
byte[] byteArray;
            
try {
                byteArray 
= Convert.FromBase64String(encryptedText);
            }
            
catch {
                
return null;
            }

            DESCryptoServiceProvider cryptoProvider 
= new DESCryptoServiceProvider();
            MemoryStream memStream 
= new MemoryStream(byteArray);
            CryptoStream cryStream 
= new CryptoStream(memStream, cryptoProvider.CreateDecryptor(byKey, byIV), CryptoStreamMode.Read);
            StreamReader sr 
= new StreamReader(cryStream);
            
            
return sr.ReadToEnd();
        }

        
private const string KEY_64 = "MyPubKey";  //公鈅
        private const string IV_64 = "MyPriKey";   //私鈅,注意了:是8个字符,64位


    }
     注意這兩段代碼標注為紅色部分的差异,其中SymmetricMethodHelper類支持超過8位的私鑰,而EncryptUtil類不支持超過8位的私鑰. 

转载于:https://www.cnblogs.com/Jebel/archive/2008/08/13/1267002.html

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

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

相关文章

47.leetcode36_valid_suduko

1.题目分析 Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could be partially filled, where empty cells are filled with the character .. A partially filled sudoku which is valid. Note: A valid Sudoku board (partia…

STM32——SPI接口

STM32——SPI接口 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 一、SPI协议【SerialPeripheral Interface】 串行外围设备接口&#xff0c;是一种高速全双工的通信总线。在ADC/LCD等与MCU间通信。 1、SPI信号线 SPI 包含 4 条总线&#xff0c;SPI 总…

这两种printf()函数重定向方法,太实用了

作者&#xff1a;echobright原文链接&#xff1a;https://blog.csdn.net/qq_29344757/article/details/75363639在前面学习了STM32的串口编程&#xff0c;通过USART1向计算机的串口调试助手打印数据&#xff0c;或者接收计算机串口调试助手的数据&#xff0c;接下来我们可以实现…

浅析Linux 64位系统虚拟地址和物理地址的映射及验证方法

前言有好久没更新了&#xff0c;这段时间发生了挺多大喜事哈。但是也还是有挺久没更新了&#xff0c;不得不意识到自己是个小菜鸡&#xff0c;就算是小菜鸡也要做一只快乐小菜鸡。就算更新慢但是我依然会持续更新&#xff0c;因为更文使我快乐。虚拟内存先简单介绍一下操作系统…

C语言指针:从底层原理到花式技巧,用图文和代码帮你讲解透彻

一、前言二、变量与指针的本质三、指针的几个相关概念四、指向不同数据类型的指针五、总结一、前言如果问C语言中最重要、威力最大的概念是什么&#xff0c;答案必将是指针&#xff01;威力大&#xff0c;意味着使用方便、高效&#xff0c;同时也意味着语法复杂、容易出错。指针…

ARM

ARM 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 1 、ARM处理器的特点 ARM 处理器具有耗电少&#xff0c;功能强大&#xff0c;16 位/32 位双指令集等众多优点。主要有以下六个主要特点&#xff1a; ① 体积小、低功耗&#xff0c;低成本和高性能&am…

解决一个I2C读写问题

之前写关于I2C相关的文章排查一个触摸屏驱动问题MTK 平台TP调试遇坑1、问题今天遇到一个问题&#xff0c;我们有一个芯片&#xff0c;I2C读写失败&#xff0c;导致录音有问题&#xff0c;而且是偶现的。log提示看到是返回 -6<3>[ 730.336308] (3)[2085:tinycap]es7243_…

用多媒体库 Bass.dll 播放 mp3 [9] - 绘制波形图

本例效果图:代码文件:unit Unit1;interfaceusesWindows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,Dialogs, StdCtrls, ExtCtrls, ComCtrls;typeTForm1 class(TForm)OpenDialog1: TOpenDialog;PaintBox1: TPaintBox;Button1: TButton;Button2: TBut…

我是如何使用wireshark软件的

长按二维码识别关注技术共享|资料共享|沟通交流01简介这篇文章介绍一个好用的抓包工具Wireshark&#xff0c; 用来获取网络数据封包&#xff0c;包括HTTP、TCP、UDP等网络协议包。开始界面wireshark是捕获机器上的某一块网卡的网络包&#xff0c;当你的机器上有多块网卡的时候&…

BZOJ4681 [jsoi2010]旅行

时间限制&#xff1a; 3S空间限制&#xff1a; 256M具体思路:DPf[i][j][k]表示1-i,前L条路上用了 j条,L后的路上换了k条的最小代价枚举一下L就有了一个复杂度O(nlognk^3)的做法AC代码#include<bits/stdc.h> using namespace std; #define INF 100000000 #define P pair&l…

IIC踩过的坑

读取IT8563WE时&#xff0c;读取第一次正确&#xff0c;第二次错误&#xff0c;第三次正确&#xff0c;第四次错误。。。。。。看到读取成功之后&#xff0c;SDA信号没有被正确拉高&#xff0c;电平大概只有一半。再次读取&#xff0c;主机设置读模式时&#xff0c;从机会发送N…

1万字30张图说清TCP协议

本篇文章较长&#xff0c;大家先看下目录1、简介2、TCP协议头3、TCP 数据包的编号&#xff08;SEQ&#xff09;4、三次握手建立连接5、四次挥手断开连接6、TCP可靠性的保证7、滑动窗口技术9、窗口滑动的数据重发9、TCP 流控制10、网线“断”了怎么办01简介TCP(Transmission Con…

Spring源码解析(二)BeanDefinition的Resource定位

IOC容器的初始化过程主要包括BeanDefinition的Resource定位、载入和注册。在实际项目中我们基本上操作的都是ApplicationContex的实现&#xff0c;我们比较熟悉的ClassPathXmlApplicationContext、FileSystemXmlApplicationContext、XmlWebapplicationContext等。ApplicationCo…

单片机(MCU)如何才能不死机之对齐访问(Aligned Access)

从一个结构体说起。如下&#xff0c;在 STM32F0 的程序中&#xff0c;我们定义了一个结构体My_Struct &#xff0c;那么这个结构体占用多少内存呢&#xff1f;struct Struct_Def { uint8_t Var_B; uint16_t Var_W0; uint16_t Var_W1; uint32_t Var_DW; }; struct Struct_Def My…

小米的隔空充电,看起来好酷

昨天是1月29号&#xff0c;昨天小米发布了一个隔空充电技术&#xff0c;很火爆&#xff0c;大胆想&#xff0c;如果有一条无线充电的高速公路&#xff0c;那电动汽车还担心没有电吗&#xff1f;—— 雷总的微博原文隔空充电技术&#xff1a;如科幻电影一般&#xff0c;拿着手机…

同事用void把我给秀翻了!

1、聊一聊今天跟大家推荐的这首歌最近应该挺火的&#xff0c;不过没办法插入AGA的原版歌曲&#xff0c;大家觉得不错可以去找找原版歌曲收录一下。昨天建立了"最后一个bug"技术交流群,由于群成员超过200就无法直接通过群二维码加入&#xff0c;如果大家想加入扫描下面…

Spring Boot之自定义属性

选择Spring Boot主要是考虑到它既能兼顾Spring的强大功能&#xff0c;还能实现快速开发的便捷。我想大多数人也是出于这个原因选择了Spring Boot,如果不是特殊应用场景&#xff0c;就只需要在application.properties中完成一些属性配置就能开启各模块的应用。而不像传统的XML配…

一个老工程师的工作经历和思考

在这里不敢以”资深”工程师自居&#xff0c;因为学历和技术水平确实一般。为什么说“老”呢&#xff1f;因为工作时间确实够长&#xff0c;已经接近20年。下面把自身工作和学习经历和大家分享一下&#xff0c;使初学者能够得到一些有用的东西。2000年毕业&#xff0c;机械电子…

电子工程师都在看什么?送你一份“修炼宝典”

现如今&#xff0c;形形色色的公众号如繁星一般让人眼花缭乱。近几年科技的飞速发展&#xff0c;让更多人开始关注科技&#xff0c;甚至成为极客。然而学习是永无止境的&#xff0c;如何才能追赶如此高速的发展&#xff1f;曾经&#xff0c;我也是不知道去看哪些&#xff0c;便…

DataCleaner(4.5)第一章

Part1. Introduction to DataCleaner  介绍DataCleaner |--What is data quality(DQ)  数据质量&#xff1f;|--What is data profiling?   数据分析&#xff1f;|--What is datastore?     数据存储&#xff1f;   Composite datastore   综合性数据存储 |…