用RND()函数加密

2016-02-19 16:30 5 1 收藏

get新技能是需要付出行动的,即使看得再多也还是要动手试一试。今天图老师小编跟大家分享的是用RND()函数加密,一起来学习了解下吧!

【 tulaoshi.com - 编程语言 】

VisualBasic的RND()函数有一个重要的特征:当RND()的参数(我们称这里可以称它为种子)为负值时,同一种子(负值)产生同一个随机数序列。同时VisualBasic还具有强大的二进制技术功能,这样我们可以按以下思路实现文件内容加密:
  X=RND(-KEY)'KEY为正数
  VAULE=INT(256*RND)'产生一个随机数(以此为密码)
  OpenFILENAME$ForBinaryAs#FILENUM'打开文件
  Get#FILENUM,I,A'取文件内容
  B=AXORVAULE'得到加密文件
  
  结合
  C=BXORVAULE'得到解密文件(B为加密后文件内容)
  
  注意:这里的A非整个文件内容,可以是极少部分、几个字节甚至单个字节,若为单字节,则文件中的每个字节同不同的数异或,破译难度可见有多么大。具体过程:
  SubENDECODE(FILENAME$,MA,FILE2$)'参数为:源文件,密码,目标文件
  DimFILENUMAsInteger,XAsSingle,IAsSingle
  DimCHARNUMAsInteger,RANDOMINTEGERAsInteger
  DimSINGLECHARAsString*1,filen2AsInteger'取单字节
  IfMA0Them
  MA=MA*(-1)
  EndIf
  
  X=Rnd(-MA)'参数为负
  FILENUM=FreeFile
  OpenFILENAME$ForBinaryAs#FILENUM'二进制方式打开源文件
  filen2=FreeFile
  OpenFILE2$ForOutputAs#filen2'以顺序文件打开目标文件
  Fori=1ToLOF(FILENUM)'LOF()文件字节长
  Get#FILENUM,i,SINGLECHAR'取单字节内容
  CHARNUM=Asc(SINGLECHAR)
  RANDOMINTEGER=Int(256*Rnd)'得到字母表
  CHARNUM=CHARNUMXorRANDOMINTEGER'异或
  Print#filen2,Chr$(CHARNUM);'写入目标文件
  NextI
  CloseFILENUM
  Closefilen2
  
  ok'调用成功对话框
  
  EndSub
  
  调用格式:ENDECODE源文件名,密码,目标文件名上面过程可以对任何EXE、COM、文本等文件进行加解密(奇数次加密,偶数次解密),重演性极好,保密性特优,若对上述过程进一步加工,如进行多重随机等手段处理,那么将会更上一层楼,在此不累述。顺便提一下,上面过程若对目标文件同样以二进制文件打开、写入,那么只能对纯西文文本进行加解密,对于纯中文文本则通过修改取双字节、I的步长为2来实现,其它(中西文结合文本、EXE、COM等文件)则将得不到预期结果,其原因可以能是ASCII大于127的字符,不能正常显示,不能用put语句正常写入文件(得到的只是空格),有兴趣者不妨一试。->

来源:https://www.tulaoshi.com/n/20160219/1612305.html

延伸阅读
Oracle 9i提供了很多函数可以用来辅助数据查询。接下来我们介绍常用的函数功能及使用方法。 4.5.1 函数 在输入select mgr, mgr/100,ceil(mgr/100) from scott.emp;,然后单击按钮,出现如图4.29所示的结果。 :\第4章\4.5\451.sql。 函数用法:ceil(n),取大于等于数值n的最小整数。 4.5.2 函数 在输入s...
如果对MSSQL的用户信息有兴趣的,可能会发现master.dbo.sysxlogins里面存放着用户的口令,可是呢,password字段如果不是null就是一堆看不懂的binary,这个口令是怎么加密的呢? 其实只要仔细看看master.dbo.sp_addlogin就知道了,MSSQL的sp都可以看到代码,真是不错。 让我们来看看它是怎么做的,注意这一行select @passwd ...
标签: SQLServer
Microsoft SQL Server是如何加密口令的?如何自制未公开的加密函数? 如果对MSSQL的用户信息有兴趣的,可能会发现master.dbo.sysxlogins里面存放着用户的口令,可是呢,password字段如果不是null就是一堆看不懂的binary,这个口令是怎么加密的呢? 其实只要仔细看看master.dbo.sp_addlogin就知道了,MSSQL的sp都可以看到代码,真是不...
标签: excel
excel减法函数怎么用   excel减法函数怎么用 很多朋友都需要用Excel来对数据进行减法运算,那么具体怎么操作呢。 excel减法函数怎么用 比如我们要计算每一行的A列数据减去B列数据的值,并把该差值放在C列。 首先在"C1"单元格里输入公式"=A1-B1"(不要引号),然后回车(即按键盘上"Enter&q...
标签: ASP
  以下是代码: <% on error resume next   Dim objXMLHTTP, xml   Set xml = Server.CreateObject("Microsoft.XMLHTTP")   xml.Open "GET", "http://chanye.finance.sina.com.cn/yj/2005-01-05/236914.shtml", False   xml.Send   tmpstr= xml.responseText   ep=clng(instr(1,tmpstr,"meta_data2"))...

经验教程

695

收藏

40
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部