Enterprise Library 4.1学习笔记6----加密应用程序块
时间:2022-04-23
本文章向大家介绍Enterprise Library 4.1学习笔记6----加密应用程序块,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
学习这一块内容前,先得大概知道"哈希算法"和"对称加密算法"是咋回事儿.
不清楚的先去这里充电5分钟再回来
哈希算法------http://baike.baidu.com/view/273836.htm
对称加密算法--http://baike.baidu.com/view/7591.htm
使用步骤:
1.先添加Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.dll的引用
2.参照http://www.cnblogs.com/Terrylee/archive/2005/11/29/286688.html中所写,创建web.config中的相关节点
需要注意的是: 对称算法中的密钥文本文件,在asp.net环境中一定不要存放在网站目录下,否则谁都可以下载,形同虚设!
完成后,web.config内容大概如下:
<configuration>
<configSections>
<section name="securityCryptographyConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.Configuration.CryptographySettings, Microsoft.Practices.EnterpriseLibrary.Security.Cryptography, Version=4.1.0.0, Culture=neutral"/>
</configSections>
<securityCryptographyConfiguration>
<hashProviders>
<add algorithmType="System.Security.Cryptography.SHA256Managed, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" saltEnabled="true" type="Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.HashAlgorithmProvider, Microsoft.Practices.EnterpriseLibrary.Security.Cryptography, Version=4.1.0.0, Culture=neutral" name="SHA256Managed"/>
</hashProviders>
<symmetricCryptoProviders>
<add algorithmType="System.Security.Cryptography.RC2CryptoServiceProvider, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" protectedKeyFilename="C:key.txt" protectedKeyProtectionScope="LocalMachine" type="Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.SymmetricAlgorithmProvider, Microsoft.Practices.EnterpriseLibrary.Security.Cryptography, Version=4.1.0.0, Culture=neutral" name="RC2CryptoServiceProvider"/>
</symmetricCryptoProviders>
</securityCryptographyConfiguration>
3.接下来就可以测试了,关键地方已经加了注释
Code
using System;
using System.Text;
using Microsoft.Practices.EnterpriseLibrary.Security.Cryptography;
namespace EncryptTest
{
public partial class _Default : System.Web.UI.Page
{
//这二个值必须与web.config相关Providers中的name一致
private const string hashProvider = "SHA256Managed";
private const string symmProvider = "RC2CryptoServiceProvider";
protected void Page_Load(object sender, EventArgs e)
{
}
/// <summary>
/// 生成Hash散列值
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnHash_Click(object sender, EventArgs e)
{
byte[] valueToHash = Encoding.Default.GetBytes(txtOriginal.Text);
byte[] generatedHash = Cryptographer.CreateHash(hashProvider, valueToHash);
// Clear the byte array memory
Array.Clear(valueToHash, 0, valueToHash.Length);
lHash.Text = Convert.ToBase64String(generatedHash);
}
/// <summary>
/// 比较Hash散列值
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnCompare_Click(object sender, EventArgs e)
{
byte[] valueToHash = System.Text.Encoding.UTF8.GetBytes(txtCompare.Text);
if (lHash.Text != "")
{
bool matched = Cryptographer.CompareHash(hashProvider, valueToHash, Convert.FromBase64String(lHash.Text));
// Clear the byte array memory
Array.Clear(valueToHash, 0, valueToHash.Length);
if (matched)
{
lCompare.Text = "<span style='color:green'>该字符串未被篡改过!</span>";
}
else
{
lCompare.Text = "<span style='color:red'>该字符串被修改过了!</span>";
}
}
}
/// <summary>
/// 加密
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnEncrypt_Click(object sender, EventArgs e)
{
lEncrypt.Text = Cryptographer.EncryptSymmetric(symmProvider, txtOriginal2.Text);
}
/// <summary>
/// 解密
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDecrypt_Click(object sender, EventArgs e)
{
lDecrypt.Text = Cryptographer.DecryptSymmetric(symmProvider, lEncrypt.Text);
}
}
}
前端asp页
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="EncryptTest._Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<style type="text/css">
*
{
font-size: 12px;
line-height: 18px;
}
th
{
font-size: 14px;
line-height: 20px;
}
.btn
{
height: 21px;
width: 100px;
line-height: 16px;
}
</style>
</head>
<body>
<form id="form1" runat="server">
<table>
<tr>
<th colspan="3" align="center">
Hash算法测试
</th>
</tr>
<tr>
<td align="right">
输入要加密的文字:
</td>
<td>
<asp:TextBox ID="txtOriginal" runat="server" Width="300px"></asp:TextBox>
</td>
<td align="left">
<asp:Button ID="btnHash" runat="server" Text="生成Hash散列" OnClick="btnHash_Click" CssClass="btn" />
</td>
</tr>
<tr>
<td colspan="3" align="center">
<asp:Literal ID="lHash" runat="server"></asp:Literal>
</td>
</tr>
<tr>
<td align="right">
请输入要比较的文字:
</td>
<td>
<asp:TextBox ID="txtCompare" runat="server" Width="300px"></asp:TextBox>
</td>
<td align="left">
<asp:Button ID="btnCompare" runat="server" Text="比较Hash散列" OnClick="btnCompare_Click"
CssClass="btn" />
</td>
</tr>
<tr>
<td colspan="3" align="center">
<asp:Literal ID="lCompare" runat="server"></asp:Literal>
</td>
</tr>
<tr>
<th colspan="3" align="center">
对称加密算法测试
</th>
</tr>
<tr>
<td align="right">
输入要加密的文字:
</td>
<td>
<asp:TextBox ID="txtOriginal2" runat="server" Width="300px"></asp:TextBox>
</td>
<td align="left">
<asp:Button ID="btnEncrypt" runat="server" Text=" 加 密 " CssClass="btn" OnClick="btnEncrypt_Click" />
</td>
</tr>
<tr>
<td colspan="3" align="center">
<asp:Literal ID="lEncrypt" runat="server"></asp:Literal>
</td>
</tr>
<tr>
<td align="right">
输入要解密的密码:
</td>
<td>
<asp:TextBox ID="txtEncrypt" runat="server" Width="300px"></asp:TextBox>
</td>
<td align="left">
<asp:Button ID="btnDecrypt" runat="server" Text=" 解 密 " CssClass="btn"
onclick="btnDecrypt_Click"/>
</td>
</tr>
<tr>
<td colspan="3" align="center">
<asp:Literal ID="lDecrypt" runat="server"></asp:Literal>
</td>
</tr>
</table>
</form>
</body>
</html>
运行界面图:
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Python中的ARIMA模型、SARIMA模型和SARIMAX模型对时间序列预测
- python3用ARIMA模型进行时间序列预测
- R语言马尔可夫转换模型研究交通伤亡人数事故预测
- scrapy爬虫框架和selenium的使用:对优惠券推荐网站数据LDA文本挖掘
- 使用R语言进行Metroplis-in-Gibbs采样和MCMC运行分析
- R语言中的马尔科夫机制转换(Markov regime switching)模型
- R语言ARMA-EGARCH模型、集成预测算法对SPX实际波动率进行预测
- nginx快速入门
- R语言中进行期权定价的Heston模型
- 使用R语言随机波动模型SV处理时间序列中的随机波动率
- 20个ES6面试高频问题
- i++和++i傻傻分不清楚?这里给你最清楚的解答
- android APT 使用
- Flutter异步编程async与await的基本使用
- 教大家一个万能PPT图片排版技巧,太赞了!