巧用VB.NET RND()函数实现文件加密功能

开发 后端
文章主要巧用VB.NET RND()函数和强大的二进制技术功能来实现文件内容加密,希望对大家有技术是上的提高。

在VB.NET中定义了很多种的函数,我们不能一一的都使用过,只有你用到过的函数你较为熟悉,这里就VB.NET RND()函数和大家简单的分析一下。VB.NET RND()函数有一个重要的特征:当RND()的参数(我们称这里可以称它为种子)为负值时,同一种子(负值)产生同一个随机数序列。同时Visual Basic还具有强大的二进制技术功能,这样我们可以按以下思路实现文件内容加密:

  1. X=RND(-KEY) ’KEY为正数  
  2. VAULE=INT(256*RND) ’产生一个随机数(以此为密码)  
  3. Open FILENAME$ For Binary As #FILENUM’打开文件  
  4. Get #FILENUM,I,A ’取文件内容  
  5. B=A XOR VAULE ’得到加密文件 

结合

  1. C=B XOR VAULE’得到解密文件(B为加密后文件内容) 

注意:这里的A非整个文件内容,可以是极少部分、几个字节甚至单个字节,若为单字节,则文件中的每个字节同不同的数异或,破译难度可见有多么大。具体过程:

  1. Sub ENDECODE(FILENAME$,MA,FILE2$)'参数为:源文件,密码,目标文件  
  2. Dim FILENUM As Integer,X As Single,I As Single  
  3. Dim CHARNUM As Integer,RANDOMINTEGER As Integer  
  4. Dim SINGLECHAR As String *1,filen2 As Integer'取单字节  
  5. If MA<0 Them  
  6. MAMA=MA*(-1)  
  7. End If  
  8. X=Rnd(-MA)'参数为负  
  9. FILENUM=FreeFile 
  10. Open FILENAME$ For Binary As #FILENUM '二进制方式打开源文件  
  11. filen2=FreeFile 
  12. Open FILE2$ For Output As #filen2’以顺序文件打开目标文件  
  13. For i=1 To LOF(FILENUM)'LOF()文件字节长  
  14. Get #FILENUM,i,SINGLECHAR'取单字节内容  
  15. CHARNUM=Asc(SINGLECHAR)  
  16. RANDOMINTEGER=Int(256*Rnd)'得到字母表  
  17. CHARNUMCHARNUM=CHARNUM Xor RANDOMINTEGER'异或  
  18. Print #filen2,Chr$(CHARNUM);’写入目标文件  
  19. Next I  
  20. Close FILENUM  
  21. Close filen2  
  22. ok ’调用成功对话框  
  23. End Sub 

#T#上面利用VB.NET RND()函数调用过程可以对任何exe com、文本等文件进行加解密(奇数次加密,偶数次解密),重演性极好,保密性特优,若对上述过程进一步加工,如进行多重随机等手段处理,那么将会更上一层楼,在此不累述。顺便提一下,上面过程若对目标文件同样以二进制文件打开、写入,那么只能对纯西文文本进行加解密,对于纯中文文本则通过修改取双字节、I的步长为2来实现,其它(中西文结合文本、exe com等文件)则将得不到预期结果,其原因可以能是ascll大于127的字符,不能正常显示,不能用put语句正常写入文件(得到的只是空格),有兴趣者不妨一试。

责任编辑:田树 来源: 博客
相关推荐

2010-01-18 16:33:57

VB.NET加密文件

2010-01-12 10:48:54

VB.NET LIST

2010-01-22 15:25:46

VB.NET Time

2010-01-13 13:53:32

VB.NET组件封装

2010-01-19 10:03:35

VB.NET Labe

2009-10-20 14:09:05

VB.NET反射功能

2010-01-20 13:42:10

VB.NET访问INIGetPrivateP

2009-10-15 17:50:48

VB.NET Spli

2009-11-10 17:22:23

VB.NET Form

2009-10-21 10:45:50

VB.NET Quic

2009-11-02 14:48:45

VB.NET HOOK

2010-01-22 16:39:46

VB.NET添加自动查

2010-01-13 09:45:53

VB.NET Arra

2010-01-07 13:40:50

VB.NET读取XML

2009-10-14 10:08:05

VB.NET编写DEC

2009-10-14 09:29:43

VB.NET加密

2009-10-29 13:46:14

VB.NET DES加

2009-10-28 14:00:02

VB.NET文件处理

2010-01-18 10:33:28

VB.NET基本函数

2009-10-26 10:44:27

VB.NET API函
点赞
收藏

51CTO技术栈公众号