PHP 편집자 Xiaoxin은 Go 언어를 사용하여 ECDSA 서명을 생성할 때 문제가 발생했습니다. 즉, JS를 확인에 사용할 수 없습니다. 이 문제에 대한 해결책은 서명의 정확성을 보장하기 위해 Go 코드에 몇 가지 추가 필드를 추가하는 것입니다. Go 코드를 일부 수정하면 이 문제를 해결할 수 있고 JS가 Go에서 생성된 ECDSA 서명을 올바르게 확인할 수 있습니다. 이 문서에서는 구체적인 솔루션과 단계를 자세히 소개합니다.
질문 내용
제목에 명시된 대로 작은 문제에 부딪혔습니다. (저를 방해하는 작은 것이 있다고 가정하지만 무엇인지 모르겠습니다).
내가 하고 있는 일의 개요부터 시작해서 내가 가진 모든 것을 제공하겠습니다.
프로젝트 개요
저는 모바일 앱에서 SHA-256
对文件进行哈希处理,并使用 ECDSA P-256
키를 사용하여 백엔드의 해시에 서명하고 있습니다. 그리고 이것은 계속됩니다. 사용자가 원한다면 파일을 다시 해시하고 해시를 조회하고 해시, 일부 메타데이터 및 서명을 가져와 파일의 무결성을 확인할 수 있습니다.
데이터가 제3자가 아닌 내 애플리케이션에 제출되었는지 확인하기 위해(해시는 블록체인에 남아 있지만 이 문제에서는 중요하지 않음) 애플리케이션은 공개 키를 사용하여 서명을 확인하려고 시도합니다. 이것은 작동 매우 잘 됩니다.
이제 내 웹사이트에도 이 옵션을 추가하고 싶은데 문제가 있습니다. jsrsasign
或 webcrypto
API를 사용하면 내 서명이 유효하지 않습니다.
데이터
- 서명 예:
3045022100f28c29042a6d766810e21f2c0a1839f93140989299cae1d37b49a454373659c802203d0967be0696686414fe2efed3a71bc1639d066 ee127cfb7c0ad369521459d00
- 공개 키:
- 해시:
bb5dbfcb5206282627254ab23397cda842b082696466f2563503f79a5dccf942
스크립트
JS 코드 으아아아 애플리케이션 인증 코드(Flutter Dart) 으아아아 키 생성 스크립트(Go) 으아아아서명 래퍼 스크립트 링크: link
나의 시도
- 두 개의 새로운 키 쌍(및 라이브러리)을 사용하여 일부 샘플 데이터에 서명하여 키에 있는 내용이 잘못되었는지 확인하고 그렇지 않은지 테스트했습니다.
- 귀하의 라이브러리와 내 개인 키를 사용하여 서명된 데이터를 테스트하고 내 개인 키가 손상되었는지 확인하기 위해 내 공개 키로 이를 확인했으며 그렇지 않습니다.
- 네트워크 암호화 API로 모든 것을 시도했지만 성공하지 못했습니다
- 위 데이터를 사용하여 로드
ECDSA
公钥并使用new KJUR.crypto.ECDSA({"curve":"secp256r1"}).verifyHex(hash,signature,pubKeyHex)
를 시도했지만 작동하지 않았습니다(브라우저 콘솔에서만 테스트). 차이점이 있는지 알아보기 위해 Firefox와 Safari를 사용해 보았으나 달라진 점은 없습니다 - 해시를
- 을 통해 문자열로 전달하려고 시도했지만 성공하지 못했습니다
sig.updateString(hashData)
그 밖에도 작은 변화가 있습니다 - 웹사이트와 앱 웹사이트의 해시, r&s+signature를 비교하면 모든 것이 예상한 대로입니다.
- 프런트엔드부터 백엔드까지 전체 프로세스를 추적했는데 데이터가 변경되지 않았습니다
마지막으로 생각해볼 점은,
서명을 사용하는 경우 go ecdsa 라이브러리가 메시지를 32바이트로 자르는 것이 문제가 될 수 있다는 것입니다. JS에서는 그렇지 않을까요? P-256
- 首先,JavaScript代码使用
KJUR.crypto.Signature ()
,它隐式对数据进行哈希处理。由于数据已经被散列,这会导致双重散列。在 Dart 方面,不会发生隐式哈希(因为ECDSASigner()
)。
为了避免 JavaScript 端的隐式哈希并与 Dart 代码兼容,KJUR.crypto.ECDSA()
可以用来代替KJUR.crypto.Signature()
。 - 其次,JavaScript 代码中的
updateHex()
对十六进制编码的哈希值执行十六进制解码,而在 Dart 代码中,十六进制编码的哈希值是 UTF-8 编码的。
为了与 Dart 代码兼容,十六进制编码的哈希值在 JavaScript 代码中也必须采用 UTF-8 编码。
以下 JavaScript 代码解决了这两个问题:
(async () => { var spki = `-----BEGIN PUBLIC KEY----- MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEq6iOuQeIhlhywCjo5yoABGODOJRZ c6/L8XzUYEsocCbc/JHiByGjuB3G9cSU2vUi1HUy5LsCtX2wlHSEObGVBw== -----END PUBLIC KEY-----`; var pubkey = KEYUTIL.getKey(spki).getPublicKeyXYHex() var pubkeyHex = '04' + pubkey.x + pubkey.y var msgHashHex = ArrayBuffertohex(new TextEncoder().encode("bb5dbfcb5206282627254ab23397cda842b082696466f2563503f79a5dccf942").buffer) // var msgHashHex = ArrayBuffertohex(new TextEncoder().encode("bb5dbfcb5206282627254ab23397cda8").buffer); // works also since only the first 32 bytes are considered for P-256 var sigHex = "3045022100f28c29042a6d766810e21f2c0a1839f93140989299cae1d37b49a454373659c802203d0967be0696686414fe2efed3a71bc1639d066ee127cfb7c0ad369521459d00" var ec = new KJUR.crypto.ECDSA({'curve': 'secp256r1'}) var verified = ec.verifyHex(msgHashHex, sigHex, pubkeyHex) console.log("Verification:", verified) })();
<script src="https://cdnjs.cloudflare.com/ajax/libs/jsrsasign/10.4.0/jsrsasign-all-min.js"></script>
위 내용은 JS를 사용하여 Go에서 생성된 ECDSA 서명을 확인할 수 없습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Golang과 C는 각각 공연 경쟁에서 고유 한 장점을 가지고 있습니다. 1) Golang은 높은 동시성과 빠른 발전에 적합하며 2) C는 더 높은 성능과 세밀한 제어를 제공합니다. 선택은 프로젝트 요구 사항 및 팀 기술 스택을 기반으로해야합니다.

Golang은 빠른 개발 및 동시 프로그래밍에 적합한 반면 C는 극심한 성능과 기본 제어가 필요한 프로젝트에 더 적합합니다. 1) Golang의 동시성 모델은 Goroutine 및 Channel을 통한 동시성 프로그래밍을 단순화합니다. 2) C의 템플릿 프로그래밍은 일반적인 코드 및 성능 최적화를 제공합니다. 3) Golang의 쓰레기 수집은 편리하지만 성능에 영향을 줄 수 있습니다. C의 메모리 관리는 복잡하지만 제어는 괜찮습니다.

goimpactsdevelopmentpositively throughlyspeed, 효율성 및 단순성.

C는 하드웨어 리소스 및 고성능 최적화가 직접 제어되는 시나리오에 더 적합하지만 Golang은 빠른 개발 및 높은 동시성 처리가 필요한 시나리오에 더 적합합니다. 1.C의 장점은 게임 개발과 같은 고성능 요구에 적합한 하드웨어 특성 및 높은 최적화 기능에 가깝습니다. 2. Golang의 장점은 간결한 구문 및 자연 동시성 지원에 있으며, 이는 동시성 서비스 개발에 적합합니다.

Golang은 실제 응용 분야에서 탁월하며 단순성, 효율성 및 동시성으로 유명합니다. 1) 동시 프로그래밍은 Goroutines 및 채널을 통해 구현됩니다. 2) Flexible Code는 인터페이스 및 다형성을 사용하여 작성됩니다. 3) NET/HTTP 패키지로 네트워크 프로그래밍 단순화, 4) 효율적인 동시 크롤러 구축, 5) 도구 및 모범 사례를 통해 디버깅 및 최적화.

GO의 핵심 기능에는 쓰레기 수집, 정적 연결 및 동시성 지원이 포함됩니다. 1. Go Language의 동시성 모델은 고루틴 및 채널을 통한 효율적인 동시 프로그래밍을 실현합니다. 2. 인터페이스 및 다형성은 인터페이스 방법을 통해 구현되므로 서로 다른 유형을 통일 된 방식으로 처리 할 수 있습니다. 3. 기본 사용법은 기능 정의 및 호출의 효율성을 보여줍니다. 4. 고급 사용에서 슬라이스는 동적 크기 조정의 강력한 기능을 제공합니다. 5. 레이스 조건과 같은 일반적인 오류는 Getest-race를 통해 감지 및 해결할 수 있습니다. 6. 성능 최적화는 sync.pool을 통해 개체를 재사용하여 쓰레기 수집 압력을 줄입니다.

Go Language는 효율적이고 확장 가능한 시스템을 구축하는 데 잘 작동합니다. 장점은 다음과 같습니다. 1. 고성능 : 기계 코드로 컴파일, 빠른 달리기 속도; 2. 동시 프로그래밍 : 고어 라틴 및 채널을 통한 멀티 태스킹 단순화; 3. 단순성 : 간결한 구문, 학습 및 유지 보수 비용 절감; 4. 크로스 플랫폼 : 크로스 플랫폼 컴파일, 쉬운 배포를 지원합니다.

SQL 쿼리 결과의 정렬에 대해 혼란스러워합니다. SQL을 학습하는 과정에서 종종 혼란스러운 문제가 발생합니다. 최근 저자는 "Mick-SQL 기본 사항"을 읽고 있습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
