JSON编码问题Ruby 2.0.0

JSON编码问题Ruby 2.0.0,ruby,json,encryption,encoding,openssl,Ruby,Json,Encryption,Encoding,Openssl,所以我编写了一个安全消息脚本,它使用JSON在客户端和服务器之间发送消息。我曾经使用SHA1生成签名消息摘要,这给了我一些无法在JSON.generate中解析的字符,以便以JSON格式发送消息。有人能帮我绕过这个错误吗?'encode':“\xAB”从ASCII-8BIT到UTF-8(Encoding::UndefinedConversionError)” 我遇到的主要问题是这段代码: #make new private / public rsa key-pair rsakey = OpenS

所以我编写了一个安全消息脚本,它使用JSON在客户端和服务器之间发送消息。我曾经使用SHA1生成签名消息摘要,这给了我一些无法在JSON.generate中解析的字符,以便以JSON格式发送消息。有人能帮我绕过这个错误吗?'encode':“\xAB”从ASCII-8BIT到UTF-8(Encoding::UndefinedConversionError)”

我遇到的主要问题是这段代码:

#make new private / public rsa key-pair
rsakey = OpenSSL::PKey::RSA.new 2048

#hash the key using sha1
sha1 = OpenSSL::Digest::SHA1.new
digest = sha1.digest(rsakey.public_key.to_pem)

pubkey = JSON.generate({
    key: rsakey.public_key.to_pem,
    digest: digest
    })
它不允许我做JSON.generate的摘要。有人知道我的消息摘要编码的解决方法或其他方法吗

我的完整代码如下:

# encoding: utf-8
require 'socket'
require 'openssl'
require 'json'

port = 9090

s = TCPServer.open(port)

#make new private / public rsa key-pair
rsakey = OpenSSL::PKey::RSA.new 2048

#hash the key using sha1
sha1 = OpenSSL::Digest::SHA1.new
digest = sha1.digest(rsakey.public_key.to_pem)

pubkey = JSON.generate({
    key: rsakey.public_key.to_pem,
    digest: digest
    })

loop {
    client = s.accept
    #get public key from alice
    incoming = client.gets()
    alice = JSON.parse(incoming)
    alice_key = OpenSSL::PKey::RSA.new alice['key']

    #send public key to alice
    puts pubkey
    client.puts pubkey  

    #get encrypted package from alice
    json_full_package = client.gets()
    full_package = JSON.parse(json_full_package)

    #decrypt and print package  
    cipher = OpenSSL::Cipher.new("DES3")
    cipher.decrypt
    key = rsakey.private_decrypt(full_package['key'])
    iv = rsakey.private_decrypt(full_package['iv'])
    json_package = cipher.update(full_package['package'])

    package = JSON.parse(json_package)
    decrypted_digest = alice_key.public_decrypt(package['signed_digest'])
    sha1 = OpenSSL::Digest::SHA1.new
    digest = sha1.digest(package['data'])
    throw 'failed digest' unless digest == decrypted_digest

    puts package['data']
    client.close
}

# encoding: utf-8
require 'socket'
require 'openssl'
require 'json'

host = 'lab1-15.eng.utah.edu'
port = 9090

s = TCPSocket.open(host, port)

pubkey_q = false

keyF = File.new("public_key.pem", 'w')

#generate alice's key pair
key = OpenSSL::PKey::RSA.new 2048

to_bob_public = JSON.generate({
    key: key.public_key.to_pem
    })
s.send(to_bob_public)

#get public key certificate from bob
while line = s.gets
    puts line.chop
    bob = JSON.parse(line)
end
bob_key = OpenSSL::PKey::RSA.new bob['key']
bob_digest = bob['digest']

#verify public key
sha1 = OpenSSL::Digest::SHA1.new
t_digest = sha1.digest(bob['key'])
throw "not verified" unless t_digest == bob_digest

data = File.read('document') #data is original message

#hash the document using sha1
sha1 = OpenSSL::Digest::SHA1.new
digest = sha1.digest(data)

#sign with private key
signed_digest = key.private_encrypt(digest)

#package this in json
package = JSON.generate({
        signed_digest: signed_digest,
        data: data      
    })

#make cipher for encryption
cipher = OpenSSL::Cipher.new("DES3")
cipher.encrypt
key = cipher.random_key
iv = cipher.random_iv
#encrypt data
encrypted = cipher.update(package) 

#encrypt key and iv using bob's public key
encrypted_cipher_key = bob_key.public_encrypt(key)
encrypted_cipher_iv = bob_key.public_encrypt(iv)

full_package = JSON.generate({
        key: encrypted_cipher_key,
        iv: encrypted_cipher_iv,
        package: encrypted      
    })

#send full_package to bob
s.send(full_package)

s.close

使用
#hexdigest
而不是
#digest
,您将获得十六进制。现在,您正试图将二进制编码为JSON(这就是
#digest
返回的内容),这导致了编码失败。

这是可行的,但现在我遇到了同样的问题,因为行签名为_digest=key.private_encrypt(digest)#将其打包为JSON package=JSON.generate({signed_digest:signed_digest,data:data})不确定我应该如何通过json发送私有_加密字符串,或者是否有可能您可以用多种方式对二进制数据进行编码,但一种简单的方式是base64。只需使用“base64”,然后使用base64.encode64对其进行编码(并使用decode64对其进行解码).太棒了,完全成功了!非常感谢你,伙计,你太棒了!