JSON编码问题Ruby 2.0.0
所以我编写了一个安全消息脚本,它使用JSON在客户端和服务器之间发送消息。我曾经使用SHA1生成签名消息摘要,这给了我一些无法在JSON.generate中解析的字符,以便以JSON格式发送消息。有人能帮我绕过这个错误吗?'encode':“\xAB”从ASCII-8BIT到UTF-8(Encoding::UndefinedConversionError)” 我遇到的主要问题是这段代码: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
#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对其进行解码).太棒了,完全成功了!非常感谢你,伙计,你太棒了!