public partial class stringTest : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
/*
string s = "i am programmer";
var arr = s.Split(' ');
for (int i = arr.Length - 1; i >= 0; i--)
{
Response.Write(arr[i]+" ");
}*/
//加密测试
string test = "邹大侠";
string vkey = "zpc870921";
Response.Write(string.Format("源字符串:{0}<br/>",test));
string encrypResult = EncryptDes(test,vkey);
Response.Write(string.Format("DES加密后字符串:{0}<br/>", encrypResult));
string decryptResult = DecryptDes(encrypResult, vkey);
Response.Write(string.Format("DES解密后字符串:{0}<br/>", decryptResult));
Response.Write(string.Format("32位MD5加密:{0}<br/>", MD5Encrypt(test)));
}
/// <summary>
/// 32位md5加密算法
/// </summary>
/// <param name="toencrypt"></param>
/// <returns></returns>
private string MD5Encrypt(string toencrypt)
{
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
byte[] s = Encoding.UTF8.GetBytes(toencrypt);
byte[] hashbyte = md5.ComputeHash(s);
StringBuilder sb = new StringBuilder();
foreach(var item in hashbyte)
{
sb.AppendFormat("{0:X2}",item);
}
return sb.ToString();
}
/// <summary>
/// DES对称秘钥加密算法
/// </summary>
/// <param name="toencrypt"></param>
/// <param name="vkey"></param>
/// <returns></returns>
private string EncryptDes(string toencrypt,string vkey)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
des.IV = Encoding.UTF8.GetBytes(FormsAuthentication.HashPasswordForStoringInConfigFile(vkey,"md5").Substring(0,8));
des.Key = Encoding.UTF8.GetBytes(FormsAuthentication.HashPasswordForStoringInConfigFile(vkey,"md5").Substring(0,8));
MemoryStream ms = new MemoryStream();
byte[] s=Encoding.UTF8.GetBytes(toencrypt);
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(s, 0, s.Length);
cs.FlushFinalBlock();
cs.Close();
}
string result = Convert.ToBase64String(ms.ToArray());
return result;
}
/// <summary>
/// DES对称秘钥解密
/// </summary>
/// <param name="toencrypt"></param>
/// <param name="vkey"></param>
/// <returns></returns>
private string DecryptDes(string toencrypt,string vkey)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
des.Key = Encoding.UTF8.GetBytes(FormsAuthentication.HashPasswordForStoringInConfigFile(vkey,"md5").Substring(0,8));
des.IV = Encoding.UTF8.GetBytes(FormsAuthentication.HashPasswordForStoringInConfigFile(vkey, "md5").Substring(0, 8));
byte[] s = Convert.FromBase64String(toencrypt);
MemoryStream ms = new MemoryStream(s);
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Read);
StreamReader sr=new StreamReader(cs,Encoding.UTF8);
string result =sr.ReadToEnd();
return result;
}
}
- PHP对称加密-AES加密、DES加密
对称加密 对称加密算法是指,数据发信方将明文(原始数据)和密钥一起经过加密处理后,使其变成复杂的加密密文发送出去.收信方收到密文后,若要解读原文,则需要使用加密密钥及相关算法的逆算法对密文进行解密,使 ...
- DES加解密算法Qt实现
算法解密qt加密table64bit [声明] (1) 本文源码 大部分源码来自:DES算法代码.在此基础上,利用Qt编程进行了改写,实现了DES加解密算法,并添加了文件加解密功能.在此对署名为b ...
- JavaScript与C#互通的DES加解密算法
原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DE ...
- 信息安全-加密:DES 加密
ylbtech-信息安全-加密:DES 加密 DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法,1977年被美国联邦政府的国家标准局确定为联邦资 ...
- md5加密、Des加密对称可逆加密、RSA非对称可逆加密、https单边验证、银行U盾双边认证
1.md5不可逆的加密方式,加密成一个32位的字符串.算法是公开的,任何语言的加密结果都是一样的.总有可能是重复的. 用途: (1)防止明文存储:可以用作密码加密 ...
- (iOS)Base64加密和DES加密、以及JAVA和iOS中DES加密统一性问题
我们在项目中为了安全方面的考虑,通常情况下会选择一种加密方式对需要安全性的文本进行加密,而Base64加密和DES64加密是常用的加密算法.我记得我在前一个项目中使用的就是这两种加密算法的结合:Bas ...
- <密码学入门>关于DES加密算法解密算法相关问题
题外话:个人觉得DES加密解密真的是一种过程冗长的方法,S盒,P盒还有各种各样的变换让人眼花缭乱. (一)Feistel密码结构 要先说Feistel密码结构的原因是DES加密过程是和Feistel密 ...
- Des加解密算法
class DesHelper { /// <summary> /// DES加密方法 /// </summary> ...
- 实验一:C语言实现DES加解密算法
计算程序执行10万次需要的时间: 总共需要175秒 加解密一次的时间小于:0.00175秒 纯计算加解密的时间会更短 去除IO操作后的时间 也就是说加解密一次的时间为0.07毫秒 /*-------- ...
随机推荐
- linux安装mysql之设置远程访问权限
1.将3306端口加入防火墙 /sbin/iptables -I INPUT -p tcp --dport 3306-j ACCEPT #添加端口3306/etc/rc.d/init.d/iptab ...
- el-checkbox根据是否被选中执行不同的操作
直接给el-checkbox绑定点击事件是没有效果的,因为它会被解析成其他形式的html,el-checkbox只是一个类名,因此,使用ts和jquery动态绑定事件: mounted() { $(& ...
- [洛谷P4568][JLOI2011]飞行路线
题目大意:最短路,可以有$k$条边无费用 题解:分层图最短路,建成$k$层,层与层之间的边费用为$0$ 卡点:空间计算出错,建边写错 C++ Code: #include <cstdio> ...
- CCmdUI
原文链接地址:http://blog.csdn.net/luicha/article/details/6771185 CCmdUI是一个只被使用于ON_UPDATECOMMAND_UI消息的响应函数中 ...
- bzoj进度条
好久没发进度了 这个月没有上个月那么猛,肯能使因为这个月不想水题吧 No. 510 Solved Problems List Solved 368 10001001100210071008101210 ...
- 东北育才冲刺noip(day9)
这十天来呢,感觉自己进步很大,(虽然被碾压的很惨),看到了自己以前完全没见过,也没想过的算法,打开新世界的大门. 同时呢,也感觉自己太弱了,于是就注册了这个博客. 为了促进进步,在这里立下flag,我 ...
- 【BZOJ 3232】圈地游戏 二分+SPFA判环/最小割经典模型
最小割经典模型指的是“一堆元素进行选取,对于某个元素的取舍有代价或价值,对于某些对元素,选取后会有额外代价或价值”的经典最小割模型,建立倒三角进行最小割.这个二分是显然的,一开始我也是想到了最小割的那 ...
- [USACO08DEC] 秘密消息Secret Message
题目描述 Bessie is leading the cows in an attempt to escape! To do this, the cows are sending secret bin ...
- java 多线程 原子性
原子性 原子性:原子操作是不能被线程调度机制中断的操作,一旦操作开始,那么它就一定可以在可能发生的“上下文切换”之前(切换到其他线程执行)执行完毕. 依赖原子性是很棘手且很危险的,除非你是并发专家,否 ...
- 设备VMnet0上的网络桥接当前未在运行解决办法
问题: 今天把自己的VM从C盘挪到了D盘,然后再open所有VM都会显示网卡无法桥接了 “vmware 没有未桥接的主机网络适配器” 解决办法: 1.关闭所有VM 2.打开 编辑-虚拟网络编辑器,会发 ...