JSON编码问题Ruby 2.0.0

时间:2013-07-12 04:34:58

标签: ruby json encryption encoding openssl

所以我编写了一个安全的消息传递脚本,它使用JSON在客户端和服务器之间发送消息。有一次,我正在使用SHA1生成签名的消息摘要,这给了我一些我无法在JSON.generate中解析的字符,以便以JSON格式发送我的消息。任何人都可以帮我解决这个错误“在'encode':”\ xAB“从ASCII-8BIT到UTF-8(编码:: 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

1 个答案:

答案 0 :(得分:1)

使用#hexdigest代替#digest,您将获得十六进制。现在你正在尝试将二进制编码为JSON(就像#digest返回的那样),这导致编码失败。