Rumah >pembangunan bahagian belakang >Golang >Kunci persendirian yang saya hasilkan dalam Node.js tidak dikenali sebagai format PEM dalam Go

Kunci persendirian yang saya hasilkan dalam Node.js tidak dikenali sebagai format PEM dalam Go

WBOY
WBOYke hadapan
2024-02-13 19:09:08496semak imbas

我在 Node.js 中生成的私钥在 Go 中不被识别为 PEM 格式

editor php Xigua menghadapi masalah semasa proses pembangunan baru-baru ini dia mendapati bahawa kunci peribadi yang dijana menggunakan Node.js tidak dapat dikenali sebagai format PEM dalam Go. Masalah ini menyusahkannya untuk masa yang lama, dan dia mencuba pelbagai kaedah untuk menyelesaikannya, tetapi tidak berjaya. Dalam artikel ini, kami akan meneroka punca masalah ini dan penyelesaian yang mungkin untuk membantu pembaca menyelesaikan masalah yang sama.

Kandungan soalan

Saya menjana kunci awam dan peribadi dalam node.js menggunakan pustaka penyulitan dan kod berikut.

function generatekeyfiles() {
  const keypair = crypto.generatekeypairsync("rsa", {
    moduluslength: 4096,
    publickeyencoding: {
      type: "spki",
      format: "pem",
    },
    privatekeyencoding: {
      type: "pkcs8",
      format: "pem",
      cipher: "aes-256-cbc",
      passphrase: "",
    },
  });
  // writing the keys in the following files
  fs.writefilesync("public_key", keypair.publickey);
  fs.writefilesync("private_key", keypair.privatekey);
}

Saya tahu kekunci berfungsi kerana saya telah menggunakannya untuk menyulitkan dan menyahsulit data. Tetapi saya cuba menggunakannya semasa pergi dan ia tidak dapat mengesan kunci peribadi dalam format pem. Walau bagaimanapun, ia mengiktiraf kunci awam. Berikut ialah coretan kod pergi saya:

// Load public key from the "public_key" file generated by Node.js
publicKeyData, err := ioutil.ReadFile("public_key")
if err != nil {
fmt.Println("Error reading the public key file:", err)
return
}

// Load public key in PEM format
block, _ := pem.Decode(publicKeyData)
if block == nil || block.Type != "PUBLIC KEY" {
fmt.Println("The public key file is not in PEM format")
return
}
publicKey, err := x509.ParsePKIXPublicKey(block.Bytes)
if err != nil {
fmt.Println("Error loading the public key:", err)
return
}

// Successfully loaded the public key in Go
fmt.Println("Public key loaded successfully:", publicKey)

// Load private key from the "private_key" file generated by Node.js
privateKeyData, err := ioutil.ReadFile("private_key")
if err != nil {
fmt.Println("Error reading the private key file:", err)
return
}

// Load private key in PEM format
block, _ = pem.Decode(privateKeyData)
if block == nil || block.Type != "PRIVATE KEY" {
fmt.Println("The private key file is not in PEM format")
return
}

Tolong, saya perlukan bantuan. Saya tidak faham mengapa apabila saya menggunakan kunci awam dan peribadi untuk penyulitan dalam program node.js saya yang lain, ia membaca kunci awam tetapi bukan kunci peribadi. Ia mengatakan "fail kunci peribadi tidak dalam format pem" tetapi itu tidak masuk akal.

Saya cuba menjana kunci baharu tetapi masalah yang sama berterusan.

Penyelesaian

Saya akhirnya menyelesaikan masalah ini dengan menggunakan perpustakaan OpenSSL pada Windows cmd untuk menjana kunci. Saya kemudian menyulitkan dan menyahsulit data menggunakan kunci yang dijana oleh OpenSSL. Saya terpaksa membersihkan data yang telah dinyahsulit, tetapi akhirnya berjaya.

Atas ialah kandungan terperinci Kunci persendirian yang saya hasilkan dalam Node.js tidak dikenali sebagai format PEM dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam