【加密算法】SHA
一、简介
安全散列算法(英语:Secure Hash Algorithm,缩写为SHA)是一个密码散列函数家族,是FIPS所认证的安全散列算法。能计算出一个数字消息所对应到的,长度固定的字符串(又称消息摘要)的算法。且若输入的消息不同,它们对应到不同字符串的机率很高。
SHA家族的五个算法,分别是SHA-1、SHA-224、SHA-256、SHA-384,和SHA-512,由美国国家安全局(NSA)所设计,并由美国国家标准与技术研究院(NIST)发布;是美国的政府标准。后四者有时并称为SHA-2。SHA-1在许多安全协定中广为使用,包括TLS和SSL、PGP、SSH、S/MIME和IPsec,曾被视为是MD5(更早之前被广为使用的杂凑函数)的后继者。但SHA-1的安全性如今被密码学家严重质疑;虽然至今尚未出现对SHA-2有效的攻击,它的算法跟SHA-1基本上仍然相似;因此有些人开始发展其他替代的杂凑算法。
二、实现
/// <summary>
/// SHA加密 不可逆 不推荐
/// </summary>
public class ShaHelper
{
/// <summary>
/// SHA1加密 不可逆 不推荐使用
/// </summary>
/// <param name="plaintext"></param>
/// <returns></returns>
public static string Encrypt1(string plaintext)
{
SHA1CryptoServiceProvider sha1 = new SHA1CryptoServiceProvider();
byte[] byteArray = Encoding.UTF8.GetBytes(plaintext);
byte[] bytResult = sha1.ComputeHash(byteArray);
sha1.Clear();
string strResult = BitConverter.ToString(bytResult);
return strResult.Replace("-", "");
} /// <summary>
/// SHA256加密 不可逆
/// </summary>
/// <param name="plaintext"></param>
/// <returns></returns>
public static string Encrypt256(string plaintext)
{
SHA256Managed sha256 = new SHA256Managed();
byte[] byteArray = Encoding.UTF8.GetBytes(plaintext);
byte[] bytResult = sha256.ComputeHash(byteArray);
sha256.Clear(); string strResult = BitConverter.ToString(bytResult);
return strResult.Replace("-", "");
} /// <summary>
/// SHA384加密 不可逆
/// </summary>
/// <param name="plaintext"></param>
/// <returns></returns>
public static string Encrypt384(string plaintext)
{
SHA384Managed sha384 = new SHA384Managed();
byte[] byteArray = Encoding.UTF8.GetBytes(plaintext);
byte[] bytResult = sha384.ComputeHash(byteArray);
sha384.Clear(); string strResult = BitConverter.ToString(bytResult);
return strResult.Replace("-", "");
} /// <summary>
/// SHA512加密 不可逆
/// </summary>
/// <param name="plaintext"></param>
/// <returns></returns>
public static string Encrypt512(string plaintext)
{
SHA512Managed sha512 = new SHA512Managed();
byte[] byteArray = Encoding.UTF8.GetBytes(plaintext);
byte[] bytResult = sha512.ComputeHash(byteArray);
sha512.Clear(); string strResult = BitConverter.ToString(bytResult);
return strResult.Replace("-", "");
}
}
【加密算法】SHA的更多相关文章
- Android数据加密之SHA安全散列算法
前言: 对于SHA安全散列算法,以前没怎么使用过,仅仅是停留在听说过的阶段,今天在看图片缓存框架Glide源码时发现其缓存的Key采用的不是MD5加密算法,而是SHA-256加密算法,这才勾起了我的好 ...
- Java MD5和SHA256等常用加密算法
前言 我们在做java项目开发的时候,在前后端接口分离模式下,接口信息需要加密处理,做签名认证,还有在用户登录信息密码等也都需要数据加密.信息加密是现在几乎所有项目都需要用到的技术,身份认证.单点登陆 ...
- HTTPS and the TLS handshake protocol阅读笔记
目的 为能够透彻理解HTTPS报文交互过程,做此笔记. 本文大部分内容来自 : http://albertx.mx/blog/https-handshake/ http://www.cnblogs.c ...
- 4.Java 加解密技术系列之 HMAC
Java 加解密技术系列之 HMAC 序 背景 正文 代码 结束语 序 上一篇文章中简单的介绍了第二种单向加密算法 — —SHA,同时也给出了 SHA-1 的 Java 代码.有这方面需求的童鞋可以去 ...
- Python学习---重点模块的学习【all】
time [时间模块] import time # print(help(time)) # time模块的帮助 print(time.time()) # 时间戳 print(time.cloc ...
- C#几种常用的加密方式
一.AES加密算法 AES算法基于排列和置换运算.排列是对数据重新进行安排,置换是将一个数据单元替换为另一个.AES 使用几种不同的方法来执行排列和置换运算. AES是一个迭代的.对称密钥分 ...
- 初探计算机网络之HTTPS请求
HTTPS自诞生以来,我们总是对它充满着很多的疑问,HTTPS到底是啥?HTTPS多出来的S指的是什么?HTTPS安全可靠吗?访问一个HTTPS的网站的流程等等,带着这些疑问,我们一起来揭开HTT ...
- 加密算法中BASE64、MD5、SHA、HMAC等之间的区别
http://blog.csdn.net/lplj717/article/details/51828692 根据项目需要了解了一下几种加密算法(参考其他博客),内容简要介绍BASE64.MD5.SHA ...
- Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC
Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC 博客分类: Java/Security Javabase64macmd5sha 加密解密,曾经是我一 ...
- BASE64与单向加密算法MD5&SHA&MAC
言归正传,这里我们主要描述Java已经实现的一些加密解密算法,最后介绍数字证书. 如基本的单向加密算法: BASE64 严格地说,属于编码格式,而非加密算法 MD5(Message Diges ...
随机推荐
- 【校招面试 之 C/C++】第30题 C++ 11新特性(一)之auto关键字
1.自动类型推断 auto自动类型推断,用于从初始化表达式中推断出变量的数据类型.通过auto的自动类型推断,可以大大简化我们的编程工作.下面是一些使用auto的例子. #include <ve ...
- Mask_RCNN Test
- iOS - OC - 打印信息 - xcode 中文打印
#import <Foundation/Foundation.h> @implementation NSDictionary (Log) //重写系统的方法控制输出 -(NSString ...
- .NET资源文件实现多语言切换
1.创建对应的资源文件 lang.en.resx 英文 lang.resx 中文,默认 lang.zh-tw.resx 繁体 首先说明,这三个文件前面部分名称需要一样,只是 点 后面的语言代号 ...
- 不要用for in语句对数组进行遍历
for...in主要用于对数组和对象的属性进行遍历.for ... in 循环中的代码每执行一次,就会对数组的元素或者对象的属性进行一次操作. 语法:for (variable in object) ...
- [Meteor] meteor project structure
- iOS.Dev.Support.MultiVersions
如何利用target conditionals和availabilty 如何来区分平台iOS OR Mac “When building for iOS the deployment target i ...
- OSGi 系列(十八)之 基于注解的 Blueprint
OSGi 系列(十八)之 基于注解的 Blueprint 1. 注解实现 blueprint 第一步:bundle 添加 Bundle-Blueprint-Annotation <plugin& ...
- MySQL相关知识总结
1. 显示所有表 show tables; 还有information_schema数据库里面有tables表,记录了所有表信息 use information_schema; select * fr ...
- 想到的regular方法果然已经被sklearn实现了就是L1和L2组合rugular