Rumah > pembangunan bahagian belakang > Golang > Sijil TLS dan X.: Pasport Digital Anda dan Terowong Selamat, Go Crypto 7

Sijil TLS dan X.: Pasport Digital Anda dan Terowong Selamat, Go Crypto 7

Linda Hamilton
Lepaskan: 2024-11-21 03:42:16
asal
774 orang telah melayarinya

TLS and X. Certificates: Your Digital Passport and Secure Tunnel, Go Crypto 7

Hai, penjelajah kripto! Bersedia untuk menyelami dunia sijil TLS dan X.509? Anggap ini sebagai pasport digital anda dan terowong selamat untuk perjalanan internet anda. Mari lihat bagaimana Go membantu kami menavigasi aspek keselamatan Internet yang penting ini!

Sijil X.509: Pasport Digital Anda

Pertama sekali, mari bercakap tentang sijil X.509. Ini seperti pasport digital yang membuktikan identiti entiti di internet. Mari lihat bagaimana kita boleh bekerjasama dengan mereka dalam Go:

Membaca Pasport Digital Anda

Begini cara anda boleh membaca dan menghuraikan sijil X.509:

import (
    "crypto/x509"
    "encoding/pem"
    "fmt"
    "io/ioutil"
)

func main() {
    // Let's read our digital passport
    certPEM, err := ioutil.ReadFile("my_digital_passport.pem")
    if err != nil {
        panic("Oops! We lost our passport!")
    }

    // Decode the PEM block (it's like opening the passport)
    block, _ := pem.Decode(certPEM)
    if block == nil {
        panic("This doesn't look like a passport...")
    }

    // Parse the certificate (reading the passport details)
    cert, err := x509.ParseCertificate(block.Bytes)
    if err != nil {
        panic("We can't read this passport!")
    }

    // Let's see what's in our passport
    fmt.Printf("Passport owner: %s\n", cert.Subject)
    fmt.Printf("Passport issuer: %s\n", cert.Issuer)
    fmt.Printf("Valid from: %s\n", cert.NotBefore)
    fmt.Printf("Valid until: %s\n", cert.NotAfter)
}
Salin selepas log masuk

Mencipta Pasport Digital Anda Sendiri (Sijil Ditandatangani Sendiri)

Kadangkala, anda mungkin perlu mencipta pasport digital anda sendiri untuk ujian. Begini caranya:

import (
    "crypto/ecdsa"
    "crypto/elliptic"
    "crypto/rand"
    "crypto/x509"
    "crypto/x509/pkix"
    "encoding/pem"
    "math/big"
    "os"
    "time"
)

func main() {
    // Let's create our secret key
    privateKey, err := ecdsa.GenerateKey(elliptic.P256(), rand.Reader)
    if err != nil {
        panic("Our key generator is feeling shy!")
    }

    // Now, let's fill out our passport application
    template := x509.Certificate{
        SerialNumber: big.NewInt(1),
        Subject: pkix.Name{
            Organization: []string{"Gopher's Cryptographic Adventures"},
        },
        NotBefore: time.Now(),
        NotAfter:  time.Now().Add(time.Hour * 24 * 180), // Valid for 180 days

        KeyUsage:              x509.KeyUsageKeyEncipherment | x509.KeyUsageDigitalSignature,
        ExtKeyUsage:           []x509.ExtKeyUsage{x509.ExtKeyUsageServerAuth},
        BasicConstraintsValid: true,
    }

    // Time to create our passport!
    derBytes, err := x509.CreateCertificate(rand.Reader, &template, &template, &privateKey.PublicKey, privateKey)
    if err != nil {
        panic("The passport printer is jammed!")
    }

    // Let's save our new passport
    certOut, err := os.Create("my_new_passport.pem")
    if err != nil {
        panic("We can't save our new passport!")
    }
    pem.Encode(certOut, &pem.Block{Type: "CERTIFICATE", Bytes: derBytes})
    certOut.Close()

    // And let's keep our secret key safe
    keyOut, err := os.Create("my_secret_key.pem")
    if err != nil {
        panic("We can't save our secret key!")
    }
    pem.Encode(keyOut, &pem.Block{Type: "EC PRIVATE KEY", Bytes: x509.MarshalECPrivateKey(privateKey)})
    keyOut.Close()

    fmt.Println("Congratulations! You've got a new digital passport!")
}
Salin selepas log masuk

TLS: Terowong Selamat Anda

Sekarang kita mempunyai pasport digital, mari kita gunakannya untuk mencipta terowong selamat untuk perjalanan internet kita. Di sinilah TLS masuk.

Menyediakan Pelayan Selamat (Pelayan HTTPS)

Berikut ialah cara anda boleh menyediakan pelayan selamat yang menggunakan pasport digital anda:

import (
    "crypto/tls"
    "fmt"
    "net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "Welcome to our secure tunnel!")
}

func main() {
    http.HandleFunc("/", handler)

    // Let's load our digital passport and secret key
    cert, err := tls.LoadX509KeyPair("my_new_passport.pem", "my_secret_key.pem")
    if err != nil {
        panic("We can't find our passport or secret key!")
    }

    // Now, let's set up our secure tunnel
    tlsConfig := &tls.Config{
        Certificates: []tls.Certificate{cert},
    }

    // Time to open our secure office
    server := &http.Server{
        Addr:      ":443",
        TLSConfig: tlsConfig,
    }

    // Let's start welcoming visitors!
    fmt.Println("Our secure office is open at https://localhost:443")
    err = server.ListenAndServeTLS("", "")
    if err != nil {
        panic("Oops! We couldn't open our office!")
    }
}
Salin selepas log masuk

Mencipta Pelanggan yang Selamat

Sekarang, mari buat pelanggan yang boleh melawati pelayan selamat kami:

import (
    "crypto/tls"
    "crypto/x509"
    "fmt"
    "io/ioutil"
    "net/http"
)

func main() {
    // Let's load the passport of the server we want to visit
    certPool := x509.NewCertPool()
    pem, err := ioutil.ReadFile("server_passport.pem")
    if err != nil {
        panic("We can't find the server's passport!")
    }
    if !certPool.AppendCertsFromPEM(pem) {
        panic("This doesn't look like a valid passport...")
    }

    // Now, let's prepare for our secure journey
    tlsConfig := &tls.Config{
        RootCAs: certPool,
    }

    // Time to create our secure transport
    client := &http.Client{
        Transport: &http.Transport{
            TLSClientConfig: tlsConfig,
        },
    }

    // Let's visit the secure server!
    resp, err := client.Get("https://example.com")
    if err != nil {
        panic("Our secure journey failed!")
    }
    defer resp.Body.Close()

    // What did the server say?
    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        panic("We couldn't understand the server's message!")
    }
    fmt.Printf("The server says: %s\n", body)
}
Salin selepas log masuk

Peraturan Emas Pasport Digital dan Terowong Selamat

Sekarang anda sudah mahir dalam pasport digital dan terowong selamat, berikut ialah beberapa peraturan emas yang perlu diingat:

  1. Sentiasa gunakan model terkini: Gunakan TLS 1.2 atau lebih baru. Model lama mempunyai beberapa kelemahan keselamatan yang serius.

  2. Periksa pasport tersebut dengan teliti: Sentiasa sahkan sijil dengan betul. Semak nama, tarikh tamat tempoh, semuanya!

  3. Dapatkan pasport anda daripada pihak berkuasa yang dipercayai: Untuk kegunaan dunia sebenar, dapatkan sijil daripada Pihak Berkuasa Sijil yang dipercayai. Sijil yang ditandatangani sendiri bagus untuk ujian, tetapi bukan untuk pengeluaran.

  4. Sematkan sijil tersebut: Untuk operasi super rahsia, laksanakan penyematan sijil. Ia seperti mempunyai ejen TSA tertentu yang anda percayai untuk menyemak pasport anda.

  5. Perbaharui pasport anda dengan kerap: Kemas kini dan putar sijil dan kunci anda. Jangan tunggu sehingga tamat tempoh!

  6. Gunakan dakwat berkualiti baik: Sentiasa gunakan penjanaan nombor rawak selamat untuk semua operasi crypto anda.

  7. Rahsiakan kunci rahsia anda: Jangan sekali-kali, dedahkan kunci peribadi dalam log atau mesej ralat. Ia seperti menyiarkan kata laluan anda kepada dunia!

  8. Kendalikan masalah dengan anggun: Laksanakan pengendalian ralat yang betul untuk semua operasi TLS. Jangan biarkan cegukan kecil bertukar menjadi bencana keselamatan.

  9. Pertimbangkan pembaharuan pasport automatik: Lihat alatan seperti Let's Encrypt untuk pengurusan sijil yang lebih mudah. Ia seperti mempunyai perkhidmatan yang memperbaharui pasport anda secara automatik!

Apa Seterusnya?

Tahniah! Anda baru sahaja menguasai seni pasport digital dan terowong selamat. Ini penting untuk memastikan data anda selamat semasa ia merentasi internet liar.

Ingat, dalam dunia kriptografi, memahami asas ini adalah penting. Ia seperti mempelajari peraturan perjalanan antarabangsa - penting untuk perjalanan selamat di dunia digital. Kuasai ini dan anda akan berjaya mencipta aplikasi yang selamat dan disahkan dalam Go.

Jadi, bagaimana pula jika anda cuba menyediakan pelayan web yang selamat? Atau mungkin buat pelanggan yang boleh berkomunikasi dengan selamat dengan perkhidmatan HTTPS sedia ada? Dunia komunikasi internet selamat berada di hujung jari anda! Selamat mengekod, juara kripto!

Atas ialah kandungan terperinci Sijil TLS dan X.: Pasport Digital Anda dan Terowong Selamat, Go Crypto 7. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan