草庐IT

openssl_encrypt

全部标签

php - 在PHP中解密由openssl_encrypt加密的AES-256-CBC密文时出现坏 block 大小错误

我有一个PHP模块,它使用openssl_encrypt使用aes-256-cbc加密电子邮件。本模块生成的密文也可以用本模块解密。但是,如果我尝试使用相同的IV和key在Go中使用aes-256-cbc的实现来解密它们,我会得到一个badblocksize错误。block大小应该是16的倍数,但PHP生成的密文不是16的倍数。这是代码packagemainimport("crypto/aes""crypto/cipher""crypto/sha256""encoding/base64""encoding/hex""fmt")var(IV=[]byte("fg3Dk54f4340fKF

javascript - AES CBC : JavaScript/CryptoJS Encrypt -> Golang Decrypt

注意:这仅供个人使用和学习,我不会尝试将自己的加密技术用于公共(public)用途。我需要AES256加密一个字符串,但是我目前的尝试在十六进制解码时以Salted__Vέ��|��l����ʼ8XCQlY服务器端的字符串结束。十六进制解码后,它应该是一个有效的utf8base64字符串,然后可以将其解码为原始字符串。这类似于提供的解决方案here,但是盐不是实际问题(尽管答案被接受)并且我无法通过在使用前对iv进行十六进制解码来抑制盐操作(如建议的那样)。有办法做到这一点吗?我尝试了几种不同的方法,但总是以相似的方式结束。我最近的尝试是这样的:加密.js//CryptoJS.pad.

encryption - 为什么 golang 加密示例不使用随机 IV?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭7年前。Improvethisquestion根据CWE-329,非随机IV允许字典攻击的可能性。然而,intheAEScryptoexample,golang文档使用非随机IV:ciphertext:=make([]byte,aes.BlockSize+len(plaintext))iv:=ciphertext[:aes.BlockSize]此实现是否安全,或者我应该使用随机函数来获取我的IV?

戈朗 : How do I encrypt plain text that is 5 characters long with DES and CBC?

目前正在尝试将5个字符长的明文加密为12个字符的加密字符串。我希望能够指定一个唯一的IV(不是随机生成的)、一个唯一的key,并使用DES。我现在的code要求明文长度为8个字符(5个字符名称加3个空格)。 最佳答案 我已经遇到过这个问题。这是因为填充问题。你想要的代码是一个Codelink你可以在goplayground上测试它。packagemainimport("crypto/cipher""crypto/des""encoding/base64""fmt""bytes")funcmain(){originalText:="y

go - Golang中如何使用Openssl RSA公私钥对数据进行加解密?

我正在尝试编写一个使用RSA公钥加密数据并使用私钥解密数据的程序。RSAkey是使用openssl工具生成的。我找到了SpacemonkeygoOpensslhttps://github.com/spacemonkeygo/openssl为此目的包装。但无法找到任何样本,而且他们也没有可用于相同的文件。以至于我无法使用。请指导我如何在Golang中使用Openssl?我正在使用第一次加密解密和Openssl。提前致谢! 最佳答案 IamtryingtowriteaprogramwhichencryptsdatausingaRSApu

encryption - 在 Go 中使用 RSA 进行 key 交换的 AES 加密通信

我正在尝试在基于RubySinatra的网络后端和GoogleGo应用程序之间建立安全通信。Go应用程序包含公钥并最初打开连接。然后它使用其公钥加密随机生成的AES,并将其发送到Web后端。所有即将到来的(大容量)数据都将使用AESkey加密。这是一般可用的方法吗?Go代码如下所示aesRand:=make([]byte,32)rand.Read(aesRand)AESBlock,_=aes.NewCipher(aesRand)//EncryptAESkeywithRSAdata,err:=rsa.EncryptPKCS1v15(rand.Reader,PubKey,aesRand)现

encryption - Go 相当于 OpenSSL EVP 对称 EVP_aes_256_cbc

我正在编写一个Go脚本,它将解密一些使用EVP_aes_256_cbc和RSA公钥加密的遗留数据。在C中,这类似于:key_size=EVP_OpenInit(&ctx,EVP_aes_256_cbc(),evp_key,eklen,iv,pkey);//...EVP_OpenUpdate(&ctx,destination,&len_out,buffer_in,buffer_size)//...EVP_OpenFinal(&ctx,destination+len_out,&len_out);我在Go中有evp_key和iv字节数组等价物,但我必须承认我无法理解EVP在OpenSSL中的

php - 使用golang解密用php openssl_encrypt加密的文件

首先。我在这里如履薄冰!我有一个从php获得的加密文件。我正在尝试用golang解密它。php应用程序使用公共(public)RSAkey来加密用于使用aes-256-cbc加密的key。我已经创建了一些概念验证代码,但我做不对。尽管key和iv在两边看起来都是正确的,但也有不正确的地方。结果只是垃圾。我怀疑某些编码不匹配(期望base64,获取字符串字节......某事)或者我误解了一些概念。加密:解密:packagemainimport("crypto/aes""crypto/cipher""crypto/rand""crypto/rsa""crypto/x509""encodin

ios - OpenSSL 签名*完全*需要 AppleWWDRCA 证书吗?

AppleWWDRCA.cer与使用OpenSSL开发证书有任何关系吗?如果是这样,什么?如果不是,它有什么用?编辑:我正在使用Windows。我不需要有关Mac开发的答案。到目前为止,我已经使用OpenSSL创建了开发应用程序(已签名并带有证书),为多个开发人员创建了临时应用程序(已签名并带有证书),它们都运行良好。这(可能)只是一个关于是否需要将应用程序放入Apple的AppStore的问题。 最佳答案 不,WWDR证书仅用于授权您的应用在AppleAppStore上销售/集成。公共(public)OpenSSL证书(通常)从外

windows - Chef 在 Windows 上找不到 encrypted_data_bag_secret

我无法在Windows上从我的加密数据包加载secret。我已将文件复制到c:\chef\encrypted_data_bag_secret,这是默认路径。我首先尝试了这个:credentials=Chef::EncryptedDataBagItem.load("system","deploy")失败并出现此错误:10.0.1.20[2014-09-12T19:51:45+00:00]FATAL:ArgumentError:Nosecretspecifiedtoload_secretandnosecretfoundatC:\chef\encrypted_data_bag_secret然