Golang へのログイン方法
Golang は、2009 年に Google によって公開されたオープンソース プログラミング言語です。 Golang は、効率性、信頼性、メンテナンスの容易さなどの利点から、バックエンド開発、クラウド コンピューティングなどの分野で広く使用されています。 Golang開発では、ユーザーログインなどの機能を実装する必要があるため、ユーザーログインをどのようにGolangに実装するかが重要な課題となっています。この記事では、Golang でユーザーログインを実装する方法を紹介します。
1. Golang におけるユーザーログインの原理
ユーザーログイン機能を実装するには、ユーザー名やパスワードなどのユーザー情報をサーバー側に保存する必要があります。ユーザーがユーザー名とパスワードを入力すると、サーバーはユーザーの入力を検証する必要があり、一致した場合、サーバーは認証成功情報をユーザーに返し、ユーザーのログイン状態をサーバー側に保存します。ログイン ステータスは Cookie またはセッションの形式で保存できるため、次回ユーザーがアクセスしたときにサーバーがユーザーを識別し、対応するデータを返すことができます。
2. Golang でユーザー ログインを実装する手順
Golang でユーザー ログインを実装するには、次の手順を完了する必要があります:
次に示すように、データベースにユーザー テーブルを作成して、ユーザーのユーザー名、パスワード、その他の情報を保存します。
CREATE TABLE users (
ID int NOT NULL AUTO_INCREMENT,
名前 varchar(20) NOT NULL,
パスワード varchar(50) NOT NULL,
主キー (ID)
);
フロントエンド ページでは、ユーザー名とパスワードの入力ボックスを提供する必要があります。ユーザーがアカウントとパスワードを入力した後、ログイン ボタンをクリックすると、リクエストがサーバーに送信されます。リクエストには、ユーザーが入力したアカウントとパスワードの情報を含める必要があります。
フロントエンド ページからリクエストを受信した後、サーバーはリクエストを受信して処理するための対応するインターフェイスを作成する必要があります。処理手順は次のとおりです。
(1) リクエストに含まれるユーザー名とパスワードの情報を取得します。
(2) データベースに接続し、ユーザーが入力したユーザー名とパスワードを確認します。ユーザー名とパスワードが正常に一致すると、成功した認証情報が返され、見つかったユーザー情報がサーバーに保存されます。
(3) ログインステータス情報をフロントエンドに返します。
Golang では、セッションまたは Cookie メカニズムを通じてユーザーのログイン ステータスを保存できます。セッションはサーバー側に保存される情報であり、Cookieはクライアント側に保存される情報です。ユーザーがログインに成功すると、サーバーはユーザー情報をセッションに保存し、セッション識別情報を Cookie に保存して、次回ユーザーがアクセスしたときにサーバーがユーザーを識別できるようにします。
ユーザーのログインプロセス中、ユーザー情報のセキュリティを確保する必要があります。ユーザーのパスワードは暗号化する必要があります。 Golang では、bcrypt アルゴリズムを使用してパスワードを暗号化できます。 bcrypt 暗号化アルゴリズムは、複数回にわたってパスワードを繰り返しハッシュする安全なハッシュ アルゴリズムであり、これによりパスワードのセキュリティが強化されます。
3. Golang でのユーザー ログインの実装例
以下は、Golang でユーザー ログインを実装する方法を示す簡単な例です。
MySQL で次の SQL ステートメントを実行します:
CREATE TABLE users (
ID int NOT NULL AUTO_INCREMENT,
名前 varchar(20) NOT NULL,
パスワード varchar(100) NOT NULL,
主キー (ID)
);
HTML ファイルでは、次のコードを記述できます:
8b05045a5be5764f313ed5b9168a17e6
100db36a723c770d327fc0aef2ce13b1
93f0f5c25f18dab9d176bd4f6de5d30e
<meta charset="UTF-8" /> <title>Login Page</title>
< ;/ head>
6c04bd5ca3fcae76e30b72ad730ca86d
<h1>Login Page</h1> <form action="/login" method="POST"> <label for="username">Username:</label> <input type="text" id="username" name="username" /><br /> <label for="password">Password:</label> <input type="password" id="password" name="password" /><br /> <input type="submit" name="submit" value="Login" /> </form>
36cc49f0c466276486e50c850b7e4956
73a6ac4ed44ffec12cee46588e518a5e
Golang コードは次のとおりです。
package main
import (
"crypto/rand" "database/sql" "fmt" "html/template" "log" "net/http" "strings" "time" "golang.org/x/crypto/bcrypt" _ "github.com/go-sql-driver/mysql"
)
type User struct {
ID int `json:"id"` Name string `json:"name"` Password string `json:"password"`
}
var db *sql.DB
func dbSetup() {
var err error db, err = sql.Open("mysql", "username:password@tcp(localhost:3306)/dbname") if err != nil { log.Fatal(err) }
}
func dbClose() {
db.Close()
}
func UserExists(ユーザー名文字列) bool {
var count int stmt := "SELECT COUNT(*) FROM users WHERE Name = ?" row := db.QueryRow(stmt, username) err := row.Scan(&count) if err != nil { log.Fatal(err) } return count > 0
}
func AddUser(user ユーザー) {
stmt := "INSERT INTO users(Name, Password) VALUES(?, ?)" _, err := db.Exec(stmt, user.Name, user.Password) if err != nil { log.Fatal(err) }
}
func GetUserByUsername( ユーザー名文字列) (ユーザー、エラー) {
var user User stmt := "SELECT ID, Name, Password FROM users WHERE Name = ?" row := db.QueryRow(stmt, username) err := row.Scan(&user.ID, &user.Name, &user.Password) switch { case err == sql.ErrNoRows: return User{}, fmt.Errorf("No user with username %s", username) case err != nil: return User{}, err } return user, nil
}
func HashPassword(パスワード文字列) (文字列、エラー) {
bytes, err := bcrypt.GenerateFromPassword([]byte(password), 14) return string(bytes), err
}
func CheckPasswordHash(パスワード, ハッシュ文字列) bool {
err := bcrypt.CompareHashAndPassword([]byte(hash), []byte(password)) return err == nil
}
func LoginHandler(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" { t, _ := template.ParseFiles("login.html") t.Execute(w, nil) } else { r.ParseForm() username := strings.TrimSpace(r.Form.Get("username")) password := strings.TrimSpace(r.Form.Get("password")) if !UserExists(username) { http.Error(w, "User not found.", http.StatusUnauthorized) return } user, err := GetUserByUsername(username) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } if !CheckPasswordHash(password, user.Password) { http.Error(w, "Invalid credentials.", http.StatusUnauthorized) return } sessionID := createSession() cookie := &http.Cookie{ Name: "sessionid", Value: sessionID, Path: "/", Expires: time.Now().Add(time.Hour * 24 * 7), HttpOnly: true, } http.SetCookie(w, cookie) fmt.Fprintf(w, "Welcome, %s!", user.Name) }
}
func createSession() string {
b := make([]byte, 16) _, err := rand.Read(b) if err != nil { log.Fatal(err) } return fmt.Sprintf("%x", b)
}
func main() {
dbSetup() defer dbClose() http.HandleFunc("/login", LoginHandler) log.Fatal(http.ListenAndServe(":8080", nil))
}
上記のコードはユーザーを実装します。ログイン機能。そのロジックには主に、ユーザーが存在するかどうかの判断、パスワードの検証、セッション ID の生成、Cookie の作成などのステップが含まれます。具体的な実装については、コード内のコメントを参照してください。
4. 概要
Golang でユーザー ログイン機能を実装するには、完了する必要がある主な手順には、ユーザー テーブルの作成、ログイン ページの作成、Golang インターフェイスの作成、ログインの保存が含まれます。ステータスとユーザー情報のセキュリティの確保についての質問です。導入プロセスでは、ユーザー情報のセキュリティに注意を払う必要があります。この記事では、簡単な例を使用して Golang でユーザー ログイン機能を実装する方法を紹介し、読者はこれに基づいて、より複雑な機能を実装することができます。
以上がgolangにログインする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。