Potrzebuję adresu URL dekodować ciąg znaków w VBScript. Łańcuch może zawierać znaki Unicode, zakodowane jako wiele bajtów zgodnie z UTF-8. Na przykład "Paryż% 20% E2% 86% 92% 20Z% C3% BCrich" zostanie odkodowany na "Paryż → Zurych".Dekodowanie adresu URL zakodowanych ciągów UTF-8 w VBScript
Aby wykonać zadanie, Używam kawałek kodu, który wygląda tak:
Function URLDecode(str)
set list = CreateObject("System.Collections.ArrayList")
strLen = Len(str)
for i = 1 to strLen
sT = mid(str, i, 1)
if sT = "%" then
if i + 2 <= strLen then
list.Add cbyte("&H" & mid(str, i + 1, 2))
i = i + 2
end if
else
list.Add asc(sT)
end if
next
depth = 0
for each by in list.ToArray()
if by and &h80 then
if (by and &h40) = 0 then
if depth = 0 then Err.Raise 5
val = val * 2^6 + (by and &h3f)
depth = depth - 1
if depth = 0 then
sR = sR & chrw(val)
val = 0
end if
elseif (by and &h20) = 0 then
if depth > 0 then Err.Raise 5
val = by and &h1f
depth = 1
elseif (by and &h10) = 0 then
if depth > 0 then Err.Raise 5
val = by and &h0f
depth = 2
else
Err.Raise 5
end if
else
if depth > 0 then Err.Raise 5
sR = sR & chrw(by)
end if
next
if depth > 0 then Err.Raise 5
URLDecode = sR
End Function
To wydaje się działać dobrze, ale wygląda na przesadnie skomplikowane do mnie. W czasach HTML5 i standardów internetowych, musi istnieć prostszy sposób na zrobienie tego bez użycia ręcznie robionych pętli i warunków. Jakieś sugestie?
To jest świetna odpowiedź, dzięki! –
@ ft1 Nie ma za co. –
@ ft1 Zrobiłem poprawkę, pamiętaj, że jeśli użyłeś drugiego rozwiązania. –