インターネット時代では、インターネット技術の継続的な進歩と人々の情報への需要の増大に伴い、Web サイトや APP の登録およびログイン機能がますます一般的になりました。この記事では、golang言語を使用して登録・ログイン機能を実装する方法を紹介します。
1. golang の概要
Golang は Google によって開発されたプログラミング言語であり、効率的な同時処理、自動ガベージ コレクション、および非常に短いコンパイル時間という特徴があり、自然な同時実行機能を備えています。大規模システムに適した機能を備えています。これらの機能により、golang は非常に優れたサーバーサイド言語になります。したがって、これを使用して登録およびログイン機能を実装することは非常に良い選択です。
2. 環境設定
golang を使用して登録およびログイン機能を実装するには、まずローカル環境に golang 言語をインストールする必要があります。インストールする前に、コンピュータのオペレーティング システムの種類 (Windows、Linux、Mac など) を確認し、ダウンロードしてインストールする対応する golang バージョンを選択する必要があります。
インストールが完了したら、コマンド ラインに次のコマンドを入力して、インストールが成功したかどうかを確認できます。
go version
golang のバージョン番号が表示されれば、インストールは成功しています。 。
3. 登録機能の実装
このプロジェクトドキュメントを配置する「login」という名前のフォルダーを作成します。このフォルダー内にコントローラーとモデルの 2 つのフォルダーを作成します。このうち、controllerはWebインターフェースのコントローラーコードを配置するために使用され、modelはデータベース操作のコードを配置するために使用されます。
モデル フォルダーに「db.go」という名前のファイルを作成し、その中に次のコードを記述してデータベース接続を確立します。
package model import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" ) const ( USERNAME = "root" PASSWORD = "" NETWORK = "tcp" SERVER = "localhost" PORT = 3306 DATABASE = "login_system" ) func DbConn() (db *sql.DB) { dbDriver := "mysql" dbUser := USERNAME dbPass := PASSWORD dbName := DATABASE db, err := sql.Open(dbDriver, dbUser+":"+dbPass+"@tcp("+SERVER+":"+strconv.Itoa(PORT)+")/"+dbName) if err != nil { fmt.Println("无法连接数据库:", err) } else { fmt.Println("成功连接数据库!") } return db }
上記のコードでは、データベース接続を実現するためにサードパーティのライブラリ「go-sql-driver/mysql」が使用されています。コードでは、ユーザー名、パスワード、ホスト アドレス、ポート番号、データベース名など、データベースのいくつかの基本情報も設定する必要があります。
次のステップでは、「user.sql」という名前のファイルを作成して、ユーザー ID、ユーザー名、パスワードなどのフィールドを含むユーザー テーブルを作成する SQL ステートメントを記述する必要があります。
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(20) NOT NULL, `password` varchar(40) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
上記のSQL文を実行すると、データベースにユーザーテーブルが作成されます。
コントローラー フォルダーに「register.go」という名前のファイルを作成し、登録インターフェイスのコントローラー コードを書き込みます。このファイルでは、サードパーティ ライブラリ「net/http」をインポートし、次のコードを記述する必要があります。
package controller import ( "crypto/md5" "database/sql" "encoding/hex" "fmt" "io/ioutil" "net/http" "server/model" ) func Register(w http.ResponseWriter, r *http.Request) { if r.Method == "POST" { username := r.FormValue("username") password := r.FormValue("password") // 密码加密 h := md5.New() h.Write([]byte(password)) password = hex.EncodeToString(h.Sum(nil)) // 数据库操作 db := model.DbConn() defer db.Close() stmt, err := db.Prepare("INSERT INTO user(username, password) VALUES (?, ?)") if err != nil { fmt.Println("SQL语句执行失败:", err) return } _, err = stmt.Exec(username, password) if err != nil { fmt.Println("用户注册失败:", err) return } fmt.Println("用户注册成功!") } // 返回页面内容 data, err := ioutil.ReadFile("register.html") if err != nil { fmt.Println("读取文件失败:", err) return } w.Write([]byte(data)) }
上記のコードでは、最初にリクエスト メソッドが POST であるかどうかを判断します。 POST リクエストの場合、ユーザー名とパスワードが取得され、パスワードは MD5 で暗号化され、暗号化されたパスワードとユーザー名がデータベースに保存されます。
ファイルの最後で、ioutil.ReadFile() 関数を使用して「register.html」という名前のファイルを読み取り、ファイルの内容をブラウザに返します。このようにして、ブラウザは登録インターフェイスを表示できます。
ログイン フォルダーに「register.html」という名前のファイルを作成し、登録ページのコードを記述します。このページでは、