>  기사  >  백엔드 개발  >  Go 웹 서버에서 HTTPS용 PEM 인증서를 연결하는 방법은 무엇입니까?

Go 웹 서버에서 HTTPS용 PEM 인증서를 연결하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-10 14:07:02477검색

How to Concatenate PEM Certificates for HTTPS in Go Web Servers?

Go 웹 서버에서 HTTPS용 PEM 인증서 연결

Go 웹 서버에 HTTPS를 설정할 때 연결해야 하는 경우가 종종 있습니다. 여러 PEM 인증서 파일. 이 프로세스는 기본 인증서와 중간 인증서를 모두 포함하는 완전한 인증서 체인을 만드는 데 필수적입니다.

중간 인증서 얻기

일반적으로 번들이 제공됩니다. SSL 인증서 구매 시

  • csr.pem(무시)
  • private-key.pem(개인 키)
  • 웹사이트를 포함한 PEM 파일. com.crt(기본 인증서)
  • website.com.ca-bundle(중간 인증서)
  • website.com.zip(번들의 압축 버전)

인증서 연결

https://www.kaihag.com/https-and-go/의 설명서에 따라 다음 PEM 파일을 연결해야 합니다.

  • website.com.ca-bundle(중간 인증서)
  • website.com.crt(기본 인증서)

이를 수행하려면 다음을 수행합니다. 다음 명령을 사용하십시오(파일이 현재 디렉터리에 있다고 가정):

cat website.com.ca-bundle website.com.crt > full-cert.crt

이렇게 하면 중간 인증서와 기본 인증서가 모두 포함된 full-cert.crt라는 결합된 인증서 파일이 생성됩니다.

Go에서 HTTPS 설정

연결된 인증서 파일이 있으면 http.ListenAndServeTLS 기능을 사용하여 Go에서 HTTPS 서버를 시작할 수 있습니다. 다음은 예제 코드 조각입니다.

package main

import (
    "log"
    "net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("Hello, HTTPS!"))
}

func main() {
    log.Printf("About to listen on 10443. Go to https://127.0.0.1:10443/")
    err := http.ListenAndServeTLS(":10443", "full-cert.crt", "private-key.pem", nil)
    log.Fatal(err)
}

full-cert.crt를 연결된 인증서 파일 이름으로 바꾸고, private-key.pem을 개인 키 파일 이름으로 바꿉니다. 프로그램을 실행하고 https://127.0.0.1:10443/에 접속하여 HTTPS가 제대로 작동하는지 확인하세요.

위 내용은 Go 웹 서버에서 HTTPS용 PEM 인증서를 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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