zoukankan
html css js c++ java
哈希算法MD5和SHA1的C#实现
/*
* 哈希算法MD5和SHA1的C#实现
*
*
* 夏春涛 Email:xChuntao@163.com
* Blog:http://bluesky521.cnblogs.com
* 运行环境:.net2.0 framework
*/
/*
* 关于哈希函数:
* 哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。
* 加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个
* 不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。
* 数据的少量更改会在哈希值中产生不可预知的大量更改。
*
* MD5 算法的哈希值大小为 128 位。
* SHA1 算法的哈希值大小为 160 位。
*/
using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Cryptography;
namespace MD5_App
{
class Program
{
static void Main(string[] args)
{
string strSrc = "How are you?";
Console.WriteLine("原文:" + strSrc);
Console.WriteLine();
Console.WriteLine("MD5哈希值:" + MD5_Hash(strSrc));
Console.WriteLine();
Console.WriteLine("SHA1哈希值:" + SHA1_Hash(strSrc));
Console.WriteLine();
}
//MD5
static public string MD5_Hash(string str_md5_in)
{
MD5 md5 = new MD5CryptoServiceProvider();
byte[] bytes_md5_in = UTF8Encoding.Default.GetBytes(str_md5_in);
byte[] bytes_md5_out = md5.ComputeHash(bytes_md5_in);
string str_md5_out = BitConverter.ToString(bytes_md5_out);
//str_md5_out = str_md5_out.Replace("-", "");
return str_md5_out;
}
//SHA1
static public string SHA1_Hash(string str_sha1_in)
{
SHA1 sha1 = new SHA1CryptoServiceProvider();
byte[] bytes_sha1_in = UTF8Encoding.Default.GetBytes(str_sha1_in);
byte[] bytes_sha1_out = sha1.ComputeHash(bytes_sha1_in);
string str_sha1_out = BitConverter.ToString(bytes_sha1_out);
//str_sha1_out = str_sha1_out.Replace("-", "");
return str_sha1_out;
}
}
}
源码附件:
/Files/bluesky521/DES_Hash_Demo.rar
查看全文
相关阅读:
使用JavaScript发布订阅设计模式实现Ajax请求节流
浏览器获取鼠标光标坐标
JavaScript正则表达式
git 入门以及git客户端的常用命令
Chrome 开发者工具的使用介绍
CSS3动画的使用以及优化
移动的自适应方法
新手如何编写测试用例
Python接口测试入门
MySQL的基本语句(一)
原文地址:https://www.cnblogs.com/Jeely/p/11727537.html
最新文章
vue 左右末端滑动导航
公共导航a标签跳转添加样式
原生js封装轮播图
vue 左右滑动效果
双飞翼布局
sass
鼠标悬浮鼠标的效果
ArcGIS平台中PostgreSQL数据连接配置总结
ArcGIS如何将表连接到空间数据上
ArcGIS Server注册地理数据库报machine:机器名[Oracle:(null)]错误的修改
热门文章
ArcGIS地图打印设置
Portal for ArcGIS上传shp文件中文乱码可能情况
不同gdb,相同数据集合并
栅格数据批量投影
遥感之热红外遥感
IDL中histogram的应用
Android中使用POI加载与显示word文档
三、Electron + Webpack + Vue 搭建开发环境及打包安装 ---- 打包electron应用
二、Electron + Webpack + Vue 搭建开发环境及打包安装
一、Electron + Webpack + Vue 搭建开发环境及打包安装
Copyright © 2011-2022 走看看