hmac.New(h func() hash.Hash, 키 바이트) hash.Hash는 JavaScript에서 동일합니다.
PHP에서는 데이터 보안을 보호하기 위해 암호화 알고리즘을 사용해야 하는 경우가 많습니다. HMAC(해시 기반 메시지 인증 코드)는 데이터 무결성 및 신원 인증을 확인하는 데 일반적으로 사용되는 암호화 알고리즘입니다. PHP에서는 해시 함수와 키를 지정해야 하는 hmac.New() 함수를 사용하여 HMAC 인스턴스를 생성할 수 있습니다. 마찬가지로 JavaScript에서는 동일한 기능을 달성하기 위해 동일한 방법을 사용할 수 있습니다. 이 기사에서는 JavaScript에서 동등한 방법을 사용하여 HMAC 인스턴스를 생성하는 방법과 PHP와 JavaScript 간의 데이터를 암호화하고 해독하는 방법을 보여 드리겠습니다.
질문 내용
저는 며칠 동안 go lang hmac.new의 js 구현에 거의 막혔습니다. 그러나 성공하지 못했습니다. crypto
、crypto-js
和 stablelib
模块进行实现。问题是,在go lang版本中,hmac
实例可以通过hmac
인스턴스 생성을 사용합니다. 예를 들면(코드 블록이 정확하고 테스트되었습니다):
사실 저도 어떻게 되는지는 잘 모르겠어요! 모든 자바스크립트 관련 모듈에서는 hmac
创建 hmac
,并且它们接受确定哈希算法的 string
에서 값을 가져올 수 없기 때문입니다.
아마도 hmac
创建hmac
에서 어떻게 오는지 자바스크립트로 물어보는 것이 더 나을 것 같습니다.
해결책은 무엇인가요?
go 버전의 출력이 구현의 출력과 동일하면 솔루션이 정확합니다.
해결 방법
사양(rfc 2104)에 따르면 hmac은 내부적으로 sha256과 같은 다이제스트 기능을 사용합니다.
그러나 귀하의 구현은 다이제스트 대신 내부적으로 다른 hmac을 사용하는 hmac을 적용합니다(실제로는 호환되지 않습니다). 여기서 가장 낮은 수준의 hmac만이 내부적으로 일반 다이제스트를 사용합니다. 이렇게 하면 중첩된 구조가 생성됩니다.
일반 hmac(다이제스트 포함)의 사양을 기반으로 Go 코드에 사용되는 hmac(다이제스트 대신)을 사용하여 hmac으로 확장할 수 있습니다.
hmac(k xor opad, hmac(k xor ipad, text))
s. rfc2104, 섹션 2. hmac
사양과의 차이로 인해 이러한 기능을 즉시 지원하는 자바스크립트 라이브러리를 찾는 것이 쉽지 않을 수 있습니다.
대부분의 라이브러리는 확실히 hmac를 지원하지만 nodejs의 암호화 모듈의 crypto.createhmac()
과 같은 다이제스트만 지정하도록 허용합니다(hmac 아님). 다른 답변도 참조하세요. 나는 이 접근 방식이 Go 코드에서 논리를 구현하는 데 사용될 수 있다고 생각하지 않습니다.
다른 답변의 접근 방식이 작동하지 않고 원하는 기능을 갖춘 다른 자바스크립트 라이브러리를 찾을 수 없는 경우 hmac의 사양이 상대적으로 간단하므로(위 참조) 자바스크립트로 로직을 직접 구현할 수 있습니다.
다음 코드는 nodejs의 암호화 모듈 구현 예입니다.
으아악결과:
으아악테스트:
다음 go 코드는 동일한 결과를 생성합니다.
으아악편집자:
이 기사에서 영감을 얻었으며 다음은 hmac_rec()
的更紧凑/高效的实现,它使用常规最后一个迭代步骤的 hmac(这也使得 gethash()
오래된 내용입니다.):
위 내용은 hmac.New(h func() hash.Hash, 키 바이트) hash.Hash는 JavaScript에서 동일합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











2009년 창립 이래 비트코인은 암호화폐 세계의 리더가 되었으며 가격은 큰 변동을 겪었습니다. 포괄적인 역사적 개요를 제공하기 위해 이 기사에서는 2009년부터 2025년까지의 비트코인 가격 데이터를 수집하여 주요 시장 이벤트, 시장 정서 변화, 가격 변동에 영향을 미치는 중요한 요소를 다룹니다.

암호화폐인 비트코인은 출시 이후 상당한 시장 변동성을 경험해 왔습니다. 이 기사에서는 독자들이 가격 추세와 주요 순간을 이해하는 데 도움이 되도록 탄생 이후 비트코인의 역사적 가격에 대한 개요를 제공합니다. 비트코인의 과거 가격 데이터를 분석함으로써 우리는 시장의 가치 평가, 변동에 영향을 미치는 요인을 이해하고 향후 투자 결정의 기초를 제공할 수 있습니다.

Bitcoin의 Price는 2009 년에 창설 된 이래 2021 년 11 월에 69,044.77 달러로 상승하여 2018 년 12 월에 3,191.22 달러로 감소했습니다. 2024 년 12 월 현재 최신 가격은 $ 100,204를 초과했습니다.

실시간 비트 코인 USD 가격 비트 코인 가격에 영향을 미치는 요인 향후 비트 코인 가격을 예측하기위한 지표 다음은 2018-2024 년 비트 코인 가격에 대한 몇 가지 주요 정보입니다.

CSS에서 크기 조정 기호를 사용자 정의하는 방법은 배경색으로 통합됩니다. 매일 개발에서, 우리는 종종 조정과 같은 사용자 인터페이스 세부 정보를 사용자 정의 해야하는 상황을 발생시킵니다.

세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? 세분화 장치를 구현하는 과정에서 왼쪽 버튼을 클릭 할 때 오른쪽 테두리를 45도 곡선으로 바꾸는 방법과 포인트 ...

Flex 레이아웃 및 솔루션에서 텍스트를 과도하게 누락하여 컨테이너 개구부 문제가 사용됩니다 ...

예, H5 페이지 제작은 HTML, CSS 및 JavaScript와 같은 핵심 기술을 포함하는 프론트 엔드 개발을위한 중요한 구현 방법입니다. 개발자는 & lt; canvas & gt; 그래픽을 그리거나 상호 작용 동작을 제어하기 위해 JavaScript를 사용하는 태그.
