golang에서 CSR 생성 중 ExtendedKeyUsage에 정보를 제공하는 데 문제가 있었습니다. 이 문제는 생성된 CSR의 정확성과 유효성에 영향을 미칠 수 있습니다. ExtendedKeyUsage는 인증서 확장의 일부이며 인증서 사용 목적을 지정하는 데 사용됩니다. CSR에 올바른 ExtendedKeyUsage 정보를 제공함으로써 특정 시나리오에서 인증서의 가용성과 보안을 보장할 수 있습니다. 하지만 golang에서는 CSR 생성 시 ExtendedKeyUsage 정보를 제대로 제공하지 못하는 문제가 가끔 발생합니다. PHP 편집자 Xigua는 독자들이 비슷한 문제를 해결하고 요구 사항을 충족하는 CSR을 성공적으로 생성할 수 있도록 이 문제의 원인과 해결 방법을 이 기사에서 자세히 소개합니다.
질문 내용
나는 이상한 문제를 발견했습니다. 저는 사용자가 제공한 입력을 기반으로 csr을 생성하는 작은 golang 도구를 작성 중입니다. 대부분 목표 달성에 성공했지만 extendedkeyusage에 문제가 발생했습니다. 간단히 말해서, 작동하지 않습니다.
일부 x509 필드에 대한 asn1 마샬링 코드:
으아악그런 다음 템플릿을 만들고 csr을 성공적으로 생성하고 저장했습니다. 거의:
으아악 으아악 으아악내 extendedkeyusage는 비어 있지만 클라이언트 인증이어야 합니다. 내가 뭘 잘못했나요?
다음을 기대합니다:
으아악빈 들판이 보입니다. 다른 oid에서 다른 바이트 세트를 사용해 보았지만 여전히 결과가 없습니다. extendedkeyusage 필드에서는 아무 것도 쓸 수 없지만(그래야 하지만)
가져온 경우:
버전: go1.19.3 darwin/amd64
해결 방법
데이터를 인쇄할 때 문제가 되는 것 같아요. 키/값은 실제로 데이터에 존재합니다.
코드에서:
으아악oidextensionextendedkeyusage는 asn.1 oid 2.5.29.37이며 der 인코더를 사용하여 인코딩하면 "55 1d 25"가 됩니다
온라인으로 인코딩하여 어떤 바이너리가 생성되는지 확인할 수 있습니다(예: https://www.php.cn/link/8e08227323cd829e449559bb381484b7)
asn1keyusagecauth 값은 2(x509.go에 정의된 상수)이며, der 인코더를 사용하여 asn.1 비트 문자열로 인코딩하면 "00 02"가 됩니다(첫 번째 00은 패딩 비트 수(없음), 02는 패딩 비트 수) 패딩 숫자) 값 2)
이제 인증서 요청의 base64 값을 가져오고 asn.1 der 디코더를 사용하여 디코딩합니다(예: https://asn1.io/asn1playground)
miibtzccav0caqawgzwxczajbgnvbaytakfvmq8wdqydvqqiewztewruzxkxdzan bgnvbactbln5zg5letetmbega1uechmkc210aensawvuddelmakga1uecxmcsvqx jtajbgnvbamthhntdggtq2xpzw50lvk4cdg1bk1psvnzmgliz0exijgbgkqhkig 9w0bcqeme3ntdghjbgllbnrac210ac5jb20wwtatbgcqhkjopqibbggqhkjopqmb bwncaar4riguoxsyxdaml9f9e2grjumuk8q0jilotb2kadmbz1rocedszuuxkqcr 0vud2aw3vidph1ar4hkqwkm43hxqof4wxayjkozihvcnaqkomu8wttaebgnvhree fzavgrnzbxroy2xpzw50qhntdgguy29tmasga1udjqqeawiiaajaobgnvhq8baf8e bamcaagwdgydvr0paqh/baqdagabmaogccqgsm49bamca0gameuciqdtbj+0atjy f1gy8am2mv7/x3tsebmmvdszkw8l6rvseqigmih8co9nkp0axdmgp9x4kvjjzk9x rw3roydt89d73oa=
으아악여기에 있을 때까지 위의 출력을 아래로 스크롤하세요!
키/값은 다음과 같습니다.
으아악ASN.1 사양에 따라 CSR을 디코딩하고 싶지만 찾을 수 없습니다. :(
위 내용은 golang에서 빌드하는 동안 CSR에 ExtendedKeyUsage 정보를 제공하는 문제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

GOOFFERSROBUSTFEATURESECURECODING, BUTDEVENCERMUSTIMPLESSECURITYBESTPRACTICEFICEATIVERY.1) USEGO'SCRYPTOPACKAGEFORUEDATAHANDLING.2) MANICECONCURNCY WHYSYNCHRONICIATIONSPRIMITIVESTOPRECONDITIONS.3) SANITIZEEXTERNALINPOPODOIDSQLINJ

go의 오류 인터페이스는 typeerRorInterface {error () string}로 정의되며, 오류로 간주 될 오류 () 메소드를 구현하는 모든 유형이 허용됩니다. 사용 단계는 다음과 같습니다. 1. 기본적으로 iferr! = nil {log.printf ( "anerroroccurred :%v", err) return}과 같은 오류를 확인하고 로그 오류합니다. 2. typeMyErrorStruct {msgstringDetailString}과 같은 자세한 정보를 제공하기 위해 사용자 정의 오류 유형을 만듭니다. 3. 오류 랩퍼를 사용하여 (GO1.13 이후) 원래 오류 메시지를 잃지 않고 컨텍스트를 추가하고,

Toeffectially HandleErrorsinconCurrentGoprograms, UsechannelStocommunicateErrors, ubstractErrorWatchers, ConsiderTimeOuts, UseBufferedChannels 및 ProvideClearerRormessages.1) UsechannelStopassErrorsfromgoroutinestothemainfunction

Go Language에서 인터페이스의 구현은 암시 적으로 수행됩니다. 1) 암시 적 구현 : 유형에 인터페이스에 의해 정의 된 모든 메소드가 포함되어있는 한 인터페이스가 자동으로 만족됩니다. 2) 빈 인터페이스 : 모든 유형의 인터페이스 {} 유형이 구현되고 적당히 사용하면 안전성 문제를 피할 수 있습니다. 3) 인터페이스 격리 : 코드의 유지 관리 및 재사용 성을 향상시키기 위해 작지만 집중된 인터페이스를 설계하십시오. 4) 테스트 : 인터페이스는 종속성을 조롱하여 단위 테스트에 도움이됩니다. 5) 오류 처리 : 인터페이스를 통해 오류를 균일하게 처리 할 수 있습니다.

toensureInitFunctionSareefeCectiveAdaintainable : 1) minimizesideFectsByReTurningValuesInsteAdglobalstate, 2) inficeDempotencyToHandleMultipLecallsSafely 및 3) BRALKTODDOCLEXINITIANSETSMALLER, FOCUSISSEDFUNCINTURATURITYANDUMALOMODUMALEDUMAL ANDM

goisidealforbeginnersandsuitableforcloudandnetworkservicesduetoitssimplicity, 효율성, 및 콘크리 론 피처

개발자는 다음과 같은 모범 사례를 따라야합니다. 1. 자원 누출을 방지하기 위해 조롱 틴을 신중하게 관리합니다. 2. 동기화를 위해 채널을 사용하지만 과용을 피하십시오. 3. 동시 프로그램의 오류를 명시 적으로 처리합니다. 4. 성능을 최적화하기 위해 GomaxProc을 이해하십시오. 이러한 관행은 효율적이고 강력한 소프트웨어 개발에 효과적이며 자원의 효과적인 관리, 적절한 동기화 구현, 적절한 오류 처리 및 성능 최적화를 보장하여 소프트웨어 효율성 및 유지 관리 가능성을 향상시킬 수 있기 때문입니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
