我有一个返回[]字节的数据加密功能。当然,必须在另一个微服务中(通过另一个功能)解密已加密的内容。当我[]byte通过JSON发送via时,会产生问题:将[]byte转换为字符串,然后当我通过调用读取JSON时,结果不再相同。
我必须能够[]byte通过JSON传递由加密功能创建的original ,或者[]byte像下面在下面看到的那样传递一次调用。另一种可能性是更改解密功能,但我没有成功。
来电功能
func Dati_mono(c *gin.Context) {
id := c.Param("id")
oracle, err := http.Get("http://XXXX/"+id)
if err != nil {
panic(err)
}
defer oracle.Body.Close()
oJSON, err := ioutil.ReadAll(oracle.Body)
if err != nil {
panic(err)
}
oracleJSON := security.Decrypt(oJSON, keyEn)
c.JSON(http.StatusOK, string(oJSON))
}
用url调用的函数
func Dati(c *gin.Context) {
var (
person Person
result mapstring.Dati_Plus
mmap []map[string]interface{}
)
rows, err := db.DBConor.Query("SELECT COD_DIPENDENTE, MATRICOLA, COGNOME FROM ANDIP021_K")
if err != nil {
fmt.Print(err.Error())
}
for rows.Next() {
err = rows.Scan(&person.COD_DIPENDENTE, &person.MATRICOLA, &person.COGNOME)
ciao := structs.Map(&person)
mmap = append(mmap, ciao)
}
defer rows.Close()
result = mapstring.Dati_Plus{
len(mmap),
mmap,
}
jsonEn := []byte(mapstring.Dati_PlustoStr(result))
keyEn := []byte(key)
cipherjson, err := security.Encrypt(jsonEn, keyEn)
if err != nil {
log.Fatal(err)
}
c.JSON(http.StatusOK, cipherjson)
}
加密和解密功能
func Encrypt(json []byte, key []byte) (string, error) {
k, err := aes.NewCipher(key)
if err != nil {
return "nil", err
}
gcm, err := cipher.NewGCM(k)
if err != nil {
return "nil", err
}
nonce := make([]byte, gcm.NonceSize())
if _, err = io.ReadFull(rand.Reader, nonce); err != nil {
return "nil", err
}
return gcm.Seal(nonce, nonce, json, nil), nil
}
一切正常,当我打印的问题是创建cipherjson于c.JSON ():在[]byte被转换成字符串。在被调用函数读取并读取时,它被读取为字符串,并且ioutil.ReadAll()创建读取字符串的[]字节。相反,我必须能够将被调用函数中使用的Encrypt函数的返回值传递给Decryot函数。
相关分类