?? enc-dec.frm
字號:
VERSION 5.00
Begin VB.Form Form1
Caption = "加密/解密"
ClientHeight = 1095
ClientLeft = 3915
ClientTop = 3315
ClientWidth = 2190
ControlBox = 0 'False
LinkTopic = "Form1"
MaxButton = 0 'False
MinButton = 0 'False
PaletteMode = 1 'UseZOrder
ScaleHeight = 1095
ScaleWidth = 2190
Begin VB.CommandButton Command1
Caption = "加密/解密"
Height = 495
Left = 480
TabIndex = 0
Top = 360
Width = 1215
End
End
Attribute VB_Name = "Form1"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
'對文件加密
Sub FileEncodeAndDecode(InputFile As String, OutputFile As String, PasswordKey As String)
On Error GoTo err1
Dim temp As Single
Dim Char As String * 1
Dim XORMask As Single
Dim temp1 As Integer
Open InputFile For Binary As #1
Open OutputFile For Binary As #2
'根據(jù)輸入的密碼字符的ASCII碼產(chǎn)生不同的隨機數(shù)種子序列
For x = 1 To Len(PasswordKey)
temp = Asc(Mid$(PasswordKey, x, 1))
For y = 1 To temp
temp1 = Rnd
Next y
Randomize temp1
Next x
Counter = 0
For z = 1 To FileLen(InputFile)
'用隨機數(shù)序列生成加密屏蔽碼
XORMask = Int(Rnd * 256)
'取得被加密字符進行XOR運算,完成加密
Get 1, , Char
Char = Chr$((Asc(Char) Xor XORMask))
Put 2, , Char
Counter = Counter + 1
If Counter > Len(PasswordKey) Then Counter = 1
'跳過部分隨機數(shù)序列
For x = 1 To (Asc(Mid$(PasswordKey, Counter, 1)) * 2)
temp = Rnd
Next x
Next z
Close #1
Close #2
Exit Sub
err1:
MsgBox "打開文件出錯!", vbCritical, , "加密/解密"
End
End Sub
Private Sub Command1_Click()
Dim InputFile As String
Dim OutputFile As String
Dim PasswordKey As String
InputFile = InputBox("輸入需要加密的文件名", "加密/解密")
OutputFile = InputBox("輸入加密后的文件名", "加密/解密")
PasswordKey = InputBox("輸入密碼", "加密/解密")
Call FileEncodeAndDecode(InputFile, OutputFile, PasswordKey)
MsgBox "已寫入文件:" + OutputFile
End
End Sub
Private Sub Form_Load()
Command1.Caption = "加密/解密"
End Sub
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -