Rumah pembangunan bahagian belakang Golang Laksanakan pengesahan dan kebenaran API asas menggunakan Go

Laksanakan pengesahan dan kebenaran API asas menggunakan Go

Jun 17, 2023 pm 07:51 PM
go membenarkan pensijilan api

Dengan pembangunan aplikasi web yang berterusan, apabila aplikasi secara beransur-ansur menjadi lebih besar dan lebih besar, antara muka API perlu dilindungi untuk menghalang akses rawak, jadi mekanisme pengesahan dan kebenaran API menjadi lebih penting. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Go untuk melaksanakan pengesahan dan kebenaran API asas.

Pertama, mari kita fahami konsep asas pengesahan dan kebenaran:

Pengesahan: Pengesahan ialah mekanisme pengesahan identiti yang digunakan untuk mengesahkan sama ada identiti yang diminta oleh pengguna adalah sah. Dalam aplikasi web, pengesahan boleh melalui nama pengguna dan kata laluan atau menggunakan token seperti JWT.

Keizinan: Keizinan ialah mekanisme pengesahan kebenaran yang digunakan untuk menentukan sama ada pengguna mempunyai hak untuk mengakses sumber yang diminta. Dalam aplikasi web, kebenaran boleh dilakukan melalui kawalan akses berasaskan peranan atau token akses.

Melaksanakan pengesahan dan kebenaran API asas dalam Go boleh dibahagikan kepada langkah berikut:

Langkah 1: Pasang dan konfigurasikan rangka kerja Gin

Sebelum menggunakan rangka kerja Gin, anda perlu memasangnya terlebih dahulu. Kita boleh memasangnya menggunakan arahan berikut:

go get -u github.com/gin-gonic/gin
Salin selepas log masuk

Selepas pemasangan selesai, kita boleh memulakan rangka kerja Gin menggunakan kod berikut:

import "github.com/gin-gonic/gin"

router := gin.Default()
Salin selepas log masuk

Langkah 2: Tambah penghalaan

Sebelum kami mula menambah Sebelum penghalaan, anda perlu menentukan fungsi perisian tengah untuk mengesahkan sama ada pengguna itu sah. Fungsi middleware menyemak pengepala permintaan masuk dan mengembalikan kod status dan mesej ralat kepada pengendali.

func AuthMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        // 验证用户是否合法
        if userValid {
            c.Set("user", "valid")
            c.Next()
        } else {
            c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"error": "Unauthorized"})
        }
    }
}
Salin selepas log masuk

Kami boleh menambah fungsi middleware dalam fungsi penghalaan untuk memastikan bahawa hanya pengguna yang disahkan boleh mengakses sumber yang diperlukan.

router.GET("/secured", AuthMiddleware(), func(c *gin.Context) {
    c.JSON(http.StatusOK, gin.H{"message": "You are authorized to access this resource"})
})
Salin selepas log masuk

Dalam kod di atas, permintaan GET akan dihalakan ke titik akhir /secured, tetapi hanya pengguna yang disahkan akan dapat mengaksesnya dengan jayanya.

Langkah 3: Laksanakan Pengesahan JWT

Kini kami telah menambah laluan dan menggunakan perisian tengah untuk memastikan pengguna disahkan untuk mengakses laluan. Seterusnya, kita akan melihat cara untuk mengesahkan pengguna menggunakan JWT.

JWT ialah token web berasaskan JSON yang menyediakan cara selamat untuk memindahkan maklumat antara pelanggan dan pelayan. JWT biasanya terdiri daripada tiga bahagian: pengepala, muatan dan tandatangan. Pengepala mengandungi jenis token dan algoritma tandatangan, muatan mengandungi data token dan tandatangan digunakan untuk mengesahkan integriti token.

Kami boleh melaksanakan pengesahan JWT dalam Go menggunakan kod berikut:

import (
    "time"

    "github.com/dgrijalva/jwt-go"
)

func CreateToken() (string, error) {
    token := jwt.New(jwt.SigningMethodHS256)
    claims := token.Claims.(jwt.MapClaims)
    claims["user"] = "john@example.com"
    claims["exp"] = time.Now().Add(time.Hour * 24).Unix()

    tokenString, err := token.SignedString([]byte("secret"))
    if err != nil {
        return "", err
    }

    return tokenString, nil
}
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mencipta token JWT dan kemudian menambah tuntutan pengguna bersama-sama dengan masa tamat tempoh. Akhirnya, token ditandatangani dan hasilnya dikembalikan.

Langkah 4: Laksanakan kebenaran berasaskan peranan

Dalam langkah terakhir, kita akan mempelajari cara menggunakan kebenaran berasaskan peranan untuk mengawal akses pengguna kepada sumber.

Dalam kawalan akses berasaskan peranan, pengguna diberikan kepada satu atau lebih peranan dan setiap peranan diberikan satu set kebenaran. Apabila mengakses sumber, pusat kebenaran menentukan sumber yang boleh diakses oleh pengguna berdasarkan peranan mereka.

Kami boleh melaksanakan kebenaran berasaskan peranan mudah menggunakan kod berikut:

func AuthzMiddleware(roles ...string) gin.HandlerFunc {
    return func(c *gin.Context) {
        userRole := "admin" // 从数据库或其他地方获取用户角色

        for _, role := range roles {
            if role == userRole {
                c.Next()
                return
            }
        }

        c.AbortWithStatusJSON(http.StatusForbidden, gin.H{"error": "Forbidden"})
    }
}
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan fungsi middleware AuthzMiddleware yang menerima senarai peranan sebagai parameter dan semak sama ada peranan pengguna disertakan. Jika pengguna mempunyai peranan yang diperlukan, lulus perisian tengah dan teruskan ke pengendali seterusnya jika tidak, kembalikan kod status Terlarang.

Akhir sekali, kami boleh menambah fungsi AuthzMiddleware pada laluan untuk memastikan bahawa hanya pengguna dengan peranan tertentu mempunyai akses kepada sumber yang diperlukan.

router.GET("/admin", AuthMiddleware(), AuthzMiddleware("admin"), func(c *gin.Context) {
    c.JSON(http.StatusOK, gin.H{"message": "You are authorized to access this resource"})
})
Salin selepas log masuk

Di atas ialah langkah asas untuk melaksanakan pengesahan dan kebenaran API asas menggunakan Go. Pelaksanaan asas ini boleh berfungsi sebagai asas untuk aplikasi dan boleh disesuaikan dan diperluaskan lagi mengikut keperluan.

Atas ialah kandungan terperinci Laksanakan pengesahan dan kebenaran API asas menggunakan Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menghantar mesej Go WebSocket? Bagaimana untuk menghantar mesej Go WebSocket? Jun 03, 2024 pm 04:53 PM

Dalam Go, mesej WebSocket boleh dihantar menggunakan pakej gorila/soket web. Langkah khusus: Wujudkan sambungan WebSocket. Hantar mesej teks: Panggil WriteMessage(websocket.TextMessage,[]bait("Mesej")). Hantar mesej binari: panggil WriteMessage(websocket.BinaryMessage,[]bait{1,2,3}).

Pemahaman mendalam tentang kitaran hayat fungsi Golang dan skop pembolehubah Pemahaman mendalam tentang kitaran hayat fungsi Golang dan skop pembolehubah Apr 19, 2024 am 11:42 AM

Dalam Go, kitaran hayat fungsi termasuk definisi, pemuatan, pemautan, pemulaan, panggilan dan skop pembolehubah dibahagikan kepada tahap fungsi dan tahap blok Pembolehubah dalam fungsi boleh dilihat secara dalaman, manakala pembolehubah dalam blok hanya kelihatan dalam blok .

Bagaimana untuk memadankan cap masa menggunakan ungkapan biasa dalam Go? Bagaimana untuk memadankan cap masa menggunakan ungkapan biasa dalam Go? Jun 02, 2024 am 09:00 AM

Dalam Go, anda boleh menggunakan ungkapan biasa untuk memadankan cap masa: susun rentetan ungkapan biasa, seperti yang digunakan untuk memadankan cap masa ISO8601: ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ . Gunakan fungsi regexp.MatchString untuk menyemak sama ada rentetan sepadan dengan ungkapan biasa.

Perbezaan antara bahasa Golang dan Go Perbezaan antara bahasa Golang dan Go May 31, 2024 pm 08:10 PM

Bahasa Go dan Go adalah entiti yang berbeza dengan ciri yang berbeza. Go (juga dikenali sebagai Golang) terkenal dengan kesesuaiannya, kelajuan penyusunan pantas, pengurusan memori dan kelebihan merentas platform. Kelemahan bahasa Go termasuk ekosistem yang kurang kaya berbanding bahasa lain, sintaks yang lebih ketat dan kekurangan penaipan dinamik.

Bagaimana untuk mengelakkan kebocoran memori dalam pengoptimuman prestasi teknikal Golang? Bagaimana untuk mengelakkan kebocoran memori dalam pengoptimuman prestasi teknikal Golang? Jun 04, 2024 pm 12:27 PM

Kebocoran memori boleh menyebabkan memori program Go terus meningkat dengan: menutup sumber yang tidak lagi digunakan, seperti fail, sambungan rangkaian dan sambungan pangkalan data. Gunakan rujukan yang lemah untuk mengelakkan kebocoran memori dan objek sasaran untuk pengumpulan sampah apabila ia tidak lagi dirujuk dengan kuat. Menggunakan go coroutine, memori tindanan coroutine akan dikeluarkan secara automatik apabila keluar untuk mengelakkan kebocoran memori.

Panduan untuk menguji unit fungsi serentak Go Panduan untuk menguji unit fungsi serentak Go May 03, 2024 am 10:54 AM

Unit menguji fungsi serentak adalah penting kerana ini membantu memastikan kelakuan mereka yang betul dalam persekitaran serentak. Prinsip asas seperti pengecualian bersama, penyegerakan dan pengasingan mesti dipertimbangkan semasa menguji fungsi serentak. Fungsi serentak boleh diuji unit dengan mensimulasikan, menguji keadaan perlumbaan dan mengesahkan keputusan.

Perkara yang perlu diambil perhatian apabila fungsi Golang menerima parameter peta Perkara yang perlu diambil perhatian apabila fungsi Golang menerima parameter peta Jun 04, 2024 am 10:31 AM

Apabila menghantar peta ke fungsi dalam Go, salinan akan dibuat secara lalai dan pengubahsuaian pada salinan tidak akan menjejaskan peta asal. Jika anda perlu mengubah suai peta asal, anda boleh menghantarnya melalui penuding. Peta kosong perlu dikendalikan dengan berhati-hati, kerana ia secara teknikal adalah penunjuk sifar, dan menghantar peta kosong kepada fungsi yang menjangkakan peta tidak kosong akan menyebabkan ralat.

Bagaimana untuk menggunakan pembungkus ralat Golang? Bagaimana untuk menggunakan pembungkus ralat Golang? Jun 03, 2024 pm 04:08 PM

Dalam Golang, pembalut ralat membolehkan anda membuat ralat baharu dengan menambahkan maklumat kontekstual kepada ralat asal. Ini boleh digunakan untuk menyatukan jenis ralat yang dilemparkan oleh perpustakaan atau komponen yang berbeza, memudahkan penyahpepijatan dan pengendalian ralat. Langkah-langkahnya adalah seperti berikut: Gunakan fungsi ralat. Balut untuk membalut ralat asal kepada ralat baharu. Ralat baharu mengandungi maklumat kontekstual daripada ralat asal. Gunakan fmt.Printf untuk mengeluarkan ralat yang dibalut, memberikan lebih konteks dan kebolehtindakan. Apabila mengendalikan pelbagai jenis ralat, gunakan fungsi ralat. Balut untuk menyatukan jenis ralat.

See all articles