什么是C#的HttpServerUtility.UrlTokenDecode的JavaScript等价物?

时间:2015-08-18 08:18:09

标签: javascript httpserverutility

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=

4 个答案:

答案 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);
}

Source

答案 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.UrlTokenEncodeHttpServerUtility.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="