>  기사  >  백엔드 개발  >  aesGCMOpen에서 비밀번호를 얻었음 오류: 메시지 인증 실패: golang 암호 해독 gcm

aesGCMOpen에서 비밀번호를 얻었음 오류: 메시지 인증 실패: golang 암호 해독 gcm

王林
王林앞으로
2024-02-06 08:05:03995검색

错误 aesGCMOpen 得到密码:消息身份验证失败:golang 解密 gcm

질문 내용

Rails activesupport 복호화를 golang에 다시 작성하려고 하는데 이 오류가 발생합니다

err aesGCMOpen 得到密码:消息验证失败

복호화를 적극적으로 지원하는 레일스 코드입니다

으아아아

이것은 내가 레일에서 다시 작성한 activesupport를 해독하려는 golang 코드입니다

으아아아

핵심은:

으아아아

이 레일스 명령으로 암호화된 데이터를 생성했습니다

으아아아

해결책을 찾으면 댓글을 남겨주세요

감사합니다

Go 코드


에서 레일 암호화


정답

aesGCM.Open()调用中、密文和认证标签分别在第三个和第四个参数中传递。这是错误的。两个数据必须连接并在第三个参数中传递。第四个参数需要是nil에서 암호화된 데이터를 해독할 수 있습니다. 이 매개변수는 여기에서 사용되지 않는 추가 데이터에 사용됩니다.
또한 Go 코드에서는 해독된 데이터의 역직렬화가 누락되었습니다. 이를 위해서는 ruby-marshal과 같은 적절한 라이브러리를 적용해야 합니다.

전체적으로 다음과 같은 변경이 필요합니다:

으아아아

이러한 변경으로 Rails 코드를 사용하여 암호화된 데이터는 Go 코드를 사용하여 성공적으로 해독될 수 있습니다.

위 내용은 aesGCMOpen에서 비밀번호를 얻었음 오류: 메시지 인증 실패: golang 암호 해독 gcm의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제