목차
질문 내용
해결책은 무엇인가요?
해결 방법
백엔드 개발 Golang hmac.New(h func() hash.Hash, 키 바이트) hash.Hash는 JavaScript에서 동일합니다.

hmac.New(h func() hash.Hash, 키 바이트) hash.Hash는 JavaScript에서 동일합니다.

Feb 09, 2024 am 08:12 AM
overflow

hmac.New(h func() hash.Hash, key byte) hash.Hash 在 JavaScript 中等效

PHP에서는 데이터 보안을 보호하기 위해 암호화 알고리즘을 사용해야 하는 경우가 많습니다. HMAC(해시 기반 메시지 인증 코드)는 데이터 무결성 및 신원 인증을 확인하는 데 일반적으로 사용되는 암호화 알고리즘입니다. PHP에서는 해시 함수와 키를 지정해야 하는 hmac.New() 함수를 사용하여 HMAC 인스턴스를 생성할 수 있습니다. 마찬가지로 JavaScript에서는 동일한 기능을 달성하기 위해 동일한 방법을 사용할 수 있습니다. 이 기사에서는 JavaScript에서 동등한 방법을 사용하여 HMAC 인스턴스를 생성하는 방법과 PHP와 JavaScript 간의 데이터를 암호화하고 해독하는 방법을 보여 드리겠습니다.

질문 내용

저는 며칠 동안 go lang hmac.new의 js 구현에 거의 막혔습니다. 그러나 성공하지 못했습니다. cryptocrypto-jsstablelib 模块进行实现。问题是,在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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

2009-2025년 탄생 이후 비트코인 ​​가격 BTC 역사적 가격에 대한 가장 완벽한 요약 2009-2025년 탄생 이후 비트코인 ​​가격 BTC 역사적 가격에 대한 가장 완벽한 요약 Jan 15, 2025 pm 08:11 PM

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

비트코인 탄생 이후의 역사적 가격 개요 비트코인의 역사적 가격 추세를 완벽하게 수집합니다. 비트코인 탄생 이후의 역사적 가격 개요 비트코인의 역사적 가격 추세를 완벽하게 수집합니다. Jan 15, 2025 pm 08:14 PM

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

비트 코인 BTC 역사 가격 추세 차트의 탄생 이후의 역사적 가격 목록 (최신 요약) 비트 코인 BTC 역사 가격 추세 차트의 탄생 이후의 역사적 가격 목록 (최신 요약) Feb 11, 2025 pm 11:36 PM

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

2018-2024 USD의 Bitcoin의 최신 가격 2018-2024 USD의 Bitcoin의 최신 가격 Feb 15, 2025 pm 07:12 PM

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

CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? Apr 05, 2025 pm 02:30 PM

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

CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? Apr 04, 2025 pm 11:45 PM

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

플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? 플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? Apr 05, 2025 pm 11:00 PM

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

H5 페이지 제작은 프론트 엔드 개발입니까? H5 페이지 제작은 프론트 엔드 개발입니까? Apr 05, 2025 pm 11:42 PM

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

See all articles