forked from cdhigh/Vb6Tkinter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBase64.bas
99 lines (81 loc) · 3.35 KB
/
Base64.bas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
Attribute VB_Name = "Base64"
'BASE64编码模块
Option Explicit
'外部直接调用此函数即可
Public Sub Base64Encode(ByRef pbAInput() As Byte, ByRef sOut As String, Optional ByRef sPrexSpace As String = "", Optional ByRef charsPerLine As Integer = 68)
Dim abOut() As Byte, idx As Long, sBase64 As String
Dim lengthMod As Integer
Dim paddingCount As Integer
Encode pbAInput, abOut
ByteArrayToString abOut, sBase64
sOut = ""
If Len(sBase64) = 0 Then Exit Sub
'Base64要求长度为4的倍数,如果不够,则添加"="
lengthMod = Len(sBase64) Mod 4
paddingCount = 4 - lengthMod
sBase64 = sBase64 & String(paddingCount, "=")
'转换为合适的换行模式
If charsPerLine > 0 Then
For idx = 1 To Len(sBase64) Step charsPerLine
sOut = sOut & sPrexSpace & Mid(sBase64, idx, charsPerLine) & vbCrLf
Next
sOut = Mid(sOut, 1, Len(sOut) - 3) '去掉上面语句添加的最后的回车换行
Else
sOut = sBase64
End If
End Sub
Public Sub ByteArrayToString(ByRef pbArrayInput() As Byte, ByRef strOut As String)
strOut = StrConv(pbArrayInput, vbUnicode)
End Sub
Public Sub Encode(ByRef pbArrayInput() As Byte, ByRef pbArrayOutput() As Byte)
Dim iSizeMod As Integer, lSizeIn As Long, lSizeOut As Long, Index As Long
Dim lIndex2 As Long, lTotal As Long, bBuffer(2) As Byte
Dim mvB64Enc(63) As Byte
Dim iIndex As Integer
For iIndex = 65 To 90
mvB64Enc(iIndex - 65) = iIndex
Next
For iIndex = 97 To 122
mvB64Enc(iIndex - 71) = iIndex
Next
For iIndex = 48 To 57
mvB64Enc(iIndex + 4) = iIndex
Next
mvB64Enc(62) = 43
mvB64Enc(63) = 47
lSizeIn = UBound(pbArrayInput) + 1
iSizeMod = lSizeIn Mod 3
lSizeOut = ((lSizeIn - iSizeMod) \ 3) * 4
If iSizeMod > 0 Then lSizeOut = lSizeOut + 4
ReDim pbArrayOutput(lSizeOut - 1)
If lSizeIn >= 3 Then
lTotal = lSizeIn - iSizeMod - 1
For Index = 0 To lTotal Step 3
bBuffer(0) = pbArrayInput(Index)
bBuffer(1) = pbArrayInput(Index + 1)
bBuffer(2) = pbArrayInput(Index + 2)
pbArrayOutput(lIndex2) = mvB64Enc((bBuffer(0) And &HFC) \ 4)
pbArrayOutput(lIndex2 + 1) = mvB64Enc((bBuffer(0) And &H3) * 16 Or (bBuffer(1) And &HF0) \ 16)
pbArrayOutput(lIndex2 + 2) = mvB64Enc((bBuffer(1) And &HF) * 4 Or (bBuffer(2) And &HC0) \ 64)
pbArrayOutput(lIndex2 + 3) = mvB64Enc((bBuffer(2) And &H3F))
lIndex2 = lIndex2 + 4
Next
End If
Select Case iSizeMod
Case 1
bBuffer(0) = pbArrayInput(lSizeIn - 1)
bBuffer(1) = 0
pbArrayOutput(lIndex2) = mvB64Enc((bBuffer(0) And &HFC) \ 4)
pbArrayOutput(lIndex2 + 1) = mvB64Enc((bBuffer(0) And &H3) * 16 Or (bBuffer(1) And &HF0) \ 16)
pbArrayOutput(lIndex2 + 2) = 61
pbArrayOutput(lIndex2 + 3) = 61
Case 2
bBuffer(0) = pbArrayInput(lSizeIn - 2)
bBuffer(1) = pbArrayInput(lSizeIn - 1)
bBuffer(2) = 0
pbArrayOutput(lIndex2) = mvB64Enc((bBuffer(0) And &HFC) \ 4)
pbArrayOutput(lIndex2 + 1) = mvB64Enc((bBuffer(0) And &H3) * 16 Or (bBuffer(1) And &HF0) \ 16)
pbArrayOutput(lIndex2 + 2) = mvB64Enc((bBuffer(1) And &HF) * 4 Or (bBuffer(2) And &HC0) \ 64)
pbArrayOutput(lIndex2 + 3) = 61
End Select
End Sub