Arca base64 autodecoder

Arca.live Base64 auto decoder

目前為 2023-12-18 提交的版本,檢視 最新版本

// ==UserScript==
// @name            Arca base64 autodecoder
// @name:ko         아카라이브 Base64 자동 디코더
// @version         1.151b
// @author          Laria
// @match           https://arca.live/b/*/*
// @description     Arca.live Base64 auto decoder
// @description:ko  아카라이브 Base64 자동 복호화 스크립트
// @icon            https://www.google.com/s2/favicons?sz=64&domain=arca.live
// @license         MIT
// @encoding        utf-8
// @run-at          document-end
// @supportURL      https://gf.qytechs.cn/ko/scripts/482577-arca-base64-autodecoder
// @namespace       https://gf.qytechs.cn/users/1235854
// ==/UserScript==

/*
 * == Change log ==
 * 1.0 - Release
 * 1.1 - Invalid character update (replace -> replaceAll)
 * 1.11 - Improved show multiple links
 * 1.12 - Show Single links Bugfix
 * 1.13 - Bugfix 1.12
 * 1.14 - Base64 add padding func
 * 1.15 - Add annotation, display improvements
*/

//max attempt decode depth, default:3
const max_iter = 3;
//regex prefix - common
const regArr = [
    /(aHR0cDovL|aHR0cHM6Ly)(\w|=|\+|\/)*(?=[^\+=\w\/])/g, //encoding 1 time
    /(YUhSMGNEb3ZM|YUhSMGNITTZMe)(\w|=|\+|\/)*(?=[^\+=\w\/])/g, //encoding 2 time
    /(WVVoU01HTkViM1pN|WVVoU01HTklUVFpNZ)(\w|=|\+|\/)*(?=[^\+=\w\/])/g, //encoding 3 time
];
//regex prefix - drag
const regInvalid = /[^\w\+\/=]/;

//auto add padding - add '=' padding in base64 encoded string
function base64AddPadding(str) {
    return str + Array((4 - str.length % 4) % 4 + 1).join('=');
}

//base64 decode
var Base64 = {
    _keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
    decode : function (input) {
        var output = "";
        var chr1, chr2, chr3;
        var enc1, enc2, enc3, enc4;
        var i = 0;

        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");

        while (i < input.length) {
            enc1 = this._keyStr.indexOf(input.charAt(i++));
            enc2 = this._keyStr.indexOf(input.charAt(i++));
            enc3 = this._keyStr.indexOf(input.charAt(i++));
            enc4 = this._keyStr.indexOf(input.charAt(i++));

            chr1 = (enc1 << 2) | (enc2 >> 4);
            chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
            chr3 = ((enc3 & 3) << 6) | enc4;

            output = output + String.fromCharCode(chr1);

            if (enc3 != 64) {
                output = output + String.fromCharCode(chr2);
            }
            if (enc4 != 64) {
                output = output + String.fromCharCode(chr3);
            }
        }

        output = Base64._utf8_decode(output);
        return output;
    },
    // private method for UTF-8 decoding
    _utf8_decode : function (utftext) {
        var string = "";
        var i = 0;
        var c = 0;
        var c1 = 0;
        var c2 = 0;
        var c3 = 0;

        while ( i < utftext.length ) {
            c = utftext.charCodeAt(i);
            if (c < 128) {
                string += String.fromCharCode(c);
                i++;
            }
            else if((c > 191) && (c < 224)) {
                c2 = utftext.charCodeAt(i+1);
                string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
                i += 2;
            }
            else {
                c2 = utftext.charCodeAt(i+1);
                c3 = utftext.charCodeAt(i+2);
                string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
                i += 3;
            }
        }
        return string;
    }
};

var hindex = 0; //total decode count

//drag function comparison
var lastSelected = document;
var lastSelectedTime = Date.now();

//create link each components
function createLink(orig, index, url, depth) {
  //n번째 링크 (base64 깊이: 0) [ ABCDEF= ]
  return '<a href="' + url + '" title="' + url + ' (새 창으로 열기)" target="_blank" rel="external nofollow noopener noreferrer">' + index.toString() + '번째 링크 (base64 깊이: ' + depth.toString() + ')</a> [ <code>' + orig.toString() + '</code> ]';
}

//decode & generate
function replacerGen(numIter) {
  return function(source) {
      try {
        return_f = ""; //return msg
        console.log(source); //source

        //decode
        var converted = Base64.decode(base64AddPadding(source));
        //attempt to decode nested base64 encoded string
        for(var i=0; i<numIter; i++) {
            converted = Base64.decode(base64AddPadding(converted));
        }
        hindex++;

        //remove invalid string - �
        converted = decodeURI(encodeURI(converted).replaceAll('%00', ''));

        //split by new line
        converted = converted.split(/\r?\n/);
        //single component
        if (converted.length == 2 && converted[converted.length-1] == '') {
          return_f += createLink(source, hindex, converted[0], numIter+1);
        //multiple component
        } else if (converted.length > 1) {
          return_f += '[ ' + source.toString() + ' ]';
          nindex = 1;
          converted.forEach(function(j) {
            if (j != '') {
              return_f += '<br>' + createLink('링크 자동 분할 : ' + nindex.toString() + '번째', hindex, j, numIter+1);
              hindex++;
              nindex++;
            }
          });
          //last components
          hindex--;
          nindex--;

          return_f = '분할된 링크 총 ' + nindex + '개 ' + return_f;
        } else return_f += createLink(source, hindex, converted, numIter+1);
        return return_f;
    } catch(e) {
        console.log(e);
        console.log('base64 변환 실패 : ' + source);
    }
    return '[ base64 변환 실패 : ' + source + ' ]';
  };
}

//user drag event
//function disabled
function selClicked(event) {
  var sel = document.getSelection().toString();
  if (!sel.match(regInvalid) && sel.length >= 10 && lastSelectedTime + 200 < Date.now()) {
    try {
      var converted = decodeURI(encodeURI(Base64.decode(base64AddPadding(sel))).replaceAll('%00', ''));
      this.innerHTML = this.innerHTML.replace(sel, converted);
      this.removeEventListener('click', selClicked);
    } catch (e) {
      return;
    } finally {
    }
  }
}

//main
(function() {
  'use strict';

  //article
  var article = document.getElementsByClassName("article-content")[0];
  for(var i=0; i<max_iter; i++) {
    article.innerHTML = article.innerHTML.replaceAll(regArr[i], replacerGen(i));
  }

  //comment
  var comments = document.getElementsByClassName("list-area");
  if(comments.length != 0) {
    for(var j=0; j<max_iter; j++) {
      comments[0].innerHTML = comments[0].innerHTML.replaceAll(regArr[j], replacerGen(j));
    }
  }

  /*
  //user drag
  document.addEventListener('selectionchange', function() {
    var sel = document.getSelection().anchorNode;
    if(sel) {
      sel = sel.parentElement;
      if(sel != lastSelected) {
        lastSelected.removeEventListener('click', selClicked);
        sel.addEventListener('click', selClicked);
        lastSelected = sel;
        lastSelectedTime = Date.now();
      }
    }
  })
  */

})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址