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

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

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

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;接下来我们可以实现…

小时级的进度监控工具

一直在找具体到小时级别的进度监控工具&#xff0c;MS Project甘特图出现也都是天为单位&#xff0c;试用GVCGantt也不行。由于小时级别也适用于个人管理。找了些个人管理模板&#xff0c;不是很理想。直到最近接触到scrum中的burn down chart才忽然明白&#xff0c;这就是我想…

【转】oracle数据库中varchar2陷阱

转自&#xff1a;http://www.cnblogs.com/iyangyuan/p/3491215.html oracle数据库相信大家都比较熟悉&#xff0c;数据库中有一种非常常用的数据类型&#xff1a;字符串型。 对应该类型&#xff0c;在oracle中有三种比较常用的类型&#xff1a;varchar2(byte)、varchar2(char)、…

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

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

SPI、I2C、UART三种串行总线协议的区别

SPI、I2C、UART三种串行总线协议的区别 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 第一个区别当然是名字&#xff1a; SPI(Serial Peripheral Interface&#xff1a;串行外设接口); I2C(INTER IC BUS&#xff1a;意为IC之间总线) UART(…

FLEX组件AnyChart实例教程.

自己看吧&#xff0c;十分详细. 这是其中一个例子&#xff1a; http://www.anychart.com/products/anychart/docs/platforms/flex/samples/gauge_tank/GaugeTank.swf http://www.anychart.com/products/anychart/docs/platforms/flex/

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

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

软件过程改进

对于软件企业来说&#xff0c;软件过程是整个企业最复 杂、最重要的业务流程&#xff0c;软件产品就是软件企业的生命&#xff0c;改进整个企业的业务流程&#xff0c;最重要的还是要改进它的软件过程。多年以来&#xff0c;人们认识到要想高效率、高质量 和低成本地开发软件&a…

ARM

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

Linux下精准踢掉登录用户-pkill命令

pkill -kill -t 用户的TTY pkill -9 用户的TTY 转载于:https://www.cnblogs.com/setart/p/8496165.html

解决一个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;当你的机器上有多块网卡的时候&…

揩油

揩油&#xff0c;说的是老是有人送上来给我揩油&#xff0c;让我很没有心理准备&#xff0c;而且很不适应。 昨天去家乐福买东西&#xff0c;排队付钱的时候&#xff0c;我和前面一个女孩子的距离间隔<?xml:namespace prefix st1 ns "urn:schemas-microsoft-com:off…

AfxGetMainWnd( )函数

AfxGetMainWnd( )函数 版权声明&#xff1a;需要转载的请注明出处 https://blog.csdn.net/qq_22642239/article/details/52241405 AfxGetMainWnd( )&#xff1a; 使用AfxGetMainWnd函数获取MFC程序中的主框架类指针是一个常用作法。 就是获得应用程序主窗口的指针&#xff…

8086 汇编

8086 汇编速查手册 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神的无限的。 一、数据传输指令 ─────────────────────────────────────── 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 1. 通用数…

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…