在 JavaScript 中,如何解码使用HttpServerUtility.UrlTokenEncode
在C#中编码的字符串?
在其他语言中有一些等价物,但我无法在JS中重写它们。任何帮助将不胜感激。
这是Java版本。
这是Objective-C版本。
C#的URLTokenEncode
与base64编码不同。例如,最后一个字符始终是填充字符的数量。所以有些角色需要正确替换。 Java和Objective-C版本的代码显示哪些字符需要替换为什么。
我尝试了decodeURIComponent
,但未成功解码。这是有道理的,因为字符串是由特定方法编码的。它不是base64。
例如,这只是C#的UrlTokenEncode
字符串的一部分:
vj4_fv7__7-_Pr6-ff3_Pr6_vz8_________________f____79_vP1_vb3_vz8____________________AAA1
这是使用Objective-C / Java方法的正确解码版本:
vj4/fv7//7+/Pr6+ff3/Pr6/vz8/////////////////f////79/vP1/vb3/vz8////////////////////AAA=
答案 0 :(得分:0)
我想那将是decodeuricomponent:
http://www.w3schools.com/jsref/jsref_decodeuricomponent.asp
在JavaScript中解码UTF8-base64编码的字符串:
var str2 = decodeURIComponent(escape(window.atob(b64)));
console.log(str2);
在JavaScript中对UTF8-JavaScript字符串进行编码:
var str = "äöüÄÖÜçéèñ";
var b64 = window.btoa(unescape(encodeURIComponent(str)))
console.log(b64);
似乎UrlTokenDecode有点复杂。
100%确定的最佳方法是使用AJAX在服务器端调用UrlTokenDecode,然后返回一个简单的base64编码字符串。
public static byte[] UrlTokenDecode (string input)
{
if (input == null)
throw new ArgumentNullException ("input");
if (input.Length < 1)
return new byte[0];
byte[] bytes = Encoding.ASCII.GetBytes (input);
int inputLength = input.Length - 1;
int equalsCount = (int)(((char)bytes[inputLength]) - 0x30);
char[] ret = new char[inputLength + equalsCount];
int i = 0;
for (; i < inputLength; i++) {
switch ((char)bytes[i]) {
case '-':
ret[i] = '+';
break;
case '_':
ret[i] = '/';
break;
default:
ret[i] = (char)bytes[i];
break;
}
}
while (equalsCount > 0) {
ret[i++] = '=';
equalsCount--;
}
return Convert.FromBase64CharArray (ret, 0, ret.Length);
}
答案 1 :(得分:0)
我终于设法将URLTokenDecode
的{{3}}转换为Objective-c version到JavaScript并且它有效。
以下是功能:
function URLTokenDecode(token) {
if (token.length == 0) return null;
// The last character in the token is the number of padding characters.
var numberOfPaddingCharacters = token.slice(-1);
// The Base64 string is the token without the last character.
token = token.slice(0, -1);
// '-'s are '+'s and '_'s are '/'s.
token = token.replace(/-/g, '+');
token = token.replace(/_/g, '/');
// Pad the Base64 string out with '='s
for (var i = 0; i < numberOfPaddingCharacters; i++)
token += "=";
return token;
}
如果您使用的是AngularJS,则为$ filter:
app.filter('URLTokenDecode', function () {
return function (token) {
if (token.length == 0) return null;
// The last character in the token is the number of padding characters.
var numberOfPaddingCharacters = token.slice(-1);
// The Base64 string is the token without the last character.
token = token.slice(0, -1);
// '-'s are '+'s and '_'s are '/'s.
token = token.replace(/-/g, '+');
token = token.replace(/_/g, '/');
// Pad the Base64 string out with '='s
for (var i = 0; i < numberOfPaddingCharacters; i++)
token += "=";
return token;
}
});
答案 2 :(得分:0)
这可能违反了发布规则,因为它不是问题的答案,但是,我找到了这个页面,同时寻找UrlTokenEncode
方法(不解码)所以使用这里的信息,我做了以下方法,我希望帮助其他人:
function urlTokenEncode(str) {
var b64 = btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,
function(match, t) {
return String.fromCharCode('0x' + t);
})),
padChars = b64.match(/=/g);
return b64.replace(/=/g, "") + (padChars == null ? 0 : padChars.length);
}
使用C#HttpServerUtility.UrlTokenEncode
和HttpServerUtility.UrlTokenEncode
答案 3 :(得分:-1)
在MDN中阅读这篇描述问题的文章。溶液:
https://developer.mozilla.org/en-US/docs/Web/API/WindowBase64/Base64_encoding_and_decoding
function b64EncodeUnicode(str) {
return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function(match, p1) {
return String.fromCharCode('0x' + p1);
}));
}
b64EncodeUnicode('✓ à la mode'); // "4pyTIMOgIGxhIG1vZGU="