Golang : Disable security check for HTTPS(SSL) with bad or expired certificate
There are times when a webmaster failed to renew the certificates from SSL connection in time or some other reason for the SSL certificates to expire. A friend of mine has a Golang program that will download data from an external website. However, the program failed recently because of the external website's expired SSL certificates.
This tutorial is a note from helping a friend today to create a custom HTTP transport client in Golang. It is to handle data retrieval for web server with expired SSL certificates by skipping security check. Basically, just a custom HTTP transport client disabled security check.
Hope you may find it useful when you encounter the similar situation in future.
Here you go!
package main
import (
"crypto/tls"
"fmt"
"io/ioutil"
"net/http"
"os"
)
func main() {
transCfg := &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, // ignore expired SSL certificates
}
client := &http.Client{Transport: transCfg}
response, err := client.Get("https://socketloop.com/")
if err != nil {
fmt.Println(err)
os.Exit(1)
}
defer response.Body.Close()
htmlData, err := ioutil.ReadAll(response.Body)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
fmt.Println(os.Stdout, string(htmlData))
}
NOTE : In a production system, it would be wise to use InsecureSkipVerify : true
parameter if the normal/secure method failed. Use it as a fallback method rather than the "normal" method. Remember to send a notification, log message or email to the system administrator if the fallback method is activated.
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+5.2k Golang : The Tao of importing package
+19.2k Golang : Populate dropdown with html/template example
+12.1k Golang : md5 hash of a string
+24.5k Golang : Change file read or write permission example
+21.9k Golang : Use TLS version 1.2 and enforce server security configuration over client
+14.3k Golang : Get uploaded file name or access uploaded files
+7.8k Golang : Load DSA public key from file example
+5.7k Golang : ROT32768 (rotate by 0x80) UTF-8 strings example
+19.7k Golang : Archive directory with tar and gzip
+15.2k Golang : Save(pipe) HTTP response into a file
+5.9k Golang : Shuffle array of list
+10k Golang : Setting variable value with ldflags