- 浏览: 139368 次
- 性别:
- 来自: 西安
最新评论
-
zhlfresh163.com:
,请速回,我也正在玩百度地图,就这里自定义图层出现问题,需要 ...
MapXtreme加载瓦片地图 -
zhlfresh163.com:
var path = "TileServer/&qu ...
MapXtreme加载瓦片地图
AES对媒体文件的加密与解密
using System.Text;
|
002
|
using System.Collections;
|
003
|
using System.ComponentModel;
|
004
|
using System.Data;
|
005
|
using System.Net;
|
006
|
using System.Net.Sockets;
|
007
|
using System.Threading;
|
008
|
using System.IO;
|
009
|
using System.Security.Cryptography;
|
010
|
011
|
public class AESEncryption
|
012
|
{
|
013
|
014
|
static string strKey= "dongbinhuiasxiny" ; //密钥,128位,也可以改为192位(24字节)或256位(32字节)。
|
015
|
static void Main( string []
args)
|
016
|
{
|
017
|
RijndaelManaged
rij = new RijndaelManaged();
|
018
|
rij.KeySize
= 128; //指定密钥长度
|
019
|
020
|
string fp
= @"..." ; //待加密文件
|
021
|
string sPhysicalFilePath
= @"..." ; //加密后的文件
|
022
|
string fw
= @"..." ; //解密后的文件
|
023
|
Console.WriteLine( "Encrypting
begin..." );
|
024
|
encryption(rij,
fp, sPhysicalFilePath);
|
025
|
decryption(rij,sPhysicalFilePath,fw);
|
026
|
027
|
}
|
028
|
//用于加密的函数
|
029
|
public static void encryption(RijndaelManaged
rij, string readfile, string writefile)
|
030
|
{
|
031
|
try
|
032
|
{
|
033
|
//byte[]
key = rij.Key;
|
034
|
byte []
key=Encoding.UTF8.GetBytes (strKey);
|
035
|
byte []
iv = rij.IV;
|
036
|
byte []
buffer = new byte [4096];
|
037
|
Rijndael
crypt = Rijndael.Create();
|
038
|
ICryptoTransform
transform = crypt.CreateEncryptor(key, iv);
|
039
|
//写进文件
|
040
|
FileStream
fswrite = new FileStream(writefile,
FileMode.Create);
|
041
|
CryptoStream
cs = new CryptoStream(fswrite,
transform, CryptoStreamMode.Write);
|
042
|
//打开文件
|
043
|
FileStream
fsread = new FileStream(readfile,
FileMode.Open);
|
044
|
045
|
/*------------------定位要加密的部分-----------------*/
|
046
|
long _file_size=fsread.Length;
|
047
|
byte []
_header = new byte [8];
|
048
|
//定位GUID
|
049
|
fsread.Seek(16,
SeekOrigin.Begin);
|
050
|
//读取header
size
|
051
|
fsread.Read(_header,
0, _header.Length);
|
052
|
//头部长度
|
053
|
long _header_size
= ( long )BitConverter.ToInt32(_header,
0);
|
054
|
byte []
_header_buffer= new byte [_header_size];
|
055
|
fsread.Seek(0,SeekOrigin.Begin);
|
056
|
fsread.Read(_header_buffer,0,_header_buffer.Length);
|
057
|
//头部写入新文件
|
058
|
fswrite.Write(_header_buffer,0,_header_buffer.Length);
|
059
|
//定位到头部,准备读取需要加密的部分
|
060
|
fsread.Seek(_header_size,SeekOrigin.Begin);
|
061
|
/*-----------------定位加密部分完成-------------------*/
|
062
|
int length;
|
063
|
//while
((length = fsread.ReadByte()) != -1)
|
064
|
//cs.WriteByte((byte)length);
|
065
|
while ((length
= fsread.Read(buffer, 0, 4096)) > 0){
|
066
|
cs.Write(buffer,
0, ( int )length);
|
067
|
}
|
068
|
069
|
fsread.Close();
|
070
|
cs.Close();
|
071
|
fswrite.Close();
|
072
|
Console.WriteLine( "Encrypt
Success" );
|
073
|
}
|
074
|
catch (Exception
e)
|
075
|
{
|
076
|
Console.WriteLine( "Encrypt
Faile" +e.ToString());
|
077
|
}
|
078
|
}
|
079
|
//用于解密的函数
|
080
|
public static void decryption(RijndaelManaged
rij, string readfile, string writefile)
|
081
|
{
|
082
|
try
|
083
|
{
|
084
|
//byte[]
key = rij.Key;
|
085
|
byte []
key=Encoding.UTF8.GetBytes (strKey);
|
086
|
byte []
iv = rij.IV;
|
087
|
byte []
buffer= new byte [4096];
|
088
|
Rijndael
crypt = Rijndael.Create();
|
089
|
ICryptoTransform
transform = crypt.CreateDecryptor(key, iv);
|
090
|
//读取加密后的文件
|
091
|
FileStream
fsopen = new FileStream(readfile,
FileMode.Open);
|
092
|
CryptoStream
cs = new CryptoStream(fsopen,
transform, CryptoStreamMode.Read);
|
093
|
//把解密后的结果写进文件
|
094
|
FileStream
fswrite = new FileStream(writefile,
FileMode.OpenOrCreate);
|
095
|
/*------------------定位要解密的部分-----------------*/
|
096
|
long _file_size=fsopen.Length;
|
097
|
byte []
_header = new byte [8];
|
098
|
//定位GUID
|
099
|
fsopen.Seek(16,
SeekOrigin.Begin);
|
100
|
//读取header
size
|
101
|
fsopen.Read(_header,
0, _header.Length);
|
102
|
//头部长度
|
103
|
long _header_size
= ( long )BitConverter.ToInt32(_header,
0);
|
104
|
byte []
_header_buffer= new byte [_header_size];
|
105
|
fsopen.Seek(0,SeekOrigin.Begin);
|
106
|
fsopen.Read(_header_buffer,0,_header_buffer.Length);
|
107
|
//头部写入新文件
|
108
|
fswrite.Write(_header_buffer,0,_header_buffer.Length);
|
109
|
//定位到头部,准备读取需要加密的部分
|
110
|
fsopen.Seek(_header_size,SeekOrigin.Begin);
|
111
|
/*-----------------定位要解密的部分完成-------------------*/
|
112
|
|
113
|
int length;
|
114
|
//while
((length = cs.ReadByte()) != -1)
|
115
|
//fswrite.WriteByte((byte)length);
|
116
|
while ((length
= cs.Read(buffer, 0, 4096)) > 0){
|
117
|
fswrite.Write(buffer,
0, ( int )length);
|
118
|
}
|
119
|
fswrite.Close();
|
120
|
cs.Close();
|
121
|
fsopen.Close();
|
122
|
Console.WriteLine( "Decrypt
Success" );
|
123
|
}
|
124
|
catch (Exception
e)
|
125
|
{
|
126
|
Console.WriteLine( "Decrypt
Failed" +e.ToString());
|
127
|
}
|
128
|
}
|
129
|
}
|
using System;
|
002
|
using System.IO;
|
003
|
using System.Security;
|
004
|
using System.Security.Cryptography;
|
005
|
using System.Runtime.InteropServices;
|
006
|
using System.Text;
|
007
|
008
|
namespace CSEncryptDecrypt
|
009
|
{
|
010
|
class Class1
|
011
|
{
|
012
|
//
Call this function to remove the key from memory after use for security
|
013
|
[System.Runtime.InteropServices.DllImport( "KERNEL32.DLL" ,
EntryPoint= "RtlZeroMemory" )]
|
014
|
public static extern bool ZeroMemory(IntPtr
Destination, int Length);
|
015
|
|
016
|
//
Function to Generate a 64 bits Key.
|
017
|
static string GenerateKey()
|
018
|
{
|
019
|
//
Create an instance of Symetric Algorithm. Key and IV is generated automatically.
|
020
|
DESCryptoServiceProvider
desCrypto =(DESCryptoServiceProvider)DESCryptoServiceProvider.Create();
|
021
|
022
|
//
Use the Automatically generated key for Encryption.
|
023
|
return ASCIIEncoding.ASCII.GetString(desCrypto.Key);
|
024
|
}
|
025
|
026
|
static void EncryptFile( string sInputFilename,
|
027
|
string sOutputFilename,
|
028
|
string sKey)
|
029
|
{
|
030
|
FileStream
fsInput = new FileStream(sInputFilename,
|
031
|
FileMode.Open,
|
032
|
FileAccess.Read);
|
033
|
034
|
FileStream
fsEncrypted = new FileStream(sOutputFilename,
|
035
|
FileMode.Create,
|
036
|
FileAccess.Write);
|
037
|
DESCryptoServiceProvider
DES = new DESCryptoServiceProvider();
|
038
|
DES.Key
= ASCIIEncoding.ASCII.GetBytes(sKey);
|
039
|
DES.IV
= ASCIIEncoding.ASCII.GetBytes(sKey);
|
040
|
ICryptoTransform
desencrypt = DES.CreateEncryptor();
|
041
|
CryptoStream
cryptostream = new CryptoStream(fsEncrypted,
|
042
|
desencrypt,
|
043
|
CryptoStreamMode.Write);
|
044
|
045
|
byte []
bytearrayinput = new byte [fsInput.Length];
|
046
|
fsInput.Read(bytearrayinput,
0, bytearrayinput.Length);
|
047
|
cryptostream.Write(bytearrayinput,
0, bytearrayinput.Length);
|
048
|
cryptostream.Close();
|
049
|
fsInput.Close();
|
050
|
fsEncrypted.Close();
|
051
|
}
|
052
|
053
|
static void DecryptFile( string sInputFilename,
|
054
|
string sOutputFilename,
|
055
|
string sKey)
|
056
|
{
|
057
|
DESCryptoServiceProvider
DES = new DESCryptoServiceProvider();
|
058
|
//A
64 bit key and IV is required for this provider.
|
059
|
//Set
secret key For DES algorithm.
|
060
|
DES.Key
= ASCIIEncoding.ASCII.GetBytes(sKey);
|
061
|
//Set
initialization vector.
|
062
|
DES.IV
= ASCIIEncoding.ASCII.GetBytes(sKey);
|
063
|
064
|
//Create
a file stream to read the encrypted file back.
|
065
|
FileStream
fsread = new FileStream(sInputFilename,
|
066
|
FileMode.Open,
|
067
|
FileAccess.Read);
|
068
|
//Create
a DES decryptor from the DES instance.
|
069
|
ICryptoTransform
desdecrypt = DES.CreateDecryptor();
|
070
|
//Create
crypto stream set to read and do a
|
071
|
//DES
decryption transform on incoming bytes.
|
072
|
CryptoStream
cryptostreamDecr = new CryptoStream(fsread,
|
073
|
desdecrypt,
|
074
|
CryptoStreamMode.Read);
|
075
|
//Print
the contents of the decrypted file.
|
076
|
StreamWriter
fsDecrypted = new StreamWriter(sOutputFilename);
|
077
|
fsDecrypted.Write( new StreamReader(cryptostreamDecr).ReadToEnd());
|
078
|
fsDecrypted.Flush();
|
079
|
fsDecrypted.Close();
|
080
|
}
|
081
|
082
|
static void Main()
|
083
|
{
|
084
|
//
Must be 64 bits, 8 bytes.
|
085
|
//
Distribute this key to the user who will decrypt this file.
|
086
|
string sSecretKey;
|
087
|
|
088
|
//
Get the Key for the file to Encrypt.
|
089
|
sSecretKey
= GenerateKey();
|
090
|
091
|
//
For additional security Pin the key.
|
092
|
GCHandle
gch = GCHandle.Alloc( sSecretKey,GCHandleType.Pinned );
|
093
|
|
094
|
//
Encrypt the file.
|
095
|
EncryptFile( @"C:\MyData.txt" ,
|
096
|
@"C:\Encrypted.txt" ,
|
097
|
sSecretKey);
|
098
|
099
|
//
Decrypt the file.
|
100
|
DecryptFile( @"C:\Encrypted.txt" ,
|
101
|
@"C:\Decrypted.txt" ,
|
102
|
sSecretKey);
|
103
|
104
|
//
Remove the Key from memory.
|
105
|
ZeroMemory(gch.AddrOfPinnedObject(),
sSecretKey.Length * 2);
|
106
|
gch.Free();
|
107
|
}
|
108
|
}
|
109
|
}
|
[代码]大文件分块加密和解密
01
|
using System.Text;
|
02
|
using System.Collections;
|
03
|
using System.ComponentModel;
|
04
|
using System.Data;
|
05
|
using System.Net;
|
06
|
using System.Net.Sockets;
|
07
|
using System.Threading;
|
08
|
using System.IO;
|
09
|
using System.Security.Cryptography;
|
10
|
11
|
namespace VideoEncrypt
|
12
|
{
|
13
|
class Program
|
14
|
{
|
15
|
static void Main( string []
args)
|
16
|
{
|
17
|
RijndaelManaged
rij = new RijndaelManaged();
|
18
|
rij.KeySize
= 128;
|
19
|
20
|
string fp
= @"E://friends//3//3.mkv" ;
|
21
|
string sPhysicalFilePath
= @"E://friends//3//o3.mkv" ;
|
22
|
string fw
= @"E://friends//3//dd3.mkv" ;
|
23
|
Console.WriteLine( "Encrypting
begin..." );
|
24
|
encryption(rij,
fp, sPhysicalFilePath);
|
25
|
decryption(rij,sPhysicalFilePath,fw);
|
26
|
27
|
}
|
28
|
//用于加密的函数
|
29
|
public static void encryption(RijndaelManaged
rij, string readfile, string writefile)
|
30
|
{
|
31
|
try
|
32
|
{
|
33
|
byte []
key = rij.Key;
|
34
|
byte []
iv = rij.IV;
|
35
|
byte []
buffer = new byte [4096];
|
36
|
Rijndael
crypt = Rijndael.Create();
|
37
|
ICryptoTransform
transform = crypt.CreateEncryptor(key, iv);
|
38
|
//写进文件
|
39
|
FileStream
fswrite = new FileStream(writefile,
FileMode.Create);
|
40
|
CryptoStream
cs = new CryptoStream(fswrite,
transform, CryptoStreamMode.Write);
|
41
|
//打开文件
|
42
|
FileStream
fsread = new FileStream(readfile,
FileMode.Open);
|
43
|
int length;
|
44
|
//while
((length = fsread.ReadByte()) != -1)
|
45
|
//cs.WriteByte((byte)length);
|
46
|
while ((length
= fsread.Read(buffer, 0, 4096)) > 0)
|
47
|
cs.Write(buffer,
0, ( int )length);
|
48
|
49
|
fsread.Close();
|
50
|
cs.Close();
|
51
|
fswrite.Close();
|
52
|
Console.WriteLine( "Encrypt
Success" );
|
53
|
}
|
54
|
catch (Exception
e)
|
55
|
{
|
56
|
Console.WriteLine( "Encrypt
Faile" +e.ToString());
|
57
|
}
|
58
|
}
|
59
|
//用于解密的函数
|
60
|
public static void decryption(RijndaelManaged
rij, string readfile, string writefile)
|
61
|
{
|
62
|
try
|
63
|
{
|
64
|
byte []
key = rij.Key;
|
65
|
byte []
iv = rij.IV;
|
66
|
byte []
buffer= new byte [4096];
|
67
|
Rijndael
crypt = Rijndael.Create();
|
68
|
ICryptoTransform
transform = crypt.CreateDecryptor(key, iv);
|
69
|
//读取加密后的文件
|
70
|
FileStream
fsopen = new FileStream(readfile,
FileMode.Open);
|
71
|
CryptoStream
cs = new CryptoStream(fsopen,
transform, CryptoStreamMode.Read);
|
72
|
//把解密后的结果写进文件
|
73
|
FileStream
fswrite = new FileStream(writefile,
FileMode.OpenOrCreate);
|
74
|
|
75
|
int length;
|
76
|
//while
((length = cs.ReadByte()) != -1)
|
77
|
//fswrite.WriteByte((byte)length);
|
78
|
while ((length
= cs.Read(buffer, 0, 4096)) > 0)
|
79
|
fswrite.Write(buffer,
0, ( int )length);
|
80
|
fswrite.Close();
|
81
|
cs.Close();
|
82
|
fsopen.Close();
|
83
|
Console.WriteLine( "Decrypt
Success" );
|
84
|
}
|
85
|
catch (Exception
e)
|
86
|
{
|
87
|
Console.WriteLine( "Decrypt
Failed" +e.ToString());
|
88
|
}
|
89
|
}
|
90
|
}
|
91
|
}
|
相关推荐
在实现AES加密解密时,要特别注意错误处理和数据完整性检查。例如,确保文件读取和写入的正确性,以及在解密过程中处理可能的异常。此外,www.willvc.com.cn 提供的资源可能是进一步学习和解决问题的途径。 总之,...
这个文件可能包含了实现AES加密解密功能的源代码、示例、文档或其他相关资源,帮助开发者在Qt5应用程序中集成AES加密。 **总结** AES加密算法是现代加密的标准之一,常用于保护数据的安全。在Qt5开发中,可以方便...
这个程序应当包含了上述知识点的具体应用,你可以通过阅读源代码、编译和运行来进一步理解和学习AES加密解密的实现细节。这个实战例程可以帮助开发者更好地掌握Qt环境下的加密解密操作,提高数据安全保护能力。
该源码具有以下功能: 1.具有AES算法(高级加密标准)的实现类源码 2.在我的源码中使用AES对象进行文件加密和解密
"aes加密ts"表明AES被用作加密手段,"ts视频解密"和"解密_ts"则提到了解密TS视频文件的过程。这个过程可能包括读取密文TS文件,使用正确的密钥进行解密,以及解复用和解码以得到原始的视频流。 在压缩包的文件名称...
本文将详细介绍 Android 使用 AES 加密和解密文件的实例代码,并对相关知识点进行详细的解释。 AES 加密算法 AES(Advanced Encryption Standard)是一种对称密钥块加密算法,是一种快速、安全的加密算法。AES ...
总的来说,这个资源为Delphi开发者提供了一种实现AES加密解密的方式,并且保证了与Java平台的兼容性。通过理解和应用这些代码,开发者可以增强他们的应用程序在数据安全方面的性能,同时也能更好地与其他Java应用...
通过AES加密解密实验,学生不仅能够掌握加密和解密的基本原理,还能实际操作,提升对密码学的理解,为信息安全领域的实践工作奠定基础。同时,这也有助于培养分析和解决实际问题的能力,因为加密技术在当今数字化...
AES256是一种高级加密标准(Advanced Encryption Standard),是目前广泛应用的数据加密算法,以其强大的安全性、效率和灵活性而闻名。该标准由NIST(美国国家标准...这些知识点对于理解并实现AES256加密解密至关重要。
压缩包中的“AES加密_解密_verilog代码.docx”文件很可能是详细介绍了如何用Verilog编写AES加密解密模块的文档,包括具体的代码示例和设计说明。阅读这份文档可以帮助你理解AES算法在Verilog中的实现细节,以及如何...
本压缩包"uniapp 前后端AES加密解密.rar"正是为了解决这一问题,它包含了在uniapp环境下实现前后端AES加密解密的方法。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,具有...
在Java中实现AES-128-CBC加密解密,你需要以下关键步骤: 1. 导入必要的库:`javax.crypto.Cipher`,`java.security.SecureRandom`,`java.util.Base64`等。 2. 创建密钥:首先,你需要一个128位的密钥。可以使用`...
后端Java实现AES加密解密: 1. **导入依赖**:在Java中,我们需要添加Apache Commons Codec库来处理Base64编码,以及Java Cryptography Extension (JCE)来支持AES操作。确保JCE未受限制,因为默认情况下,Java对某些...
总之,虽然Qt本身不内置AES加密,但结合第三方库和Qt的现有组件,我们可以方便地实现AES加密和解密,为应用程序提供必要的安全保护。在开发过程中,务必遵循最佳实践,确保数据的完整性和安全性。
在提供的aes_demo压缩包中,可能包含了示例代码、说明文档等内容,帮助开发者理解并实现这个加密解密过程。通过对这些资源的深入学习和实践,可以更好地理解和应用这个前端jQuery加密、后端PHP解密的方案。
支持任何形式的aes加密,文件,字符,字节等,内含php代码,可以与php平台实现aes加密,而且包含rsa非对称加密签名验签实现,都是对字节数组的加密解密,签名验签,支持多种形式的的,可以将待操作的对象转换成字节...
本项目"大文件AES加密解密程序"就是针对这一需求而设计的,适用于VS2019开发环境,可能无法在较低版本的Visual Studio中正常运行。 AES,全称为Advanced Encryption Standard,是一种广泛使用的对称加密算法,以其...
在uni-app中,可以使用JavaScript的crypto-js库来实现AES加密解密。首先,你需要通过HBuilderX引入该库,然后在uni-app代码中使用: ```javascript const CryptoJS = require('crypto-js'); const key = 'your_...
然而,仅依赖AES加密可能不够安全,因为如果攻击者获取到相同的密钥,他们就能解密数据。因此,通常会结合密钥管理策略,如使用密钥派生函数(KDFs)或密钥协商协议,以及使用非对称加密(如RSA)来安全地交换AES...
uni-app aes的加密和解密