公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

asp/vbscript版Base64函數(shù)/Base64編碼Base64encode解碼Base64

admin
2011年12月22日 15:29 本文熱度 3706
'**************************************************************
' Software name: PowerEasy SiteWeaver
' Web: http://www.powereasy.net
' Copyright (C) 2005-2008 佛山市動(dòng)易網(wǎng)絡(luò)科技有限公司 版權(quán)所有
'**************************************************************

Const BASE_64_CHARACTERS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
Private sBASE_64_CHARACTERS


Public Function Base64encode(ByVal asContents)
asContents = strUnicode2Ansi(asContents)


Dim lnPosition
Dim lsResult
Dim Char1
Dim Char2
Dim Char3
Dim Char4
Dim Byte1
Dim Byte2
Dim Byte3
Dim SaveBits1
Dim SaveBits2
Dim lsGroupBinary
Dim lsGroup64
Dim M4, len1, len2


len1 = LenB(asContents)
If len1 < 1 Then
Base64encode = ""
Exit Function
End If


M4 = len1 Mod 3
If M4 > 0 Then asContents = asContents & String(3 - M4, Chr(0))
'補(bǔ)足位數(shù)是為了便于計(jì)算


If M4 > 0 Then
len1 = len1 + (3 - M4)
len2 = len1 - 3
Else
len2 = len1
End If


lsResult = ""
sBASE_64_CHARACTERS = strUnicode2Ansi(BASE_64_CHARACTERS)


For lnPosition = 1 To len2 Step 3
lsGroup64 = ""
lsGroupBinary = MidB(asContents, lnPosition, 3)


Byte1 = AscB(MidB(lsGroupBinary, 1, 1)): SaveBits1 = Byte1 And 3
Byte2 = AscB(MidB(lsGroupBinary, 2, 1)): SaveBits2 = Byte2 And 15
Byte3 = AscB(MidB(lsGroupBinary, 3, 1))


Char1 = MidB(sBASE_64_CHARACTERS, ((Byte1 And 252) \ 4) + 1, 1)
Char2 = MidB(sBASE_64_CHARACTERS, (((Byte2 And 240) \ 16) Or (SaveBits1 * 16) And &HFF) + 1, 1)
Char3 = MidB(sBASE_64_CHARACTERS, (((Byte3 And 192) \ 64) Or (SaveBits2 * 4) And &HFF) + 1, 1)
Char4 = MidB(sBASE_64_CHARACTERS, (Byte3 And 63) + 1, 1)
lsGroup64 = Char1 & Char2 & Char3 & Char4


lsResult = lsResult & lsGroup64
Next


'處理最后剩余的幾個(gè)字符
If M4 > 0 Then
lsGroup64 = ""
lsGroupBinary = MidB(asContents, len2 + 1, 3)


Byte1 = AscB(MidB(lsGroupBinary, 1, 1)): SaveBits1 = Byte1 And 3
Byte2 = AscB(MidB(lsGroupBinary, 2, 1)): SaveBits2 = Byte2 And 15
Byte3 = AscB(MidB(lsGroupBinary, 3, 1))


Char1 = MidB(sBASE_64_CHARACTERS, ((Byte1 And 252) \ 4) + 1, 1)
Char2 = MidB(sBASE_64_CHARACTERS, (((Byte2 And 240) \ 16) Or (SaveBits1 * 16) And &HFF) + 1, 1)
Char3 = MidB(sBASE_64_CHARACTERS, (((Byte3 And 192) \ 64) Or (SaveBits2 * 4) And &HFF) + 1, 1)


If M4 = 1 Then
lsGroup64 = Char1 & Char2 & ChrB(61) & ChrB(61) '用=號(hào)補(bǔ)足位數(shù)
Else
lsGroup64 = Char1 & Char2 & Char3 & ChrB(61) '用=號(hào)補(bǔ)足位數(shù)
End If


lsResult = lsResult & lsGroup64
End If


Base64encode = strAnsi2Unicode(lsResult)


End Function


Public Function Base64decode(ByVal asContents)
asContents = strUnicode2Ansi(asContents)


Dim lsResult
Dim lnPosition
Dim lsGroup64, lsGroupBinary
Dim Char1, Char2, Char3, Char4
Dim Byte1, Byte2, Byte3
Dim M4, len1, len2


len1 = LenB(asContents)
M4 = len1 Mod 4


If len1 < 1 Or M4 > 0 Then
'字符串長(zhǎng)度應(yīng)當(dāng)是4的倍數(shù)
Base64decode = ""
Exit Function
End If


'判斷最后一位是不是 = 號(hào)
'判斷倒數(shù)第二位是不是 = 號(hào)
'這里m4表示最后剩余的需要單獨(dú)處理的字符個(gè)數(shù)
If MidB(asContents, len1, 1) = ChrB(61) Then M4 = 3
If MidB(asContents, len1 - 1, 1) = ChrB(61) Then M4 = 2


If M4 = 0 Then
len2 = len1
Else
len2 = len1 - 4
End If


sBASE_64_CHARACTERS = strUnicode2Ansi(BASE_64_CHARACTERS)


For lnPosition = 1 To len2 Step 4
lsGroupBinary = ""
lsGroup64 = MidB(asContents, lnPosition, 4)
Char1 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 1, 1)) - 1
Char2 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 2, 1)) - 1
Char3 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 3, 1)) - 1
Char4 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 4, 1)) - 1
Byte1 = ChrB(((Char2 And 48) \ 16) Or (Char1 * 4) And &HFF)
Byte2 = lsGroupBinary & ChrB(((Char3 And 60) \ 4) Or (Char2 * 16) And &HFF)
Byte3 = ChrB((((Char3 And 3) * 64) And &HFF) Or (Char4 And 63))
lsGroupBinary = Byte1 & Byte2 & Byte3


lsResult = lsResult & lsGroupBinary
Next


'處理最后剩余的幾個(gè)字符
If M4 > 0 Then
lsGroupBinary = ""
lsGroup64 = MidB(asContents, len2 + 1, M4) & ChrB(65) 'chr(65)=A,轉(zhuǎn)換成值為0
If M4 = 2 Then '補(bǔ)足4位,是為了便于計(jì)算
lsGroup64 = lsGroup64 & ChrB(65)
End If
Char1 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 1, 1)) - 1
Char2 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 2, 1)) - 1
Char3 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 3, 1)) - 1
Char4 = InStrB(sBASE_64_CHARACTERS, MidB(lsGroup64, 4, 1)) - 1
Byte1 = ChrB(((Char2 And 48) \ 16) Or (Char1 * 4) And &HFF)
Byte2 = lsGroupBinary & ChrB(((Char3 And 60) \ 4) Or (Char2 * 16) And &HFF)
Byte3 = ChrB((((Char3 And 3) * 64) And &HFF) Or (Char4 And 63))


If M4 = 2 Then
lsGroupBinary = Byte1
ElseIf M4 = 3 Then
lsGroupBinary = Byte1 & Byte2
End If


lsResult = lsResult & lsGroupBinary
End If


Base64decode = strAnsi2Unicode(lsResult)


End Function


Private Function strUnicodeLen(ByVal asContents)
'計(jì)算unicode字符串的Ansi編碼的長(zhǎng)度
Dim asContents1
Dim len1
Dim k
Dim i
Dim asc1


asContents1 = "a" & asContents
len1 = Len(asContents1)
k = 0
For i = 1 To len1
asc1 = Asc(Mid(asContents1, i, 1))
If asc1 < 0 Then asc1 = 65536 + asc1
If asc1 > 255 Then
k = k + 2
Else
k = k + 1
End If
Next
strUnicodeLen = k - 1
End Function


Private Function strUnicode2Ansi(ByVal asContents)
'將Unicode編碼的字符串,轉(zhuǎn)換成Ansi編碼的字符串
Dim len1
Dim i
Dim VarChar
Dim varAsc
Dim varHex, varlow, varhigh


strUnicode2Ansi = ""
len1 = Len(asContents)
For i = 1 To len1
VarChar = Mid(asContents, i, 1)
varAsc = Asc(VarChar)
If varAsc < 0 Then varAsc = varAsc + 65536
If varAsc > 255 Then
varHex = Hex(varAsc)
varlow = Left(varHex, 2)
varhigh = Right(varHex, 2)
strUnicode2Ansi = strUnicode2Ansi & ChrB("&H" & varlow) & ChrB("&H" & varhigh)
Else
strUnicode2Ansi = strUnicode2Ansi & ChrB(varAsc)
End If
Next
End Function


Private Function strAnsi2Unicode(asContents)
'將Ansi編碼的字符串,轉(zhuǎn)換成Unicode編碼的字符串
Dim len1
Dim i
Dim VarChar
Dim varAsc


strAnsi2Unicode = ""
len1 = LenB(asContents)
If len1 = 0 Then Exit Function
For i = 1 To len1
VarChar = MidB(asContents, i, 1)
varAsc = AscB(VarChar)
If varAsc > 127 Then
strAnsi2Unicode = strAnsi2Unicode & Chr(AscW(MidB(asContents, i + 1, 1) & VarChar))
i = i + 1
Else
strAnsi2Unicode = strAnsi2Unicode & Chr(varAsc)
End If
Next
End Function


該文章在 2011/12/22 15:29:40 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 福利小视频在线观看 | 国产91白浆在线观看 | 国产午夜亚洲精品无码 | 国产成人精品午夜2025 | 国产精品亚洲日韩aⅴ在线 国产精品亚洲日韩aⅴ在线观看 | a级国产乱午夜理论片在线观看 | 国产午夜不卡av高清 | 操人视频网站 | 怀孕动漫精品国产一区二区三区 | 国产精品欧美亚洲韩国日本不卡 | 国产午夜不卡av免费 | 国产精品无码一区二区在线观看 | 成人免费观看高清视频a斤 成人免费观看国产高清 | 91精品亚洲影视在线观看 | 国产女人喷水视频在线观看 | 国产偷伦视频 | 国产精品一线二线三线区别解析 | 国语久久无码高清 | 国产3p露脸 | 国产高清一区二区三区 | 2025精品国产自在现线看 | 国产做国产爱免费视频 | 91精品丝袜国产高 | 精品视频精品免费 | 国产精品vr无码专区 | 91国产日韩制服在线一区 | 国产三级精品美女三级 | 国产视频一区在线 | 2025国内精品久久久久精免费 | 精品无码成人 | 国产精品酒店在线 | 精品无码一级午夜一区二区 | 国产精品福利在线观看 | 海角乱伦蝌蚪永久甘蔗 | 99久久国产精品人妻无码 | 国产重口调教在线观看 | 国产盗摄一区二区欧美精品 | 国产精品亚洲高清 | 国产肥熟女一区二区三区 | 成人午夜a级毛片免费 | 国产精品va在线观看浪 |