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

标签:字符串,加密函数,加密
0
投稿

猜你喜欢

  • 无法通过Google网站管理工具验证的部分情况解决办法

    2009-07-28 12:56:00
  • 用正则表达式找出不包含连续字符串abc的单词

    2010-03-02 20:28:00
  • 关于JS中变量的显式申明和隐式申明

    2008-09-12 13:04:00
  • 此数据库没有有效所有者,因此无法安装数据库关系图支持对象

    2012-01-29 18:15:11
  • 分面搜索(Faceted Search)

    2009-07-31 12:44:00
  • fso怎样判断一个盘上是否有文件

    2007-09-26 12:35:00
  • asp如何实现歌曲在线点播?

    2010-05-19 21:32:00
  • MySQL数据库的其它安全问题

    2008-12-23 15:40:00
  • 走中国特色的网站重构道路

    2010-04-08 16:10:00
  • Javascript学习第一季 二

    2008-06-24 18:20:00
  • MySQL数据库备份的基础知识大全

    2009-12-20 18:14:00
  • Oracle下时间转换在几种语言中的实现

    2009-02-28 11:09:00
  • 5个常见的XHTML验证错误

    2010-01-15 20:24:00
  • Web 标准设计实践:Google 的首页

    2008-10-12 12:14:00
  • 查询字符串中包含特殊字符的问题

    2009-01-09 13:13:00
  • MSXML2家族探秘

    2008-03-03 12:35:00
  • CSS 3入门

    2009-04-19 13:00:00
  • mysql3升级到mysql5解决乱码心得

    2009-04-20 14:41:00
  • asp利用XmlHttp和Adodb.Stream采集图片

    2007-12-06 18:42:00
  • 可以输入的下拉菜单

    2009-01-04 14:21:00
  • asp之家 网络编程 m.aspxhome.com