将以字符串格式表示的GUID转换为Base64的Javascript方法

10
我在客户端,JavaScript环境下。我有一个字符串格式的GUID“e8b75aff-3422-4529-8a6a-15b33e674f48”,需要将其转换为Base64字符串“/1q36CI0KUWKahWzPmdPSA==”。该怎么做? 谢谢。

可能是重复的问题:如何使用Javascript进行Base64编码? - Felix Kling
1
可能是重复的问题,链接为https://dev59.com/_HVC5IYBdhLWcg3wlyIo。 - dexter
这个怎么样:https://dev59.com/8EvSa4cB1Zd3GeqPdU17 - mplungjan
要将GUID转换为base64,我们需要先将GUID转换为十六进制表示,然后再转换为base64。 - David
1个回答

15

// Convert GUID string to Base-64 in Javascript
// by Mark Seecof, 2012-03-31

var hexlist = '0123456789abcdef';
var b64list = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';

// GUID string with four dashes is always MSB first,
// but base-64 GUID's vary by target-system endian-ness.
// Little-endian systems are far more common.  Set le==true
// when target system is little-endian (e.g., x86 machine).
//
function guid_to_base64(g, le) {
    var s = g.replace(/[^0-9a-f]/ig, '').toLowerCase();
    if (s.length != 32) return '';

    if (le) s = s.slice(6, 8) + s.slice(4, 6) + s.slice(2, 4) + s.slice(0, 2) +
      s.slice(10, 12) + s.slice(8, 10) +
      s.slice(14, 16) + s.slice(12, 14) +
      s.slice(16);
    s += '0';

    var a, p, q;
    var r = '';
    var i = 0;
    while (i < 33) {
      a = (hexlist.indexOf(s.charAt(i++)) << 8) |
        (hexlist.indexOf(s.charAt(i++)) << 4) |
        (hexlist.indexOf(s.charAt(i++)));

      p = a >> 6;
      q = a & 63;

      r += b64list.charAt(p) + b64list.charAt(q);
    }
    r += '==';

    return r;
  } // guid_to_base64()

//EDIT
function tryConversion() {
  document.getElementById("result").innerText = guid_to_base64(
    document.getElementById("input_guid").value,
    document.getElementById("cb_le").checked
  );
}
input[type=text] {
  font-family: monospace;
  font-size: 12px;
  width: 270px;
}
<div><label for="input_guid">GUID</label> <input type="text" maxlength="36" id="input_guid" value="83D95782-BDE4-466F-A490-46820D2B2CDC" />
</div>
<div><label for="cb_le">Little-Endian?</label> <input type="checkbox" id="cb_le" checked="checked" /></div>
<hr />
<div><button onclick="javascript:tryConversion()">Convert</button></div>
<div>Result: <span id="result"></span></div>


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接