Enterprise Library 4.1学习笔记6----加密应用程序块

简介: 学习这一块内容前,先得大概知道"哈希算法"和"对称加密算法"是咋回事儿. 不清楚的先去这里充电5分钟再回来 哈希算法------http://baike.baidu.com/view/273836.

学习这一块内容前,先得大概知道"哈希算法"和"对称加密算法"是咋回事儿.

不清楚的先去这里充电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中的相关节点

img_dc1ae6253faecdbee9354150c4db5a9b.jpg

需要注意的是:
对称算法中的密钥文本文件,在asp.net环境中一定不要存放在网站目录下,否则谁都可以下载,形同虚设!

完成后,web.config内容大概如下:

img_64bd3f76c3bac8e6b320829f254ffa63.gif
< configuration >
    
< configSections >
        img_64bd3f76c3bac8e6b320829f254ffa63.gif
        
<section name="securityCryptographyConfiguration" type ="Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.Configuration.CryptographySettings, Microsoft.Practices.EnterpriseLibrary.Security.Cryptography, Version=4.1.0.0, Culture=neutral"/>
        img_64bd3f76c3bac8e6b320829f254ffa63.gif
    
</ 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>
    img_64bd3f76c3bac8e6b320829f254ffa63.gif

3.接下来就可以测试了,关键地方已经加了注释
ContractedBlock.gif ExpandedBlockStart.gif 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 >
运行界面图:
img_dd6b086bea1092c4ddf47e34745c06cd.jpg
目录
相关文章
|
3月前
|
移动开发 JavaScript 安全
Vue 应用程序性能优化:代码压缩、加密和混淆配置详解
Vue 应用程序性能优化:代码压缩、加密和混淆配置详解
38 0
|
4月前
|
JavaScript 安全 开发工具
​Vue 应用程序性能优化:代码压缩、加密和混淆配置详解
简介在 Vue 应用程序的开发中,代码压缩、加密和混淆是优化应用程序性能和提高安全性的重要步骤。 Vue CLI 是一个功能强大的开发工具,它提供了方便的配置选项来实现这些功能。本文将介绍如何使用 Vue CLI 配置代码压缩、加密和混淆功能,以提高应用程序的性能和安全性。
|
5月前
|
开发工具 数据安全/隐私保护 git
【Devchat 插件】创建一个GUI应用程序,使用Python进行加密和解密
【Devchat 插件】创建一个GUI应用程序,使用Python进行加密和解密
76 0
|
8月前
|
数据安全/隐私保护
java202303java学习笔记第三十六天综合练习(加密和解密文件)1
java202303java学习笔记第三十六天综合练习(加密和解密文件)1
50 0
|
8月前
|
数据安全/隐私保护
java202303java学习笔记第三十六天综合练习(加密和解密文件)2
java202303java学习笔记第三十六天综合练习(加密和解密文件)2
54 0
|
10月前
|
数据安全/隐私保护
java202303java学习笔记第三十六天综合练习(加密和解密文件)1
java202303java学习笔记第三十六天综合练习(加密和解密文件)1
54 0
|
11月前
|
Go 数据安全/隐私保护
Go实现aes加密,并带你手撸一个命令行应用程序
Go实现aes加密,并带你手撸一个命令行应用程序
130 0
|
数据安全/隐私保护
java202302java学习笔记第十一天-数字的加密和解密3
java202302java学习笔记第十一天-数字的加密和解密3
63 0
java202302java学习笔记第十一天-数字的加密和解密3
|
数据安全/隐私保护
java202302java学习笔记第十一天-数字的加密和解密2
java202302java学习笔记第十一天-数字的加密和解密2
50 0
java202302java学习笔记第十一天-数字的加密和解密2
|
安全 算法 Cloud Native
使用阿里云服务网格 ASM 和 Intel Multi-Buffer 技术实现更快的应用服务间加密通信|学习笔记
快速学习使用阿里云服务网格 ASM 和 Intel Multi-Buffer 技术实现更快的应用服务间加密通信
304 0
使用阿里云服务网格 ASM 和 Intel Multi-Buffer 技术实现更快的应用服务间加密通信|学习笔记