인터넷 시대, 인터넷 기술의 지속적인 발전과 정보에 대한 사람들의 수요가 증가함에 따라 웹사이트와 앱의 등록 및 로그인 기능이 점점 더 보편화되었습니다. 이 기사에서는 golang 언어를 사용하여 등록 및 로그인 기능을 구현하는 방법을 소개합니다.
1. golang 소개
golang은 Google에서 개발한 프로그래밍 언어로 효율적인 동시 처리, 자동 가비지 수집, 매우 짧은 컴파일 시간 등의 특징을 가지고 있으며 자연스러운 동시성 기능을 갖추고 있어 대규모 작업에 적합합니다. 시스템. 이러한 기능은 golang을 매우 뛰어난 서버측 언어로 만듭니다. 따라서 이를 사용하여 등록 및 로그인 기능을 구현하는 것은 매우 좋은 선택입니다.
2. 환경 설정
golang을 사용하여 등록 및 로그인 기능을 구현하려면 먼저 로컬 환경에 golang 언어를 설치해야 합니다. 설치하기 전에 컴퓨터의 운영 체제 유형(Windows, Linux, Mac 등)을 확인하고 해당 golang 버전을 선택하여 다운로드 및 설치해야 합니다.
설치가 완료된 후 명령줄에 다음 명령을 입력하여 설치 성공 여부를 확인할 수 있습니다.
go version
golang 버전 번호가 표시되면 설치가 성공한 것입니다.
3. 등록 기능 구현
이 프로젝트의 파일을 저장할 "login"이라는 폴더를 생성하세요. 이 폴더에 컨트롤러와 모델이라는 두 개의 폴더를 만듭니다. 그 중 컨트롤러는 웹 인터페이스의 컨트롤러 코드를 배치하는 데 사용되고 모델은 데이터베이스 작업 코드를 배치하는 데 사용됩니다.
모델 폴더에 "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 }
위 코드에서 제3자는 데이터베이스 연결을 구현하기 위해 라이브러리 "go-sql-driver/mysql"을 사용했습니다. 코드에서는 사용자 이름, 비밀번호, 호스트 주소, 포트 번호, 데이터베이스 이름 등과 같은 데이터베이스의 일부 기본 정보도 설정해야 합니다.
다음 단계에서는 사용자 ID, 사용자 이름 및 비밀번호와 같은 필드가 포함된 사용자 테이블을 생성하는 SQL 문을 작성하기 위해 "user.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"이라는 파일을 생성하여 등록 페이지 코드를 작성하세요. 이 페이지에서는