当前位置: 首页 > 面试题库 >

无法解密Xor-Base64文本

莫英卓
2023-03-14
问题内容

我正在使用以下html" target="_blank">代码加密和解密数据。现在,我想从Node JS加密数据,并想从Go lang解密数据。但是我无法使用GO语言实现它。

var B64XorCipher = {
  encode: function(key, data) {
    return new Buffer(xorStrings(key, data),'utf8').toString('base64');
  },
  decode: function(key, data) {
    data = new Buffer(data,'base64').toString('utf8');
    return xorStrings(key, data);
  }
};

function xorStrings(key,input){
  var output='';
  for(var i=0;i<input.length;i++){
    var c = input.charCodeAt(i);
    var k = key.charCodeAt(i%key.length);
    output += String.fromCharCode(c ^ k);
  }
  return output;
}

从头开始,我试图像下面这样解码,但我无法实现。

bytes, err := base64.StdEncoding.DecodeString(actualInput)
encryptedText := string(bytes)
fmt.Println(EncryptDecrypt(encryptedText, "XXXXXX"))

func EncryptDecrypt(input, key string) (output string) {
    for i := range input {
        output += string(input[i] ^ key[i%len(key)])
    }

    return output
}

有人可以帮我解决这个问题吗?


问题答案:

您应该使用DecodeRuneInString而不只是slice字符串到字节。

操场上的解决方案:https :
//play.golang.org/p/qi_6S1J_dZU

package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {
    fmt.Println("Hello, playground")
    k:="1234fd23434"
    input:="The 我characterode我 113 is equal to q"
    fmt.Println(EncryptDecrypt(input,k))

    // expect: "eZV扷ZRFRWEWA[戣[@GRX@^B"

}

func EncryptDecrypt(input, key string) (output string) {
    keylen := len(key)
    count := len(input)
    i := 0
    j := 0
    for i < count {
        c, n := utf8.DecodeRuneInString(input[i:])
        i += n
        k, m := utf8.DecodeRuneInString(key[j:])
        j += m
        if j >= keylen {
            j = 0
        }

        output += string(c ^ k)
    }

    return output
}

与您的js结果相比

function xorStrings(key,input){
  var output='';
  for(var i=0;i<input.length;i++){
    var c = input.charCodeAt(i);
    var k = key.charCodeAt(i%key.length);
    output += String.fromCharCode(c ^ k);
  }
  return output;
}

console.log(xorStrings('1234fd23434',"The 我characterode我 113 is equal to q"))
// expect: "eZV扷ZRFRWEWA[戣[@GRX@^B"

测试结果是相同的。

这就是为什么。

在旅途中,当您设置字符串范围时,将迭代字节,但是javascript
charCodeAt是针对字符而不是字节。在utf-8中,字符长度可能为2或3个字节。这就是为什么您得到不同的输出的原因。

在操场上测试https://play.golang.org/p/XawI9aR_HDh

package main

import (
    "fmt"
    "unicode/utf8"
)

var sentence = "The 我quick brown fox jumps over the lazy dog."

var index = 4

func main() {
    fmt.Println("slice of string...")
    fmt.Printf("The byte at %d is |%s|, |%s| is 3 bytes long.\n",index,sentence[index:index+1],sentence[index:index+3])

    fmt.Println("runes of string...")
    ru, _ := utf8.DecodeRuneInString(sentence[index:])
    i := int(ru)
    fmt.Printf("The character code at %d is|%s|%d|    \n",index, string(ru), i)
}

输出是

slice of string...
The byte at 4 is |�|, |我| is 3 bytes long.
runes of string...
The character code at 4 is|我|25105|


 类似资料:
  • 本文向大家介绍java实现Base64加密解密算法,包括了java实现Base64加密解密算法的使用技巧和注意事项,需要的朋友参考一下 Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045~RFC2049,上面有MIME的详细规范。Base64编码可用于在HTTP环境下传递较长的标识信息。例如,在Java Persistence系统Hibernate中,就

  • 本文向大家介绍go语言base64加密解密的方法,包括了go语言base64加密解密的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了go语言base64加密解密的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的Go语言程序设计有所帮助。

  • 本文向大家介绍浅谈Javascript Base64 加密解密,包括了浅谈Javascript Base64 加密解密的使用技巧和注意事项,需要的朋友参考一下 html代码: 效果: 推荐一个Javascript IDE 比Aptana还好用。Komodo IDE(免费版:Komodo Edit,基本功能一样)支持语法高亮,智能感知,还支持perl,python,ruby,nodejs语法等。

  • 我想测试ECC算法的加密和解密。 我编写代码用于: 我的输出加密字符串如下所示: 这是我的私钥 在Android上解密字符串

  • 所以我有一个AES-256-ecb base64字符串,我用在线工具解码了它。然而,我更喜欢命令行,所以我尝试使用命令行来解码它。 这是我尝试过的,但我得到了严重的解密错误 是加密的base64文本 -aes-256-ecb是加密密码 而366a74cb3c959de17d61db30591c39d1是关键 结果应该是另一个base64字符串:

  • 我需要解密用AES加密的传入请求,我尝试使用共享示例但无法找到正确的参数集 加密:AES/CBC/PKCS5添加AES/CBC/PKCS5 初始化向量:长度为16的空字节数组 测试密钥:1234567890123456 纯文本:abcdefghigklmnopqrstuvwxyz0123456789 加密:8Z3dZzqn05FmiuBLowExK0CAbs4TY2GorC2dDPVlsn/tP