简单加解密算法 - vb.net
Public Class Form1
Dim charAarray() As Char
'加密
Private Sub Btn_En_Click(sender As System.Object, e As System.EventArgs) Handles Btn_En.Click
Dim s As String
Dim result As Boolean
result = EncryptOrDecrypt(Txt_PlainText_1.Text, Txt_Secrect_Key.Text, 1, s)
Txt_Text_1.Text = s
MessageBox.Show(IIf(result, "Success", "Failure"))
End Sub
'解密
Private Sub Btn_De_Click(sender As System.Object, e As System.EventArgs) Handles Btn_De.Click
Dim s As String
Dim result As Boolean
result = EncryptOrDecrypt(Txt_Text_2.Text, Txt_Secrect_Key.Text, -1, s)
Txt_PlainText_2.Text = s
MessageBox.Show(IIf(result, "Success", "Failure"))
End Sub
'加解密字符串
'str为待加密的字符串
'secretKey为秘钥
'f为加解密标示,f=1标示加密,f=-1标示解密
'outputStr为加解密之后的字符串
'返回操作结果
Function EncryptOrDecrypt(ByVal str As String, ByVal secretKey As Integer, ByVal f As Integer, ByRef outputStr As String) As Boolean
outputStr = ""
If (String.IsNullOrWhiteSpace(str)) Then
Return False
End If
Dim c As Char
For i As Integer = 0 To str.Length - 1
c = str(i)
c = EncryptChar(c, secretKey, f)
outputStr &= c
Next i
Return True
End Function
Private Sub Form1_Load(sender As System.Object, e As System.EventArgs) Handles MyBase.Load
charAarray = CreateCharArray()
MessageBox.Show("OK")
End Sub
Function CreateCharArray() As System.Array
Dim s As String = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_"
Dim rnd As New Random
Dim cArray(s.Length - 1) As Char
Dim index As Integer
Dim i As Integer
i = 0
Do
index = rnd.Next(s.Length)
If Not cArray.Contains(s(index)) Then
cArray(i) = s(index)
i += 1
End If
Loop While (i < s.Length)
Return cArray
End Function
'加密单个字符
'c为要加密的字符
'secretKey为秘钥
'f为加解密标示,f=1标示加密,f=-1标示解密
'返回加密之后的字符
Function EncryptChar(ByVal c As Char, ByVal secretKey As Integer, ByVal f As Integer) As Char
Dim cIndex As Integer
Dim len As Integer
len = charAarray.Length
cIndex = Array.IndexOf(charAarray, c)
If f = 1 Then
cIndex += secretKey
Else
cIndex -= secretKey
End If
If (cIndex >= len) Then
Math.DivRem(cIndex, len, cIndex)
End If
If (cIndex < 0) Then
Do
cIndex += len
Loop While (cIndex < 0)
End If
Return charAarray(cIndex)
End Function
End Class
简单加解密算法 - vb.net的更多相关文章
- DES加解密算法Qt实现
算法解密qt加密table64bit [声明] (1) 本文源码 大部分源码来自:DES算法代码.在此基础上,利用Qt编程进行了改写,实现了DES加解密算法,并添加了文件加解密功能.在此对署名为b ...
- AES加解密算法Qt实现
[声明] (1) 本文源码 在一位未署名网友源码基础上,利用Qt编程,实现了AES加解密算法,并添加了文件加解密功能.在此表示感谢!该源码仅供学习交流,请勿用于商业目的. (2) 图片及描述 除图1外 ...
- C#加解密算法
先附上源码 加密解密算法目前已经应用到我们生活中的各个方面 加密用于达到以下目的: 保密性:帮助保护用户的标识或数据不被读取. 数据完整性:帮助保护数据不被更改. 身份验证:确保数据发自特定的一方. ...
- 3des加解密算法
编号:1003时间:2016年4月1日09:51:11功能:openssl_3des加解密算法http://blog.csdn.net/alonesword/article/details/17385 ...
- QQ协议的TEA加解密算法
QQ通讯协议里的加解密算法. #include <stdio.h> #include <stdlib.h> #include <memory.h> #include ...
- AES加解密算法在Android中的应用及Android4.2以上版本调用问题
from://http://blog.csdn.net/xinzheng_wang/article/details/9159969 AES加解密算法在Android中的应用及Android4.2以上 ...
- [转]RSA,DSA等加解密算法介绍
From : http://blog.sina.com.cn/s/blog_a9303fd90101cgw4.html 1) MD5/SHA MessageDigest是一个数据的数字指纹. ...
- JavaScript与C#互通的DES加解密算法
原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DE ...
- C# 中使用 RSA加解密算法
一.什么是RSA RSA公开密钥密码体制.所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥,是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体制. 在公开密钥密码体制中,加密密钥(即 ...
随机推荐
- json转义字符串
json前台写数据 @RequestMapping("/addUserJson") public void addUserJson(User user,HttpServletReq ...
- ADO。net学习笔记
来源于网络 1. SqlConnection(DBConnection) 建立程序与数据库的链接 链接字符串有两种形式: //使用Windows验证 SSPI(安全支持提供程序接口) ...
- Polipo
polipo代理服务器简介 HTTP代理polipo的配置与使用:http://wuwei5460.blog.51cto.com/2893867/1407369/
- ARC下需要注意的内存管理
ARC下需要注意的内存管理 2016/04/03 · iOS开发 · 内存管理 分享到:1 原文出处: 一不(@luoyibu) 之前发了一篇关于图片加载优化的文章,还是引起很多人关注的,不过也 ...
- 通过 File API 使用 JavaScript 读取文件
原文地址:http://www.html5rocks.com/zh/tutorials/file/dndfiles/ 简介 HTML5 终于为我们提供了一种通过 File API 规范与本地文件交互的 ...
- (简单) HDU 3397 Sequence operation,线段树+区间合并。
Problem Description lxhgww got a sequence contains n characters which are all '0's or '1's. We have ...
- HDU 3264 Open-air shopping malls ——(二分+圆交)
纯粹是为了改进牛吃草里的两圆交模板= =. 代码如下: #include <stdio.h> #include <algorithm> #include <string. ...
- VMWare虚拟机启动报错物理内存不足
尝试了三种修改 1.说是微软补丁KB2995388冲突-->>失败 2.修改win8.1高级环境性能更改设置-->>失败 3.修改config.ini文件-->>成 ...
- webgl 网站demo
网络上的一些经典的WebGL资源网站和WebGL开源引擎整理 http://www.babylonjs.com/ http://threejs.org/ http://www.finalmesh.co ...
- linux系统安装iprouter
在上文中将mpls编译进了linux内核,现在需要安装iprouter,安装过程如下: 1) 下载两个文件iproute2-2.6.39.tar.gz和iproute2-v2.6.39-mpls.pa ...