<var id="qxa1c"><thead id="qxa1c"><address id="qxa1c"></address></thead></var>
  • \n
    \n\n\n\n

    The index.html is a simple web page that provides a user interface for displaying the login status of a user. It uses Bootstrap for styling and Font Awesome for icons. On page load, it checks the user's authentication status by sending a request to the server with a JWT token stored in localStorage. If the user is logged in, it shows a success message with the user's name and a logout button. If not logged in, it shows a message indicating the user is not logged in and redirects them to the login page after a few seconds.<\/p>\n\n

    \n \n \n login.html\n<\/h3>\n\n\n\n
    \n\n\n    \n    \n    \n    \n<\/head>\n
    

    亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

    \n
    \n\n\n\n

    The login.html page provides a simple login form where users can input their username and password. It uses Bootstrap for styling and Font Awesome for icons. When the user submits the form, a JavaScript function login() sends a POST request to the \/login endpoint with the entered credentials. If the login is successful, the server returns a JWT token, which is stored in localStorage. The page then redirects the user to the home page (\/). If the login fails, an error message is displayed.<\/p>\n\n

    \n \n \n Run project\n<\/h2>\n\n\n\n
    go run main.go\n<\/pre>\n\n\n\n

    ?ffnen Sie den Webbrowser und gehen Sie zu http:\/\/localhost:8080

    \nSie finden diese Testseite.<\/p>\n\n

    \"Implementing<\/p>

    \n \n \n Testen\n<\/h2>\n\n

    Nach ein paar Sekunden werden Sie zur Anmeldeseite weitergeleitet.<\/p>\n\n

    \"Implementing<\/p>\n\n

    Drücken Sie die Anmeldeschaltfl?che und Sie werden auf der Startseite angemeldet, auf der der Name des angemeldeten Benutzers angezeigt wird.<\/p>\n\n

    \"Implementing<\/p>\n\n

    Versuchen Sie, den Browser zu aktualisieren, und Sie werden sehen, dass Sie immer noch angemeldet sind. Klicken Sie dann auf die Schaltfl?che ?Abmelden“. Das JWT-Token wird entfernt und Sie werden erneut zur Anmeldeseite weitergeleitet.<\/p>\n\n

    \"Implementing<\/p>\n\n

    \n \n \n Abschluss\n<\/h2>\n\n

    Zusammenfassend l?sst sich sagen, dass die Implementierung der JWT-Authentifizierung in einer Go-API einen sicheren und skalierbaren Ansatz für die Benutzerauthentifizierung bietet. Durch die Verwendung des Gin-Frameworks zusammen mit dem Paket golang-jwt\/jwt k?nnen wir die tokenbasierte Authentifizierung problemlos in unsere Anwendung integrieren. JWT-Tokens werden w?hrend der Anmeldung generiert, um Benutzeranmeldeinformationen sicher zu validieren und Zugriff auf geschützte Routen zu gew?hren. Die Middleware stellt sicher, dass nur authentifizierte Benutzer auf diese Routen zugreifen k?nnen, indem sie die Gültigkeit des Tokens überprüft. Dieser zustandslose Authentifizierungsmechanismus bietet verbesserte Leistung und Flexibilit?t und ist somit eine ideale Wahl für moderne API-Architekturen.<\/p>\n\n

    Quellcode: https:\/\/github.com\/stackpuz\/Example-JWT-Go<\/p>\n\n

    Erstellen Sie in wenigen Minuten eine CRUD-Web-App: https:\/\/stackpuz.com<\/p>\n\n\n \n\n \n <\/pre><\/pre>"}

    Heim Backend-Entwicklung Golang Implementierung der JWT-Authentifizierung in der Go-API

    Implementierung der JWT-Authentifizierung in der Go-API

    Dec 27, 2024 pm 08:56 PM

    Implementing JWT Authentication in Go API

    JWT (JSON Web Token) ist eine ?u?erst effektive Methode zum Sichern von APIs durch tokenbasierte Authentifizierung und stellt sicher, dass nur authentifizierte Benutzer auf Ihre API-Endpunkte zugreifen k?nnen. Im Gegensatz zu herk?mmlichen sitzungsbasierten Ans?tzen ist JWT zustandslos, sodass keine serverseitige Sitzungsspeicherung erforderlich ist, was es ideal für skalierbare und leistungsstarke Anwendungen macht. In diesem Leitfaden führen wir Sie durch die Implementierung der JWT-Authentifizierung in einer Go-API, von der Generierung von Tokens bei der Benutzeranmeldung bis hin zur Sicherung Ihrer Endpunkte durch Validierung dieser Tokens, um letztendlich die Sicherheit und Robustheit der Daten und Ressourcen Ihrer Anwendung zu verbessern.

    Voraussetzungen

    • Gehen Sie 1,21

    Setup-Projekt

    go mod init app
    go get github.com/gin-gonic/gin@v1.5.0
    go get github.com/golang-jwt/jwt
    go get github.com/joho/godotenv 
    

    Projektstruktur

    ├─ .env
    ├─ main.go
    ├─ middleware
    │  └─ authenticate.go
    └─ public
       ├─ index.html
       └─ login.html
    

    Projektdateien

    .env

    jwt_secret = b0WciedNJvFCqFRbB2A1QhZoCDnutAOen5g1FEDO0HsLTwGINp04GXh2OXVpTqQL
    

    Diese .env-Datei enth?lt eine einzelne Umgebungsvariable jwt_secret, die einen geheimen Schlüssel enth?lt, der zum Signieren und überprüfen von JWT-Tokens in der Anwendung verwendet wird.

    Authenticate.go

    package middleware
    
    import (
        "net/http"
        "os"
        "strings"
    
        "github.com/gin-gonic/gin"
        "github.com/golang-jwt/jwt"
    )
    
    type Claims struct {
        Id int `json:"id"`
        Name string `json:"name"`
        jwt.StandardClaims
    }
    
    func Authenticate() gin.HandlerFunc {
        return func(c *gin.Context) {
            if c.Request.URL.Path == "/" || c.Request.URL.Path == "/login" {
                c.Next()
                return
            }
            authHeader := c.GetHeader("Authorization")
            if authHeader == "" {
                c.Status(http.StatusUnauthorized)
                c.Abort()
                return
            }
            tokenString := strings.TrimPrefix(authHeader, "Bearer ")
            token, err := jwt.ParseWithClaims(tokenString, &Claims{}, func(token *jwt.Token) (interface{}, error) {
                return []byte(os.Getenv("jwt_secret")), nil
            })
            if err != nil || !token.Valid {
                c.Status(http.StatusUnauthorized)
                c.Abort()
                return
            }
            if claims, ok := token.Claims.(*Claims); ok {
                c.Set("user", claims)
            } else {
                c.Status(http.StatusUnauthorized)
                c.Abort()
                return
            }
            c.Next()
        }
    }
    

    Die Authenticate.go-Middleware definiert eine Funktion für die JWT-Authentifizierung in einer Go-API unter Verwendung des Gin-Frameworks. Es prüft, ob die Anforderung für die Pfade / oder /login gilt. In diesem Fall ist keine Authentifizierung erforderlich. Für andere Routen ruft es den Authorization-Header ab und erwartet ein Bearer-Token. Das Token wird mithilfe des JWT-Pakets und eines geheimen Schlüssels aus Umgebungsvariablen analysiert und validiert. Wenn das Token ungültig ist oder fehlt, wird die Anfrage mit dem Status ?401 Nicht autorisiert“ abgebrochen. Wenn sie gültig sind, werden die Benutzeransprüche (z. B. ID und Name) extrahiert und dem Gin-Kontext hinzugefügt, wodurch der Zugriff auf geschützte Routen erm?glicht wird.

    main.go

    package main
    
    import (
        "app/middleware"
        "net/http"
        "os"
        "time"
    
        "github.com/gin-gonic/gin"
        "github.com/golang-jwt/jwt"
        "github.com/joho/godotenv"
    )
    
    func main() {
        godotenv.Load()
        router := gin.Default()
        router.Use(middleware.Authenticate())
        router.LoadHTMLFiles("public/index.html", "public/login.html")
    
        router.GET("/", func(c *gin.Context) {
            c.HTML(http.StatusOK, "index.html", nil)
        })
    
        router.GET("/login", func(c *gin.Context) {
            c.HTML(http.StatusOK, "login.html", nil)
        })
    
        router.GET("/user", func(c *gin.Context) {
            user, _ := c.Get("user")
            claims := user.(*middleware.Claims)
            c.JSON(http.StatusOK, gin.H{"name": claims.Name})
        })
    
        router.POST("/login", func(c *gin.Context) {
            var login map[string]string
            c.BindJSON(&login)
            if login["name"] == "admin" && login["password"] == "1234" {
                token := jwt.NewWithClaims(jwt.SigningMethodHS256, &middleware.Claims{
                    Id: 1,
                    Name: login["name"],
                    StandardClaims: jwt.StandardClaims{
                        IssuedAt: time.Now().Unix(),
                        ExpiresAt: time.Now().Add(24 * time.Hour).Unix(),
                    },
                })
                tokenString, _ := token.SignedString([]byte(os.Getenv("jwt_secret")))
                c.JSON(http.StatusOK, gin.H{"token": tokenString})
            } else {
                c.Status(http.StatusBadRequest)
            }
        })
        router.Run()
    }
    

    Die main.go-Datei richtet einen Go-Webserver mithilfe des Gin-Frameworks ein, um Routen mit JWT-basierter Authentifizierung zu verarbeiten. Zur Authentifizierung wird Middleware verwendet, die in Anfragen nach gültigen JWT-Tokens sucht. Der Server stellt zwei HTML-Seiten bereit: index.html und login.html, die über die Routen / und /login zug?nglich sind.

    Für die /user-Route ruft der Server den Namen des authentifizierten Benutzers aus den JWT-Ansprüchen ab und gibt ihn in der Antwort zurück. Für die POST-Route /login validiert der Server die Benutzeranmeldeinformationen (Name und Passwort) und generiert, falls gültig, ein JWT-Token, signiert es mit einem geheimen Schlüssel und sendet es an den Client zurück. Der Server ist so konfiguriert, dass er auf Anfragen wartet und auf dem Standardport ausgeführt wird.

    index.html

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width,initial-scale=1">
        <link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.3/css/bootstrap.min.css" rel="stylesheet">
        <link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css" rel="stylesheet">
    </head>
    <body>
        <div>
    
    
    
    <p>The index.html is a simple web page that provides a user interface for displaying the login status of a user. It uses Bootstrap for styling and Font Awesome for icons. On page load, it checks the user's authentication status by sending a request to the server with a JWT token stored in localStorage. If the user is logged in, it shows a success message with the user's name and a logout button. If not logged in, it shows a message indicating the user is not logged in and redirects them to the login page after a few seconds.</p>
    
    <h3>
      
      
      login.html
    </h3>
    
    
    
    <pre class="brush:php;toolbar:false"><!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width,initial-scale=1">
        <link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.3/css/bootstrap.min.css" rel="stylesheet">
        <link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css" rel="stylesheet">
    </head>
    <body>
        <div>
    
    
    
    <p>The login.html page provides a simple login form where users can input their username and password. It uses Bootstrap for styling and Font Awesome for icons. When the user submits the form, a JavaScript function login() sends a POST request to the /login endpoint with the entered credentials. If the login is successful, the server returns a JWT token, which is stored in localStorage. The page then redirects the user to the home page (/). If the login fails, an error message is displayed.</p>
    
    <h2>
      
      
      Run project
    </h2>
    
    
    
    <pre class="brush:php;toolbar:false">go run main.go
    

    ?ffnen Sie den Webbrowser und gehen Sie zu http://localhost:8080

    Sie finden diese Testseite.

    Implementing JWT Authentication in Go API

    Testen

    Nach ein paar Sekunden werden Sie zur Anmeldeseite weitergeleitet.

    Implementing JWT Authentication in Go API

    Drücken Sie die Anmeldeschaltfl?che und Sie werden auf der Startseite angemeldet, auf der der Name des angemeldeten Benutzers angezeigt wird.

    Implementing JWT Authentication in Go API

    Versuchen Sie, den Browser zu aktualisieren, und Sie werden sehen, dass Sie immer noch angemeldet sind. Klicken Sie dann auf die Schaltfl?che ?Abmelden“. Das JWT-Token wird entfernt und Sie werden erneut zur Anmeldeseite weitergeleitet.

    Implementing JWT Authentication in Go API

    Abschluss

    Zusammenfassend l?sst sich sagen, dass die Implementierung der JWT-Authentifizierung in einer Go-API einen sicheren und skalierbaren Ansatz für die Benutzerauthentifizierung bietet. Durch die Verwendung des Gin-Frameworks zusammen mit dem Paket golang-jwt/jwt k?nnen wir die tokenbasierte Authentifizierung problemlos in unsere Anwendung integrieren. JWT-Tokens werden w?hrend der Anmeldung generiert, um Benutzeranmeldeinformationen sicher zu validieren und Zugriff auf geschützte Routen zu gew?hren. Die Middleware stellt sicher, dass nur authentifizierte Benutzer auf diese Routen zugreifen k?nnen, indem sie die Gültigkeit des Tokens überprüft. Dieser zustandslose Authentifizierungsmechanismus bietet verbesserte Leistung und Flexibilit?t und ist somit eine ideale Wahl für moderne API-Architekturen.

    Quellcode: https://github.com/stackpuz/Example-JWT-Go

    Erstellen Sie in wenigen Minuten eine CRUD-Web-App: https://stackpuz.com

    Das obige ist der detaillierte Inhalt vonImplementierung der JWT-Authentifizierung in der Go-API. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Erkl?rung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

    Hei?e KI -Werkzeuge

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    Video Face Swap

    Video Face Swap

    Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

    Hei?e Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    Ist Golang Frontend oder Backend Ist Golang Frontend oder Backend Jul 08, 2025 am 01:44 AM

    Golang wird haupts?chlich für die Back-End-Entwicklung verwendet, kann aber auch eine indirekte Rolle im Front-End-Bereich spielen. Die Konstruktionsziele konzentrieren sich auf leistungsstarke, gleichzeitige Programmierungen und Systeme auf Systemebene und eignen sich zum Erstellen von Back-End-Anwendungen wie API-Servern, Microservices, verteilten Systemen, Datenbankoperationen und CLI-Tools. Obwohl Golang nicht die Mainstream-Sprache für das Web-Front-End ist, kann er über Gopherjs in JavaScript zusammengestellt werden, auf WebAssembly über Tinygo ausgeführt werden oder HTML-Seiten mit einer Vorlagenmotor zur Teilnahme an der Front-End-Entwicklung erzeugen. Die moderne Front-End-Entwicklung muss jedoch noch auf JavaScript/Typecript und sein ?kosystem beruhen. Daher eignet sich Golang besser für die Auswahl der Technologiestapel mit Hochleistungs-Backend als Kern.

    So erstellen Sie eine GraphQL -API in Golang So erstellen Sie eine GraphQL -API in Golang Jul 08, 2025 am 01:03 AM

    Um ein GraphQLAPI in Go zu erstellen, wird empfohlen, die GQLGen -Bibliothek zur Verbesserung der Entwicklungseffizienz zu verwenden. 1. W?hlen Sie zun?chst die entsprechende Bibliothek wie GQLGen aus, die die automatische Codegenerierung basierend auf dem Schema unterstützt. 2. Definieren Sie dann GraphQlSchema, beschreiben Sie das API -Struktur und das Abfrageportal, z. B. das Definieren von Post -Typen und Abfragemethoden; 3. Initialisieren Sie dann das Projekt und generieren Sie grundlegende Code, um die Gesch?ftslogik in Resolver zu implementieren. 4. Schlie?lich verbinden Sie GraphQlHandler mit HTTPServer und testen Sie die API über den integrierten Spielplatz. Zu den Anmerkungen geh?ren Feldnamenspezifikationen, Fehlerbehandlung, Leistungsoptimierung und Sicherheitseinstellungen, um die Projektwartung sicherzustellen

    So installieren Sie sich So installieren Sie sich Jul 09, 2025 am 02:37 AM

    Der Schlüssel zur Installation von GO besteht darin, die richtige Version auszuw?hlen, Umgebungsvariablen zu konfigurieren und die Installation zu überprüfen. 1. Gehen Sie zur offiziellen Website, um das Installationspaket des entsprechenden Systems herunterzuladen. Windows verwendet .msi -Dateien, macOS. PKG -Dateien, Linux verwendet .tar.gz -Dateien und entpackt sie in /usr /lokales Verzeichnis. 2. Konfigurieren Sie Umgebungsvariablen, bearbeiten Sie ~/.bashrc oder ~/.zshrc in Linux/macOS, um Pfad und GOPath hinzuzufügen, und Windows -Set -Pfad, um die Systemeigenschaften zu verfolgen. 3.. Verwenden Sie das Regierungsbefehl, um die Installation zu überprüfen, und führen Sie das Testprogramm Hello.go aus, um zu best?tigen, dass die Zusammenstellung und Ausführung normal ist. Pfadeinstellungen und Schleifen w?hrend des gesamten Prozesses

    Go Sync.waitGroup Beispiel Go Sync.waitGroup Beispiel Jul 09, 2025 am 01:48 AM

    Sync.waitGroup wird verwendet, um auf eine Gruppe von Goroutinen zu warten, um die Aufgabe zu erledigen. Sein Kern besteht darin, drei Methoden zusammenzuarbeiten: hinzufügen, fertig und warten. 1.Add (n) Stellen Sie die Anzahl der Goroutiner fest, um zu warten; 2.Done () wird am Ende jeder Goroutine bezeichnet, und die Anzahl wird um eins reduziert; 3.wait () blockiert die Hauptkorutine, bis alle Aufgaben erledigt sind. Beachten Sie bitte, dass Sie bei der Verwendung au?erhalb der Goroutine doppelte Warten vermeiden, und stellen Sie sicher, dass der Don aufgerufen wird. Es wird empfohlen, es mit Aufhebung zu verwenden. Es ist h?ufig bei der gleichzeitigen Krabbeln von Webseiten, der Stapeldatenverarbeitung und anderer Szenarien und kann den Parallelit?tsprozess effektiv steuern.

    Gehen Sie ein Paket -Tutorial ein Gehen Sie ein Paket -Tutorial ein Jul 09, 2025 am 02:46 AM

    Durch die Verwendung von GO -Einbettenpaket k?nnen statische Ressourcen einfach in bin?re und für Webdienste geeignet einbetten, um HTML, CSS, Bilder und andere Dateien zu verpacken. 1. Deklarieren Sie die eingebettete Ressource zum Hinzufügen // Go: Einbetten Sie einen Kommentar vor der Variablen ein, z. B. das Einbettung einer einzelnen Datei hello.txt; 2. Es kann in das gesamte Verzeichnis wie static/*eingebettet werden und die Multi-File-Verpackung durch Einbettung.Fs realisieren; 3.. Es wird empfohlen, den Festplattenlastmodus über Geb?ude- oder Umgebungsvariablen zu wechseln, um die Effizienz zu verbessern. 4. Achten Sie auf Pfadgenauigkeit, Einschr?nkungen der Dateigr??en und schreibgeschützte Merkmale eingebetteter Ressourcen. Die rationale Verwendung von Einbetten kann die Bereitstellung vereinfachen und die Projektstruktur optimieren.

    Gehen Sie für Audio-/Videoverarbeitung Gehen Sie für Audio-/Videoverarbeitung Jul 20, 2025 am 04:14 AM

    Der Kern der Audio- und Videoverarbeitung liegt darin, die grundlegenden Prozess- und Optimierungsmethoden zu verstehen. 1. Der grundlegende Prozess umfasst Akquisition, Codierung, übertragung, Decodierung und Wiedergabe, und jeder Link hat technische Schwierigkeiten. 2. H?ufige Probleme wie Audio- und Video -Aberration, Verz?gerungsverz?gerung, Schallger?usch, verschwommenes Bild usw. k?nnen durch synchrone Einstellung, Codierungsoptimierung, Rauschverringerungsmodul, Parameteranpassung usw. gel?st werden; 3.. Es wird empfohlen, FFMPEG, OpenCV, Webrtc, Gstreamer und andere Tools zu verwenden, um Funktionen zu erzielen. 4. In Bezug auf das Leistungsmanagement sollten wir auf die Beschleunigung der Hardware, die angemessene Einstellung der Aufl?sungsrahmenquoten, die Kontrollverkehr und Speicher -Leckage -Probleme achten. Wenn Sie diese wichtigen Punkte beherrschen, werden die Entwicklungseffizienz und die Benutzererfahrung verbessert.

    So erstellen Sie einen Webserver in Go So erstellen Sie einen Webserver in Go Jul 15, 2025 am 03:05 AM

    Es ist nicht schwierig, einen in Go geschriebenen Webserver zu erstellen. Der Kern liegt in der Verwendung des NET/HTTP -Pakets zur Implementierung grundlegender Dienste. 1. Verwenden Sie Net/HTTP, um den einfachsten Server zu starten: Registrieren Sie die Verarbeitungsfunktionen und h?ren Sie Ports über einige Codezeilen an. 2. Routing -Management: Verwenden Sie ServeMux, um mehrere Schnittstellenpfade für eine einfache strukturierte Verwaltung zu organisieren. 3. H?ufige Praktiken: Gruppenrouting nach funktionalen Modulen und verwenden Bibliotheken von Drittanbietern, um eine komplexe übereinstimmung zu unterstützen. 4. Statischer Dateidienst: Geben Sie HTML-, CSS- und JS -Dateien über http.FileServer an; 5. Leistung und Sicherheit: Aktivieren Sie HTTPS, begrenzen Sie die Gr??e des Anforderungsorganisation und stellen Sie Zeitüberschreitungen ein, um die Sicherheit und Leistung zu verbessern. Nach dem Beherrschen dieser Schlüsselpunkte ist es einfacher, die Funktionalit?t zu erweitern.

    W?hlen Sie mit Standardfall ausw?hlen W?hlen Sie mit Standardfall ausw?hlen Jul 14, 2025 am 02:54 AM

    Der Zweck von Select Plus -Standard besteht darin, das Ausw?hlen zu erm?glichen, ein Standardverhalten durchzuführen, wenn keine anderen Zweige bereit sind, um das Programmblockieren zu vermeiden. 1. Beim Empfangen von Daten aus dem Kanal ohne Blockierung, wenn der Kanal leer ist, wird direkt die Standardzweigung eingegeben. 2. In Kombination mit der Zeit. Nach oder Ticker versuchen Sie, Daten regelm??ig zu senden. Wenn der Kanal voll ist, wird er nicht blockiert und überspringt. 3. Verhindern Sie Deadlocks, vermeiden Sie das Programm, das nicht sicher ist, ob der Kanal geschlossen ist. Beachten Sie bei der Verwendung, dass die Standardzweig sofort ausgeführt wird und nicht missbraucht wird, und standardm??ig und der Fall sind sich gegenseitig ausschlie?lich und werden nicht gleichzeitig ausgeführt.

    See all articles