草庐IT

EVP_CIPHER_CTX

全部标签

ruby-on-rails - Rails 3 和加密字符串 Gem - 获取 OpenSSL::Cipher::CipherError: bad decrypt error

我正在使用rails3.2、Ruby1.9.3和encrypted_stringsgem,尝试以下操作:"wC6234sdf234234cCY1Lag==\n".decrypt(:symmetric,:key=>"mykeynottelling")我收到这个错误:OpenSSL::Cipher::CipherError:baddecrypt然而,这不会发生在Ruby1.8.7中。我对此有点迷茫,有人知道是什么原因造成的吗?更新1:如果我在ruby​​1.8.7中加密一个字符串:"password".encrypt(:symmetric,:key=>"www.buyandsell.ie"

ruby-on-rails - Rails 5 cipher.key "key must be 32 bytes"错误

全新的Rails应用程序。Rails版本5.0.0.1,Ruby版本2.4.0preview2。创建应用程序“demo”,运行一个简单的脚手架生成产品,并在尝试查看脚手架的概览页面时出现错误(基本索引文件仍然可以正常加载欢迎使用Rails屏幕):ProductsController中的参数错误#indexkey必须是32字节:cipher=new_ciphercipher.encryptcipher.key=@secret#RelyonOpenSSLfortheinitializationvectoriv=cipher.random_iv问题行显然是cipher.key=@secret

ruby-on-rails - 如何使用 OpenSSL::Cipher 加密 UTF-8 字符串中的数据?

在Rails3.0(Ruby1.9.2)应用程序中,我正在尝试使用如下方式加密一些数据:cipher=OpenSSL::Cipher.new'aes-256-cbc'cipher.encryptcipher.key=cipher.random_keycipher.iv=cipher.random_ivencrypted=cipher.update'mostsecretdataintheworld'encrypted这将进入UTF-8数据库。我的问题是>encrypted.encoding=>#>encrypted.encode'utf-8'Encoding::UndefinedConv

javascript - Koa 的 `ctx.status` 没有发送给客户端

这是我的简单路线:router.post('/getFile',async(ctx)=>{constfileName=`${ctx.request.body.file}.pdf`;constfile=fs.createReadStream(fileName);//Thisfilemightnotexist.file.on('error',(err)=>{ctx.response.status=500;//Thisstatuscodedoesn'tmakeittoclientwhenthere'sanerror.});ctx.response.type='application/pdf'

golang 加密 cipher.Block/AES key 本身

我正在使用cipher.Block类型的AESkey,该key是通过使用具有以下功能的crypto/aes包生成的:aesBlock,err:=aes.NewCipher(randKey)我用它来加密一组特定的数据,但之后我想用公钥加密aesBlock本身,这样我就可以存储并稍后用非对称私钥解密。但是,我很难找到加密aesBlock的最佳方法。显然这需要是可逆的,这样我才能用它来解密前面提到的数据。funcEncryptOAEP来自crypto/aes似乎很合适,因为它需要一个*PublicKey,但是msg参数的类型是[]byte并且我的AESkey是cipher.Block类型。不

goroutine 不尊重 `ctx.done()` 或正确退出

我正在尝试在用户按下Ctrl-C时优雅地退出。我正在尝试MakeCtrl+Ccancelthecontext.Context中的代码.包主import("context""fmt""os""os/signal""time")funcmain(){ctx:=context.Background()//trapCtrl+Candcallcancelonthecontextctx,cancel:=context.WithCancel(ctx)c:=make(chanos.Signal,1)signal.Notify(c,os.Interrupt)deferfunc(){signal.Stop

go - Beego语法的功能 'Ctx.Input.GetData(' <variable-name >')'

我是beego和goLang的新手。我遇到了一个代码。如果有人可以解释流程,那将非常有帮助。它是一个GETAPI。我认为Prepare()就像一个过滤器。我不明白的是c.Ctx.Input.GetData("customerid")和c.Ctx.Input.GetData("customergroupid")函数。谁能解释一下GetData正在做什么以及我们如何将值传递给它们?//URLMapping...func(c*CampusHomeController)URLMapping(){c.Mapping("GetOne",c.GetOne)}func(c*CampusHomeCont

http - 为什么推荐使用ctx作为第一个参数?

作为documentation说DonotstoreContextsinsideastructtype;instead,passaContextexplicitlytoeachfunctionthatneedsit.TheContextshouldbethefirstparameter,typicallynamedctx但是我发现,在典型的http请求处理函数中,一个http.Request对象有一个.Context()方法可以获取http请求关联的上下文。那么为什么建议在这些函数中使用上下文作为第一个参数呢?在这种情况下这样做合理吗?我知道这不是绝对规则。但我想知道为什么Handle

go - 从谷歌存储加载文件时,在 bigquery 中使用 .Run(ctx) 重复记录

对于每天明智的分区,我们每3分钟将文件加载到bigquery中,每个文件的大小约为200MB。(.gz)。有时我会重复,但我不确定为什么。我已经验证输入文件只包含一次数据并且日志证明文件只被处理过一次。重复的可能原因是什么?在bigquery上传之前有什么方法可以阻止它吗?client,err:=bigquery.NewClient(ctx,loadJob.ProjectID,clientOption)iferr!=nil{returnnil,jobID,err}deferclient.Close()ref:=bigquery.NewGCSReference(loadJob.URIs.

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中的