suchen
HeimBackend-EntwicklungGolangErstellen Sie einen OTP-basierten Authentifizierungsserver mit Go: Teil 1

Build an OTP-Based Authentication Server with Go: Part 1

Erste Schritte

Erstellen Sie zunächst einen neuen Ordner für Ihr Projekt und initialisieren Sie ein Go-Modul mit dem folgenden Befehl:

gehen Sie mod init github.com/vishaaxl/cheershare

Richten Sie die Projektstruktur ein

Beginnen Sie mit der Einrichtung eines neuen Go-Projekts mit der folgenden Ordnerstruktur:

my-otp-auth-server/
├── cmd/
│   └── api/
│       └── main.go
│       └── user.go
│       └── token.go
├── internal/
│   └── data/
│       ├── models.go
│       └── user.go
│       └── token.go
├── docker-compose.yml
├── go.mod
└── Makefile

Als nächstes richten Sie Ihre docker-compose.yml-Datei ein. Diese Konfiguration definiert die Dienste – PostgreSQL und Redis –, mit denen Sie in diesem Tutorial arbeiten werden.

Dienste mit Docker Compose einrichten

Wir beginnen mit der Konfiguration der für unser Projekt erforderlichen Dienste. Für das Backend benötigen wir Folgendes:

  • Redis: Wir verwenden das Redis:6-Image. Dieser Dienst konfiguriert ein Passwort für den sicheren Zugriff, stellt Port 6379 bereit und erzwingt die Passwortauthentifizierung mithilfe des Flags --requirepass, um den Redis-Zugriff zu sichern.

  • PostgreSQL: Wir verwenden das Bild postgres:13. Der Dienst definiert einen Standardbenutzer, ein Standardkennwort und eine Standarddatenbank, stellt Port 5432 für die Kommunikation bereit und speichert Daten auf einem benannten Volume (postgres_data), um die Haltbarkeit sicherzustellen.

Optional:

  • Haupt-Backend-Dienst: Sie können hier auch den Haupt-Backend-Dienst definieren, der sowohl mit PostgreSQL als auch Redis interagiert.
// docker-compose.yml
services:
  postgres:
    image: postgres:13
    container_name: postgres
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: mysecretpassword
      POSTGRES_DB: cheershare
    ports:
      - "5432:5432"
    volumes:
      - postgres_data:/var/lib/postgresql/data

  redis:
    image: redis:6
    container_name: redis
    environment:
      REDIS_PASSWORD: mysecretpassword
    ports:
      - "6379:6379"
    command: ["redis-server", "--requirepass", "mysecretpassword"]

volumes:
  postgres_data:

Haupt-Backend-Dienst

Für die Weiterleitung und Bearbeitung von HTTP-Anfragen verwenden wir das Paket github.com/julienschmidt/httprouter. Um die Abhängigkeit zu installieren, führen Sie den folgenden Befehl aus:

go get github.com/julienschmidt/httprouter

Als nächstes erstellen Sie eine Datei unter cmd/api/main.go und fügen den folgenden Code ein. Eine Erklärung zu jeder Zeile finden Sie in den Kommentaren:

//  main.go
package main

import (
    "fmt"
    "log"
    "net/http"
    "os"
    "time"

    "github.com/julienschmidt/httprouter"
)

/*
config struct:
- Holds application-wide configuration settings such as:
  - `port`: The port number on which the server will listen.
  - `env`: The current environment (e.g., "development", "production").
*/
type config struct {
    port int
    env  string
}

/*
applications struct:
- Encapsulates the application's dependencies, including:
  - `config`: The application's configuration settings.
  - `logger`: A logger instance to handle log messages.
*/
type applications struct {
    config config
    logger *log.Logger
}

func main() {
    cfg := &config{
        port: 4000,
        env:  "development",
    }

    logger := log.New(os.Stdout, "INFO\t", log.Ldate|log.Ltime)

    app := &applications{
        config: *cfg,
        logger: logger,
    }

    router := httprouter.New()

    router.GET("/", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
        w.WriteHeader(http.StatusOK)
        fmt.Fprintln(w, "Welcome to the Go application!")
    })

    /*
        Initialize the HTTP server
        - Set the server's address to listen on the specified port.
        - Assign the router as the handler.
        - Configure timeouts for idle, read, and write operations.
        - Set up an error logger to capture server errors.
    */
    srv := &http.Server{
        Addr:         fmt.Sprintf(":%d", app.config.port),
        Handler:      router,
        IdleTimeout:  time.Minute,
        ReadTimeout:  10 * time.Second,
        WriteTimeout: 30 * time.Second,
    }

    app.logger.Printf("Starting server on port %d in %s mode", app.config.port, app.config.env)

    err := srv.ListenAndServe()
    if err != nil {
        app.logger.Fatalf("Could not start server: %s", err)
    }
}

Im Moment können Sie Ihr Setup testen, indem Sie den Server mit go run ./cmd/api starten und eine Anfrage an http://localhost:4000 senden, die eine Willkommensnachricht zurückgibt. Als Nächstes definieren wir drei zusätzliche Routen zur Implementierung unserer Kernfunktionalität:

  1. /send-otp: Diese Route übernimmt das Senden von OTPs an Benutzer. Es wird ein eindeutiges OTP generiert, in Redis gespeichert und an den Benutzer übermittelt.

  2. /verify-otp: Diese Route überprüft das vom Benutzer bereitgestellte OTP. Es wird mit dem in Redis gespeicherten Wert verglichen, um die Identität des Benutzers zu bestätigen.

  3. /login: Diese Route übernimmt die Benutzeranmeldefunktion, sobald das OTP überprüft und der Benutzer erfolgreich erstellt wurde.

Aber bevor wir fortfahren, benötigen wir eine Möglichkeit, Benutzerinformationen wie Telefonnummer und ihr Einmalpasswort zu speichern, für die wir eine Verbindung zu den Diensten herstellen müssen, die wir zuvor in der Datei docker-compose.yml definiert haben.

Hilfsfunktionen definieren

Bevor wir die Routen implementieren, definieren wir zwei wesentliche Hilfsfunktionen. Diese Funktionen verwalten Verbindungen zu den Redis- und PostgreSQL-Servern und stellen so sicher, dass unser Backend mit diesen Diensten interagieren kann.

Ändern Sie die Struktur „config“, um Informationen über die Dienste zu speichern. Diese Funktionen sind ziemlich selbsterklärend.

my-otp-auth-server/
├── cmd/
│   └── api/
│       └── main.go
│       └── user.go
│       └── token.go
├── internal/
│   └── data/
│       ├── models.go
│       └── user.go
│       └── token.go
├── docker-compose.yml
├── go.mod
└── Makefile

Mit diesen Funktionen können Sie eine Verbindung zur PostgreSQL-Datenbank und zum Redis-Server herstellen, nachdem Sie die Dienste mit dem Befehl docker-compose up -d gestartet haben.

Im nächsten Teil beginnen wir mit der Arbeit an den Routen, über die wir zuvor gesprochen haben. So sollte Ihre main.go-Datei jetzt aussehen.

// docker-compose.yml
services:
  postgres:
    image: postgres:13
    container_name: postgres
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: mysecretpassword
      POSTGRES_DB: cheershare
    ports:
      - "5432:5432"
    volumes:
      - postgres_data:/var/lib/postgresql/data

  redis:
    image: redis:6
    container_name: redis
    environment:
      REDIS_PASSWORD: mysecretpassword
    ports:
      - "6379:6379"
    command: ["redis-server", "--requirepass", "mysecretpassword"]

volumes:
  postgres_data:

Das obige ist der detaillierte Inhalt vonErstellen Sie einen OTP-basierten Authentifizierungsserver mit Go: Teil 1. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Lernen Sie Go Byte Slice Manipulation: Arbeiten mit dem 'Bytes' -Paket arbeitenLernen Sie Go Byte Slice Manipulation: Arbeiten mit dem 'Bytes' -Paket arbeitenMay 16, 2025 am 12:14 AM

ThytespackageingoiSessentialFormanipulationsBytesliceseffectival.1) UseBytes.JointoConcatenatesLices.2) uaBytes.BufferfordynamicDataconstruction.3) useIndexandcontains

So verwenden Sie das Paket 'Codierung/Binär', um binäre Daten in Go zu codieren und zu dekodieren (Schritt für Schritt)So verwenden Sie das Paket 'Codierung/Binär', um binäre Daten in Go zu codieren und zu dekodieren (Schritt für Schritt)May 16, 2025 am 12:14 AM

Tousethe "codieren/binär" paketingoforencodinganddecodingBinyData, folge theSesteps: 1) ImportthepackageandCreatabuffer.2) Gebrauch

Wie verwenden Sie das 'Coding/Binary' -Paket, um Binärdaten in Go zu codieren und zu dekodieren?Wie verwenden Sie das 'Coding/Binary' -Paket, um Binärdaten in Go zu codieren und zu dekodieren?May 16, 2025 am 12:13 AM

Das Codierung/Binärpaket bietet eine einheitliche Möglichkeit, binäre Daten zu verarbeiten. 1) Verwenden Sie die Funktionen von Binary.Write und Binary. 2) Benutzerdefinierte Typen können durch die Implementierung der Binary.Byteorder -Schnittstelle behandelt werden. 3) Achten Sie auf die Auswahl der Endianess, die Datenausrichtung und die Fehlerbehandlung, um die Richtigkeit und Effizienz der Daten zu gewährleisten.

GO STRINGS -Paket: Ist es für jeden Anwendungskoffer vollständig?GO STRINGS -Paket: Ist es für jeden Anwendungskoffer vollständig?May 16, 2025 am 12:09 AM

Das Stringspaket von Go ist nicht für alle Anwendungsfälle geeignet. Es funktioniert für die meisten häufigsten String-Operationen, aber es können Bibliotheken von Drittanbietern für komplexe NLP-Aufgaben, regelmäßige Ausdrucksanpassungen und spezifisches Format-Parsing erforderlich sein.

Was sind die Grenzen des GO -String -Pakets?Was sind die Grenzen des GO -String -Pakets?May 16, 2025 am 12:05 AM

Das Strings -Paket in GO verfügt über die Einschränkungen der Leistung und Speicherverbrauch bei der Umstellung einer großen Anzahl von String -Operationen. 1) Leistungsprobleme: Zum Beispiel Strings.replace und Strings.replaceall sind im Umgang mit groß angelegten Saitenersatz weniger effizient. 2) Speicherverwendung: Da die Zeichenfolge unveränderlich ist, werden neue Objekte bei jeder Operation generiert, was zu einer Erhöhung des Speicherverbrauchs führt. 3) Unicode -Verarbeitung: Es ist nicht flexibel genug, wenn sie komplexe Unicode -Regeln bearbeiten, und erfordern möglicherweise die Hilfe anderer Pakete oder Bibliotheken.

String Manipulation in Go: Beherrschen des 'Strings' -PaketsString Manipulation in Go: Beherrschen des 'Strings' -PaketsMay 14, 2025 am 12:19 AM

Das Beherrschen des Strings -Pakets in GO -Sprache kann die Funktionen der Textverarbeitung und die Entwicklungseffizienz verbessern. 1) Verwenden Sie die Enthaltende Funktion, um Substrings zu überprüfen. 2) Verwenden Sie die Indexfunktion, um die Substringposition zu ermitteln. Vermeiden Sie vorsichtig, um häufige Fehler zu vermeiden, wie z.

Gehen Sie 'Strings' -Paket -Tipps und TricksGehen Sie 'Strings' -Paket -Tipps und TricksMay 14, 2025 am 12:18 AM

Sie sollten sich um das Strings -Paket in Go kümmern, da es die String -Manipulation vereinfachen und den Code klarer und effizienter gestalten kann. 1) Saiten verwenden. 2) Verwenden Sie Zeichenfolgen. 3) Substringpositionen durch Zeichenfolgen finden. Index und Strings.lastindex; 4) Verwenden Sie Strings.replaceAll, um Zeichenfolgen zu ersetzen; 5) Verwenden von Saiten.Builder, um Strings effizient zu spleißen; 6) Überprüfen Sie die Eingaben immer, um unerwartete Ergebnisse zu vermeiden.

'Strings' -Paket in Go: Ihre Anlaufstelle für String-Operationen'Strings' -Paket in Go: Ihre Anlaufstelle für String-OperationenMay 14, 2025 am 12:17 AM

ThestringspackagesingoiSessentialSticientStringManipulation.1) ItofferSimpeyet-PowerfulfunctionsForfunctionStaskSlikechkesSubstringsandjoiningStrings.2) itHandlesunicodewell, mit Functionslikestrings.Fieldsfordhitspace-separatierte Vala-Valuation.3) -Fassenderformance, st

See all articles

Heiße KI -Werkzeuge

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.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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ßer Artikel

Nordhold: Fusionssystem, erklärt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)