安装 Portable.BouncyCastle Nuget包
Install-Package Portable.BouncyCastle
 

 using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Crypto.Engines;
using Org.BouncyCastle.Crypto.Modes;
using Org.BouncyCastle.Crypto.Paddings;
using Org.BouncyCastle.Crypto.Parameters;
using System;
using System.Collections.Generic;
using System.IO;
using System.Security.Cryptography;
using System.Text; namespace ConsoleAppDES
{
class Program
{
public static string desData = "fu kai hang";
public static string desKey = "";
public static string desIV = "";
static void Main(string[] args)
{
var encrypt = DESHelper.EncryptDES(desData, desKey, desIV);
Console.WriteLine(encrypt);
var decrypt = DESHelper.DecryptDES(encrypt, desKey, desIV);
Console.WriteLine(decrypt);
Console.ReadKey();
}
}
public class DESHelper
{
static IBlockCipher engine = new DesEngine();
/// <summary>
/// 使用DES加密
/// </summary>
/// <param name="data">待加密的字符串</param>
/// <param name="key">加密密钥,要求8位</param>
/// <param name="iv">偏移向量</param>
/// <returns></returns>
public static string EncryptDES(string data, string key, string iv)
{
byte[] byKey = Encoding.UTF8.GetBytes(key);
byte[] byIV = Encoding.UTF8.GetBytes(iv);
byte[] byData = Encoding.UTF8.GetBytes(data); BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CbcBlockCipher(engine), new Pkcs7Padding());
cipher.Init(true, new ParametersWithIV(new DesParameters(byKey), byIV));
byte[] rv = new byte[cipher.GetOutputSize(byData.Length)];
int tam = cipher.ProcessBytes(byData, , byData.Length, rv, );
cipher.DoFinal(rv, tam);
return Convert.ToBase64String(rv);
}
/// <summary>
/// 使用DES解密
/// </summary>
/// <param name="data">待解密的字符串</param>
/// <param name="key">解密密钥,要求8位</param>
/// <param name="vi">偏移向量</param>
/// <returns></returns>
public static string DecryptDES(string data, string key, string vi)
{
StringBuilder ret = new StringBuilder();
foreach (byte b in Convert.FromBase64String(data))
{
ret.AppendFormat("{0:X2}", b);
}
byte[] byData = new byte[ret.ToString().Length / ];
for (int x = ; x < ret.ToString().Length / ; x++)
{
int i = (Convert.ToInt32(ret.ToString().Substring(x * , ), ));
byData[x] = (byte)i;
}
byte[] byKey = Encoding.UTF8.GetBytes(key);
byte[] byVI = Encoding.UTF8.GetBytes(vi);
BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CbcBlockCipher(engine));
cipher.Init(false, new ParametersWithIV(new DesParameters(byKey), byVI));
byte[] rv = new byte[cipher.GetOutputSize(byData.Length)];
int tam = cipher.ProcessBytes(byData, , byData.Length, rv, );
cipher.DoFinal(rv, tam);
var rvl = new List<byte>();
rvl.AddRange(rv);
rvl.RemoveAll(b => b == );
rv = rvl.ToArray();
return Encoding.UTF8.GetString(rv);
}
}
}

Core DES加、解密的更多相关文章

  1. Node.js的DES加解密和MD5加密

    最基本的就是经常用的md5加密算法 代码如下 var  MD5=function (data) {        var _encrymd5 = require('crypto').createHas ...

  2. 一个java的DES加解密类转换成C#

    原文:一个java的DES加解密类转换成C# 一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //i ...

  3. DES加解密算法Qt实现

      算法解密qt加密table64bit [声明] (1) 本文源码 大部分源码来自:DES算法代码.在此基础上,利用Qt编程进行了改写,实现了DES加解密算法,并添加了文件加解密功能.在此对署名为b ...

  4. Java Des加解密方法(c#加密Java解密)

    最近我们用Java把一个用.net编写的老系统重新做了翻版,但是登录还是用.net的登录.这样就会遇到一个比较棘手的问题,我们登录用的cookie信息都是.net用des加密的,但我们不得不用Java ...

  5. DES加解密 cbc模式 的简单讲解 && C++用openssl库来实现的注意事项

    DES cbc是基于数据块加密的.数据块的长度为8字节64bit.以数据块为单位循环加密,再拼接.每个数据块加密的秘钥一样,IV向量不同.第一个数据快所需的IV向量,需要我们提供,从第二个数据块开始, ...

  6. JavaScript与C#互通的DES加解密算法

    原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DE ...

  7. PHP 基础篇 - PHP 中 DES 加解密详解

    一.简介 DES 是对称性加密里面常见一种,全称为 Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法.密钥长度是64位(bit),超过位数密钥被忽略.所谓对 ...

  8. Java拓展教程:文件DES加解密

    Java拓展教程:文件加解密 Java中的加密解密技术 加密技术根据一般可以分为对称加密技术和非对称加密技术.对称加密技术属于传统的加密技术,它的加密和解密的密钥是相同的,它的优点是:运算速度快,加密 ...

  9. javascript JS CryptoJS DES加解密CBC模式与C#DES加解密相同互通

    我们只知道不同的语言解密要相互通用,就需要遵循相同的加密方式,然而在具体做技术预研的时候,就发现会遇到很多问题,网上找的资料也是比较片面,所以我踩了坑,并且把解决方案和相关资料源码提供出来,给需要的朋 ...

  10. JavaScript与C#互通的DES加解密算法的实现(转)

    本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DES解密算法将其解密 ...

随机推荐

  1. IntelliJ IDEA插件系列

    参考: IntelliJ IDEA插件系列 1. activate-power-mode 和 Power mode II 根据Atom的插件activate-power-mode的效果移植到IDEA上 ...

  2. DatakeyNames和datakey

    DataKey 类用于表示数据绑定控件中某个记录的主键.记录的主键可以由数据源中的一个或多个字段组成.尽管 DataKey 类不是集合,但它可以存储多个键字段值.当调用 DataKey 类的某个构造函 ...

  3. python大法好——Python XML解析

    Python XML解析 什么是XML? XML 被设计用来传输和存储数据. XML是一套定义语义标记的规则,这些标记将文档分成许多部件并对这些部件加以标识. 它也是元标记语言,即定义了用于定义其他与 ...

  4. 原生JS实现异步图片上传(预览)

    效果 实现过程分为两步 1. 用户点击添加后通过 H5文件读取 FileReader对象以DataURL的格式读取图片 2. 通过FormData对象生成表单数据,通过ajax上传到后台 HTML & ...

  5. Java面试题 BAT 大公司面试题整理总结!

    本文只列出了问题,答案还是需要需要自己的总结,很多时候自己总结出来的语言在面试时比硬背的效果好很多. 这些题目是网友去百度.小米.乐视.美团.58.猎豹.360.新浪.搜狐等一线互联网公司面试被问到的 ...

  6. python中TCP协议中的粘包问题

    TCP协议中的粘包问题 1.粘包现象 基于TCP实现一个简易远程cmd功能 #服务端 import socket import subprocess sever = socket.socket() s ...

  7. 阿里云ossfs配置

    Github:https://github.com/aliyun/ossfs/wiki Root账户卸载:umount /挂载目录非root用户要卸载目录,请用:fusermount -u your_ ...

  8. 机械革命 x7ti-s 1周年使用报告

    2017年11月19日在京东入手一台机械革命x7ti-s(https://item.jd.com/5048818.html)当时各种优惠返现什么的最终8399.5到手(是1060显卡的机械版).前几周 ...

  9. sql语句(已在Oracle中测试,之后有添加内容放在评论中)

    1增 1.1[创建一张表] create table 表名(列名 类型); 例: ),性别 ),出生日期 date); ),sex ),出生日期 date); 1.2[插入单行]insert [int ...

  10. .net 语音,视频等格式转换

    最近在做微信公众号开发的时候遇到一个问题,就是微信接收到语音消息的格式为amr,在网页上通常不能直接播放,需要先转为mp3,于是找到了一个办法,使用ffmpeg.exe,网上可以搜一下ffmpeg.e ...