草庐IT

aes_encrypt

全部标签

go - aes.NewCipher 返回一个有效 block ,但调用 block.BlockSize() 时出现错误

我正在尝试在我的goAPI中使用AES加密和解密,我使用aes.NewCipher(mykey)创建了一个新block并且该block似乎有效,但是当我调用cipher.NewCB​​CDecrypter(block,iv)该函数在尝试调用b.BlockSize()时在cbc.go的第26行导致“无效内存地址或零指针取消引用”错误。所以我尝试从我自己的代码中调用block.BlockSize()并且我也得到了一个异常,但是当我检查blockvar时它不是nil。funcDecrypt(data[]byte)(result[]byte,errerror){logger:=logrus.N

javascript - 从 Go 到 JS forge 的 AES-CFB

我正在尝试写一些不安全的东西。目的是加密服务器端的mp3,这样它们就不能用wget下载或“另存为”并被普通人使用。思路在服务端,加载mp3,aes-cfb加密,在header中发送key,在responsebody中发送加密后的mp3。服务器端使用Go的标准库和AES-CFB加密。首先使用base64编码,然后只是加密[]byte-s的普通输出。客户端我正在使用forge解密。我发送一个xhr,读取数组缓冲区,使用forge解密并将输出写入控制台。test.txt的内容是“这只是一个测试,可能有效也可能无效。”主.gopackagemainimport("net/http""io""c

encryption - 加密数据的机器学习

我想使用GO在加密数据上实现机器学习模型(KNN或随机森林)。我的数据是用HElib(同态加密)加密的,这意味着我仍然可以对加密数据执行ADD和MUL。我的问题是:我是否必须使用GO重新实现所有机器学习算法,或者我可以使用一些“golearn”库吗?使用golearn库的GO的KNN实现示例:rawData,err:=base.ParseCSVToInstances("../datasets/iris_headers.csv",true)iferr!=nil{panic(err)}//InitialisesanewKNNclassifiercls:=knn.NewKnnClassifi

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.

php - 解密在 GOLang 上用 PHP 解密的 AES-CBC-256 Mcrypt_RIJNDAEL

我尝试在go中重写一些在php5.6(CodeIgniter)中编写的旧代码,但我正在忙于解密。我设法从php解码MCRYPT_RIJNDAEL_128去,其中iv大小是16个字符,但我不能在256上这样做-iv是32。我不想使用go_mcrypt因为它对libcryptheader很严格,所以我试过了在CBC模式下使用goclassicencryptlibsAES密码,但在256上它提示IV长度...phpIV有32个字符而不是预期的16个字符..php部分运行良好...private$CIPHER_KEY="12345678901234567890123456789012";pri

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

Vb.net 到 golang AES

我正在尝试将函数加密例程从VB转换为Golang。我的Go路由返回我传递给它的任何值的十六进制长度,但VB例程总是返回32的长度。有人可以告诉我我做错了什么吗?VB:FunctionencryptString(ByValsourceAsString,ByValkeyAsByte(),ByValIVAsByte())AsByte()DimarrayAsByte()=NothingUsingaesManagedAsSystem.Security.Cryptography.AesManaged=NewSystem.Security.Cryptography.AesManaged()aesMa

node.js - Nodejs/Golang aes 256解密

我有一个加密的字符串,我可以使用以下代码在nodejs中对其进行解密letdecrypt=crypto.createDecipheriv('aes-256-cbc-hmac-sha1',derived,iv);decrypt.setAutoPadding(false);letdecrypted=decrypt.update(new_buf,'binary','utf8')+decrypt.final('utf8');我必须能够在go程序中解密相同的缓冲区,所以我写了这个fmt.Printf("bufsize=%d\n",len(derivedKey))block,err:=aes.Ne