Foxtable(狐表)用户栏目专家坐堂 → [求助]狐表引用vb.net编写DEC加密解密程序?


  共有6072人关注过本帖树形打印复制链接

主题:[求助]狐表引用vb.net编写DEC加密解密程序?

帅哥哟,离线,有人找我吗?
浙江仔
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1326 积分:9603 威望:0 精华:1 注册:2010/7/21 14:20:00
[求助]狐表引用vb.net编写DEC加密解密程序?  发帖心情 Post By:2013/11/11 8:50:00 [只看该作者]

网上找到这么一个加密解密的方法,不知道怎么转换到狐表中来,再次求助,谢谢帮忙:

在vb.NET中编写DEC加密程序 ,因为vb.NET的类库中就自带了相应的函数,下面分别是加密函数和解密函数。
  加密函数:

  Public Shared Function Encrypt(ByVal pToEncrypt As String, ByVal sKey As String) As String

  Dim DES As New DESCryptoServiceProvider()

  Dim inputByteArray() As Byte

  inputByteArray = Encoding.Default.GetBytes(pToEncrypt)

  ''建立加密对象的密钥和偏移量

  ''原文使用ASCIIEncoding.ASCII方法的GetBytes方法

  ''使得输入密码必须输入英文文本

  DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)

  DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)

  ''写二进制数组到加密流

  ''(把内存流中的内容全部写入)

  Dim ms As New System.IO.MemoryStream()

  Dim cs As New CryptoStream(ms, DES.CreateEncryptor, CryptoStreamMode.Write)

  ''写二进制数组到加密流

  ''(把内存流中的内容全部写入)

  cs.Write(inputByteArray, 0, inputByteArray.Length)

  cs.FlushFinalBlock()

  ''建立输出字符串

  Dim ret As New StringBuilder()

  Dim b As Byte

  For Each b In ms.ToArray()

  ret.AppendFormat("", b)

  Next

  Return ret.ToString()

  End Function

------------------------------------------------------------------

  解密函数:

  Public Shared Function Decrypt(ByVal pToDecrypt As String, ByVal sKey As String) As String

  Dim DES As New DESCryptoServiceProvider()

  ''把字符串放入byte数组

  Dim len As Integer

  len = pToDecrypt.Length / 2 - 1

  Dim inputByteArray(len) As Byte

  Dim x, i As Integer

  For x = 0 To len

  i = Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16)

  inputByteArray(x) = CType(i, Byte)

  Next

  ''建立加密对象的密钥和偏移量,此值重要,不能修改

  DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)

  DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)

  Dim ms As New System.IO.MemoryStream()

  Dim cs As New CryptoStream(ms, DES.CreateDecryptor, CryptoStreamMode.Write)

  cs.Write(inputByteArray, 0, inputByteArray.Length)

  cs.FlushFinalBlock()

  Return Encoding.Default.GetString(ms.ToArray)

  End Function

-------------------------------------------

  两个函数中第一个参数是待加密或解密的字符串,sKey是使用的密钥,必须是8位,使用的时候要注意哦,不然会出错的。

 

dll文件:

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:mscorlib.zip


 回到顶部
帅哥哟,离线,有人找我吗?
浙江仔
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1326 积分:9603 威望:0 精华:1 注册:2010/7/21 14:20:00
  发帖心情 Post By:2013/11/11 10:10:00 [只看该作者]

人工置顶

 回到顶部
帅哥,在线噢!
狐狸爸爸
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251397 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/11/11 10:10:00 [只看该作者]

1、添加命名空间,空间缩写为sur, sur可以随便取,但是要和代码保持一致:

 

 
图片点击可在新窗口打开查看此主题相关图片如下:001.jpg
图片点击可在新窗口打开查看

 

2、将下面的修改后的代码复制到foxtable的全局代码中,注意加粗的:

 

Public Function Encrypt(ByVal pToEncrypt As String, ByVal sKey As String) As String
Dim DES As New sur.DESCryptoServiceProvider()
Dim inputByteArray() As Byte
inputByteArray = Encoding.Default.GetBytes(pToEncrypt)
''建立加密对象的密钥和偏移量
''原文使用ASCIIEncoding.ASCII方法的GetBytes方法
''使得输入密码必须输入英文文本
DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)
DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)
''写二进制数组到加密流
''(把内存流中的内容全部写入)
Dim ms As New System.IO.MemoryStream()
Dim cs As New sur.CryptoStream(ms, DES.CreateEncryptor, sur.CryptoStreamMode.Write)
''写二进制数组到加密流
''(把内存流中的内容全部写入)
cs.Write(inputByteArray, 0, inputByteArray.Length)
cs.FlushFinalBlock()
''建立输出字符串
Dim ret As New StringBuilder()
Dim b As Byte
For Each b In ms.ToArray()
    ret.AppendFormat("", b)
Next
Return ret.ToString()
End Function


Public Function Decrypt(ByVal pToDecrypt As String, ByVal sKey As String) As String
  Dim DES As New sur.DESCryptoServiceProvider()
  ''把字符串放入byte数组
  Dim len As Integer
  len = pToDecrypt.Length / 2 - 1
  Dim inputByteArray(len) As Byte
  Dim x, i As Integer
  For x = 0 To len
  i = Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16)
  inputByteArray(x) = CType(i, Byte)
  Next
  ''建立加密对象的密钥和偏移量,此值重要,不能修改
  DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)
  DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)
  Dim ms As New System.IO.MemoryStream()
  Dim cs As New sur.CryptoStream(ms, DES.CreateDecryptor, sur.CryptoStreamMode.Write)
  cs.Write(inputByteArray, 0, inputByteArray.Length)
  cs.FlushFinalBlock()
  Return Encoding.Default.GetString(ms.ToArray)
End Function


 


 回到顶部
帅哥,在线噢!
狐狸爸爸
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251397 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/11/11 10:11:00 [只看该作者]

所以vb.net的代码其实可以直接在foxtable用的,只是命名空间

 回到顶部
帅哥哟,离线,有人找我吗?
浙江仔
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1326 积分:9603 威望:0 精华:1 注册:2010/7/21 14:20:00
  发帖心情 Post By:2013/11/11 14:54:00 [只看该作者]

以下是引用狐狸爸爸在2013-11-11 10:10:00的发言:

1、添加命名空间,空间缩写为sur, sur可以随便取,但是要和代码保持一致:

 

 
图片点击可在新窗口打开查看此主题相关图片如下:001.jpg
图片点击可在新窗口打开查看

 

2、将下面的修改后的代码复制到foxtable的全局代码中,注意加粗的:

 

Public Function Encrypt(ByVal pToEncrypt As String, ByVal sKey As String) As String
Dim DES As New sur.DESCryptoServiceProvider()

.......


 

多谢狐爸,给了这么易懂的范本。

System.Security.Cryptography命名空间直接可以用的啊,我还以为还要添加外部引用。

 

但是程序设置好后,加密解密不起作用,不知道是不是本人设置不当,还望指点。谢谢

 下载信息  [文件大小:   下载次数: ]
点击浏览该文件:dec数据加密解密.table


 回到顶部
帅哥哟,离线,有人找我吗?
浙江仔
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1326 积分:9603 威望:0 精华:1 注册:2010/7/21 14:20:00
  发帖心情 Post By:2013/11/11 15:29:00 [只看该作者]

找到原因了,原来是一个代码问题,红色:

'加密
Public Function Encrypt(ByVal pToEncrypt As String, ByVal sKey As String) As String
Dim DES As New sur.DESCryptoServiceProvider()
Dim inputByteArray() As Byte
inputByteArray = Encoding.Default.GetBytes(pToEncrypt)
''建立加密对象的密钥和偏移量
''原文使用ASCIIEncoding.ASCII方法的GetBytes方法
''使得输入密码必须输入英文文本
DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)
DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)
''写二进制数组到加密流
''(把内存流中的内容全部写入)
Dim ms As New System.IO.MemoryStream()
Dim cs As New sur.CryptoStream(ms, DES.CreateEncryptor, sur.CryptoStreamMode.Write)
''写二进制数组到加密流
''(把内存流中的内容全部写入)
cs.Write(inputByteArray, 0, inputByteArray.Length)
cs.FlushFinalBlock()
''建立输出字符串
Dim ret As New StringBuilder()
Dim b As Byte
For Each b In ms.ToArray()
    ret.AppendFormat("{0:X2}", b)
Next
Return ret.ToString()
End Function

'解密
Public Function Decrypt(ByVal pToDecrypt As String, ByVal sKey As String) As String
Dim DES As New sur.DESCryptoServiceProvider()
''把字符串放入byte数组
Dim len As Integer
len = pToDecrypt.Length / 2 - 1
Dim inputByteArray(len) As Byte
Dim x, i As Integer
For x = 0 To len
    i = Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16)
    inputByteArray(x) = CType(i, Byte)
Next
''建立加密对象的密钥和偏移量,此值重要,不能修改
DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey)
DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey)
Dim ms As New System.IO.MemoryStream()
Dim cs As New sur.CryptoStream(ms, DES.CreateDecryptor, sur.CryptoStreamMode.Write)
cs.Write(inputByteArray, 0, inputByteArray.Length)
cs.FlushFinalBlock()
Return Encoding.Default.GetString(ms.ToArray)
End Function

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:dec数据加密解密.table

[此贴子已经被作者于2013-11-11 15:45:55编辑过]

 回到顶部