-
-
Save preetampvp/7c5a6fd17a7aaa533ef6cd050148af26 to your computer and use it in GitHub Desktop.
SSL Client Authentication Golang sample
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| package main | |
| import ( | |
| "crypto/tls" | |
| "crypto/x509" | |
| "flag" | |
| "io/ioutil" | |
| "log" | |
| "net/http" | |
| ) | |
| var ( | |
| certFile = flag.String("cert", "someCertFile", "A PEM eoncoded certificate file.") | |
| keyFile = flag.String("key", "someKeyFile", "A PEM encoded private key file.") | |
| caFile = flag.String("CA", "someCertCAFile", "A PEM eoncoded CA's certificate file.") | |
| ) | |
| func main() { | |
| flag.Parse() | |
| // Load client cert | |
| cert, err := tls.LoadX509KeyPair(*certFile, *keyFile) | |
| if err != nil { | |
| log.Fatal(err) | |
| } | |
| // Load CA cert | |
| caCert, err := ioutil.ReadFile(*caFile) | |
| if err != nil { | |
| log.Fatal(err) | |
| } | |
| caCertPool := x509.NewCertPool() | |
| caCertPool.AppendCertsFromPEM(caCert) | |
| // Setup HTTPS client | |
| tlsConfig := &tls.Config{ | |
| Certificates: []tls.Certificate{cert}, | |
| RootCAs: caCertPool, | |
| } | |
| tlsConfig.BuildNameToCertificate() | |
| transport := &http.Transport{TLSClientConfig: tlsConfig} | |
| client := &http.Client{Transport: transport} | |
| // Do GET something | |
| resp, err := client.Get("https://goldportugal.local:8443") | |
| if err != nil { | |
| log.Fatal(err) | |
| } | |
| defer resp.Body.Close() | |
| // Dump response | |
| data, err := ioutil.ReadAll(resp.Body) | |
| if err != nil { | |
| log.Fatal(err) | |
| } | |
| log.Println(string(data)) | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment