asp简单可逆运算字符串加密解密函数
作者:雨哲 时间:2010-05-04 16:42:00
前段时间在开发雨哲树网程序的时候,遇到需要转换地址中的参数,需要用到简单可逆运算的加密功能。在网上找了很多都不理想。
因为我需要的这个可逆运算的加密功能,要能实现一对一的转换加密,就是原来是一个字符串,加密后还是一个字符串。
这样才能达到我需要的效果。没找到现成的没办法,只得自己动手做了呵。
这个加密转换的原理很简单,就是按照指定的规则进行位数加1替换。这里我命名为“位数加1替换法”。
下面列出具体函数代码:
Function YuZhe_EnText(StrText, EnType, ListEnText)
'EnType 0-加密 1-解密
'ListEnText 加密转换规则,请填写1-9a-z之前不重复数字和字母。按照规则,位数加1替换,如果规则中未涉及的字符将显示原字符。例规则为“321a456”,那么原字符串“1c2a3b”转换后就为ac142b
'本函数代码由雨哲[http://www.yz81.com]原创,转载或使用请保留本信息
If StrText = "" or IsNull(StrText) Then
YuZhe_EnText = StrText
Exit Function
End If
Dim StrEnText, IsShowText, iEnText, MidEnText
Dim iListEnText, MidListEnText, LenListEnText, GetTextLen
If ListEnText = "" Then '默认加密转换规则
ListEnText = "q0nc9w8edaoiuk2mzrfy3xt1p5ls67g4bvhj"
End If
StrEnText = ""
LenListEnText = Len(ListEnText)
For iEnText = 1 To Len(StrText)
MidEnText = LCase(Mid(StrText,iEnText,1))
IsShowText = False
For iListEnText = 1 To LenListEnText
MidListEnText = LCase(Mid(ListEnText,iListEnText,1))
If MidEnText = MidListEnText Then
IsShowText = True
GetTextLen = 0
If EnType = 0 Then'加密
If iListEnText = LenListEnText Then
GetTextLen = 1
Else
GetTextLen = iListEnText + 1
End If
Else'解密
If iListEnText = 1 Then
GetTextLen = LenListEnText
Else
GetTextLen = iListEnText - 1
End If
End If
StrEnText = Mid(ListEnText,GetTextLen,1) & StrEnText
Exit For
End If
Next
If IsShowText = False Then
StrEnText = MidEnText & StrEnText
End If
Next
YuZhe_EnText = StrEnText
End Function
参数说明:
StrText - 原字符串,即需要加密转换的字符
EnType - 类型,0-加密 1-解密。也就是一个可逆操作。如果先使用1,那么解密就使用0。
ListEnText - 加密转换规则,请填写1-9a-z不重复数字和字母。按照这里填写的规则位数加1替换。因为我只需要用到数字和字母,所以只是测试了数字和字母,至于中文能否使用,可以测试一下。
示例说明:
原字字符串:159863247
加密转换规则:973614285
加密转换过程:加1替换。9换7,7换3,3换6,6换1,1换4,4换2,2换8,8换5,5换9
调用函数:<%=YuZhe_EnText("159863247", 0, "973614285")%>
加密后结果:497516823
加密后字符串:497516823
解密转换规则:973614285
解密转换过程:减1替换。9换5,7换9,3换7,6换3,1换6,4换1,2换4,8换2,5换8
调用函数:<%=YuZhe_EnText("497516823", 1, "973614285")%>
解密后结果:159863247