Core DES加、解密
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加、解密的更多相关文章
- Node.js的DES加解密和MD5加密
最基本的就是经常用的md5加密算法 代码如下 var MD5=function (data) { var _encrymd5 = require('crypto').createHas ...
- 一个java的DES加解密类转换成C#
原文:一个java的DES加解密类转换成C# 一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //i ...
- DES加解密算法Qt实现
算法解密qt加密table64bit [声明] (1) 本文源码 大部分源码来自:DES算法代码.在此基础上,利用Qt编程进行了改写,实现了DES加解密算法,并添加了文件加解密功能.在此对署名为b ...
- Java Des加解密方法(c#加密Java解密)
最近我们用Java把一个用.net编写的老系统重新做了翻版,但是登录还是用.net的登录.这样就会遇到一个比较棘手的问题,我们登录用的cookie信息都是.net用des加密的,但我们不得不用Java ...
- DES加解密 cbc模式 的简单讲解 && C++用openssl库来实现的注意事项
DES cbc是基于数据块加密的.数据块的长度为8字节64bit.以数据块为单位循环加密,再拼接.每个数据块加密的秘钥一样,IV向量不同.第一个数据快所需的IV向量,需要我们提供,从第二个数据块开始, ...
- JavaScript与C#互通的DES加解密算法
原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DE ...
- PHP 基础篇 - PHP 中 DES 加解密详解
一.简介 DES 是对称性加密里面常见一种,全称为 Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法.密钥长度是64位(bit),超过位数密钥被忽略.所谓对 ...
- Java拓展教程:文件DES加解密
Java拓展教程:文件加解密 Java中的加密解密技术 加密技术根据一般可以分为对称加密技术和非对称加密技术.对称加密技术属于传统的加密技术,它的加密和解密的密钥是相同的,它的优点是:运算速度快,加密 ...
- javascript JS CryptoJS DES加解密CBC模式与C#DES加解密相同互通
我们只知道不同的语言解密要相互通用,就需要遵循相同的加密方式,然而在具体做技术预研的时候,就发现会遇到很多问题,网上找的资料也是比较片面,所以我踩了坑,并且把解决方案和相关资料源码提供出来,给需要的朋 ...
- JavaScript与C#互通的DES加解密算法的实现(转)
本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DES解密算法将其解密 ...
随机推荐
- 开源小程序CMS网站, JeeWx-App-CMS 1.1 版本升级发布,持续更新!
JeeWx-App-CMS开源小程序CMS网站,持续更新ing~ JeeWx-App-CMS 是jeewx开发的小程序网站开源项目,基于小程序wepy语言,具备cms网站的基本功能,能够打造简单易用的 ...
- C Mergeable Stack(list超好用)
ZOJ 4016 list用法https://www.cnblogs.com/LLLAIH/p/10673068.html 一开始用普通的栈做,超内存,链表模拟栈也没写出来orz.补题发现list超 ...
- Win10下VirtualBox安装流程
一.VirtualBox简介 VirtualBox 是一款开源的虚拟机软件,最初由美国SUN公司开发,后来SUN被Oracle收购,VirtualBox 更名为Oracle VirtualBox .不 ...
- Windows10安装pycocotools方法,亲测可用!
如果遇到:No module named 'pycocotools' 错误,说明你的环境需要安装pycocotools,以下介绍在Windows10下安装pycocotools的方法,这是本人结合看过 ...
- Mha-Atlas-MySQL高可用方案实践(二)
六,配置VIP漂移 主机名 IP地址(NAT) 漂移VIP 描述 mysql-db01 eth0:192.168.0.51 VIP:192.168.0.60 系统:CentOS6.5(6.x都可以) ...
- form表单的三个属性 action 、mothod 、 enctype。
form_action: 表单数据提交到此页面 下面的表单拥有两个输入字段以及一个提交按钮,当提交表单时,表单数据会提交到名为 "form_action.asp" 的页面: < ...
- /etc/security/limits.conf的相关说明
今天遇到root账户登录不了的情况,很是郁闷,即使单用户修改了root密码也不能登录. 所以就特意看了一下/etc/security/limits.conf,发现是下面这样的.感觉呗坑了许久.(标红线 ...
- 利用Access-Control-Allow-Origin响应头解决跨域请求原理
传统的跨域请求没有好的解决方案,无非就是jsonp和iframe,随着跨域请求的应用越来越多,W3C提供了跨域请求的标准方案(Cross-Origin Resource Sharing).IE8.Fi ...
- 利用gitbush从git上下载代码到本地
1. 在本地新建一个存放代码的文件夹: 2.进入文件夹,右击Git bush here3 3. 出现以下面板: 4. 输入: git init 5.输入:git clone 文件地址链接 成功,在文件 ...
- python多线程的学习
0x00.前言 学了一下python的多线程,threading模块 感觉挺有意思的,随便练手写了一个很粗陋的windows下多线程扫在线ip的脚本 脚本没什么技术含量,纯粹练手,扫一趟192的局域网 ...