[args]: args1 對生成的私鑰文件是否要使用加密算法進行對稱加密: -des : CBC模式的DES加密 -des3 : CBC模式的3DES加密 -aes128 : CBC模式的AES128加密 -aes192 : CBC模式的AES192加密 -aes256 : CBC模式的AES256加密 args2 對稱加密密碼 -passout passwords 其中passwords爲對稱加密(des、3des、aes)的密碼(使用這個參數就省去了console交互提示輸入密碼的環節) args3 輸出文件 -out file : 輸出證書私鑰文件 [numbits]: 密鑰長度,理解爲私鑰長度
[args] args1 是輸入輸入文件格式:-inform arg -inform DER 使用輸入文件格式爲 DER -inform PEM 使用輸入文件格式爲 PEM args2 輸出文件格式:-outform arg -outform DER 使用輸出文件格式爲 DER -outform PEM 使用輸出文件格式爲 PEM args3 是待處理文件 -in inputfilepath args4 待輸出文件 -out outputfilepath args5 用於簽名待生成的請求證書的私鑰文件的解密密碼 -passin passwords args6 用於簽名待生成的請求證書的私鑰文件 -key file args7 指定輸入密鑰的編碼格式 -keyform arg -keyform DER -keyform NET -keyform PEM args8 生成新的證書請求 -new args9 輸出一個 X509 格式的證書,簽名證書時使用 -x509 args10 使用 X509 簽名證書的有效時間 -days // -days 3650 有效期 10 年 args11 生成一個 bits 長度的 RSA 私鑰文件,用於簽發,與-key互斥,生成證書請求或者自簽名證書時自動生成密鑰,而後生成的密鑰名稱由 -keyout 參數指定 -newkey rsa:bits args12 設置 HASH 算法-[digest],指定對建立請求時提供的申請者信息進行數字簽名時指定的 hash 算法 -md5 -sha1 // 高版本瀏覽器開始不信任這種算法 -md2 -mdc2 -md4 args13 指定 openssl 配置文件,不少內容不容易經過參數配置,能夠指定配置文件 -config filepath args14 顯示格式 txt(用於查看證書、私鑰信息) -text
[args] args1 是輸入輸入文件格式:-inform arg -inform DER 使用輸入文件格式爲 DER -inform PEM 使用輸入文件格式爲 PEM args2 輸出文件格式:-outform arg -outform DER 使用輸出文件格式爲 DER -outform PEM 使用輸出文件格式爲 PEM args3 是待處理 X509 證書文件 -in inputfilepath args4 待輸出 X509 證書文件 -out outputfilepath args5 代表輸入文件是一個「請求籤發證書文件(CSR)」,等待進行簽發 -req args6 簽名證書的有效時間 -days // -days 3650 有效期 10 年 args7 指定用於簽發請求證書的根 CA 證書 -CA arg args8 根 CA 證書格式(默認是 PEM) -CAform arg args9 指定用於簽發請求證書的 CA 私鑰證書文件 -CAkey arg args10 指定根 CA 私鑰證書文件格式(默認爲 PEM 格式) -CAkeyform arg args11 指定序列號文件(serial number file) -CAserial arg args12 若是序列號文件(serial number file)沒有指定,則自動建立它 -CAcreateserial args12 設置 HASH 算法-[digest],指定對建立請求時提供的申請者信息進行數字簽名時指定的 hash 算法 -md5 -sha1 // 高版本瀏覽器開始不信任這種算法 -md2 -mdc2 -md4
package main import ( "io" "log" "net/http" ) func main() { http.HandleFunc("/", func(w http.ResponseWriter, req *http.Request) { io.WriteString(w, "hello, world!\n") }) if e := http.ListenAndServeTLS("0.0.0.0:5200", "/home/ao/Documents/certs/review/server.crt", "/home/ao/Documents/certs/review/server.key", nil); e != nil { log.Fatal("ListenAndServe: ", e) } //if e := http.ListenAndServe("0.0.0.0:5200", nil); e != nil { // log.Fatal("ListenAndServe: ", e) //} }
package main import ( "crypto/tls" "crypto/x509" "io" "io/ioutil" "log" "net/http" "os" ) func loadCA(caFile string) *x509.CertPool { pool := x509.NewCertPool() ca, err := ioutil.ReadFile(caFile) if err != nil { log.Fatal("ReadFile: ", err) } pool.AppendCertsFromPEM(ca) return pool } func main() { //c := &http.Client{ // Transport: &http.Transport{ // TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, // }} c := &http.Client{ Transport: &http.Transport{ TLSClientConfig: &tls.Config{RootCAs: loadCA("/home/ao/Documents/certs/review/server.crt")}, }} resp, err := c.Get("https://localhost:5200") if err != nil { log.Fatal("http.Client.Get: ", err) } defer resp.Body.Close() io.Copy(os.Stdout, resp.Body) }
$ go run client.go
hello, world!
$ go run client.go 2019/09/30 15:11:41 http.Client.Get: Get https://127.0.0.1:5200: x509: cannot validate certificate for 127.0.0.1 because it doesn't contain any IP SANs exit status 1
2019/09/30 15:11:41 http: TLS handshake error from 127.0.0.1:33596: remote error: tls: bad certificate
$ go run client.go 2019/09/30 15:11:41 http.Client.Get: Get https://127.0.0.1:5200: x509: cannot validate certificate for 127.0.0.1 because it doesn't contain any IP SANs exit status 1
$ go run client.go 2019/09/30 15:19:24 http.Client.Get: Get https://127.0.0.1:5200: x509: cannot validate certificate for 127.0.0.1 because it doesn't contain any IP SANs exit status 1
$ openssl genrsa -out server.key 2048 $ echo subjectAltName = IP:127.0.0.1 > extfile.cnf $ openssl x509 -req -sha256 -days 365 -in server.csr -signkey server.key -extfile extfile.cnf -out server.crt
$ openssl genrsa -out ca.key 2048 $ openssl req -x509 -new -nodes -key ca.key -days 10000 -out ca.crt -subj "/CN=localhost.ca.com"
$ openssl genrsa -out server.key 2048 $ openssl req -new -key server.key -subj "/CN=127.0.0.1" -out server.csr $ openssl x509 -req -sha256 -days 365 -in server.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out server.crt -extfile extfile.cnf
[req] distinguished_name = req_distinguished_name req_extensions = v3_req [req_distinguished_name] countryName = CN countryName_default = CN stateOrProvinceName = Beijing stateOrProvinceName_default = Beijing localityName = Beijing localityName_default = Beijing organizationName = WangAo organizationName_default = WangAo organizationalUnitName = Dev organizationalUnitName_default = Dev commonName = test.openssl.com commonName_default = test.openssl.com commonName_max = 64 [v3_req] basicConstraints = CA:TRUE subjectAltName = @alt_names [alt_names] DNS.1 = test.openssl.com IP.1 = 127.0.0.1 IP.2 = 10.0.2.15
$ openssl genrsa -out server.key 2048 $ openssl req -nodes -new -key server.key -out server.csr -subj "/CN=test.openssl.com" $ openssl x509 -req -sha256 -days 365 -in server.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out server.crt -extensions v3_req -extfile openssl.cnf