인터넷의 발전과 대중화로 인해 점점 더 많은 웹사이트와 애플리케이션이 개발되고 있으며, 그 중 상당수는 사용자 유효성과 보안을 보장하기 위해 확인 코드가 필요합니다. 이 글에서는 Beego 프레임워크와 Captcha 라이브러리를 사용하여 인증 코드 기능을 구현하는 방법을 소개합니다. 그 중 Beego는 Go 언어를 기반으로 한 웹 애플리케이션 프레임워크이고, Captcha는 Go 언어를 기반으로 한 오픈 소스 검증 코드 라이브러리입니다.
인증 코드를 구현하기 전에 Beego 프레임워크를 설치하고 새로운 Go 애플리케이션을 만들어야 합니다. Beego 프레임워크는 다음 명령을 사용하여 설치할 수 있습니다.
go get github.com/astaxie/beego
그런 다음 새 애플리케이션을 만들고 서비스를 시작합니다.
beego new myapp cd myapp bee run
모든 것이 순조롭게 진행되면 "Welcome to Beego!"가 출력되면서 브라우저에서 해당 애플리케이션에 액세스할 수 있어야 합니다.
다음으로 보안문자 라이브러리를 설치해야 합니다. 다음 명령을 사용하여 설치할 수 있습니다.
go get github.com/mojocn/base64Captcha
설치가 완료된 후 Go 애플리케이션에서 Captcha 라이브러리를 가져오고 다음 코드를 사용하여 인증 코드를 생성하고 확인할 수 있습니다.
// 生成验证码 config := captcha.ConfigCharacter{ Height: 60, Width: 240, Mode: captcha.CaptchaModeNumber, Complexity: captcha.CaptchaComplexityNormal, CaptchaLen: 4, CaptchaTimeout: 1200, SubPixel: false, ShowLineOptions: captcha.OptionShowHollowLine | captcha.OptionShowSineLine, Source: "1234567890", BgColor: "#eeeeee", } captchaId, captchaImage := captcha.GenerateCaptcha("", config) // 验证验证码 result := captcha.VerifyCaptcha(captchaId, userInputCaptcha)
위 코드에서 구성 파일 config가 먼저 정의됩니다. 구성 파일은 너비, 높이, 문자 집합, 생존 시간 등과 같은 확인 코드의 다양한 속성을 지정합니다. 이후, GenerateCaptcha 메소드를 호출하여 인증코드를 생성하고, 생성된 인증코드 이미지와 인증코드 ID를 사용자에게 반환하여 표시 및 저장하게 된다. 마지막으로 사용자가 입력한 인증코드가 이전에 생성된 인증코드 ID와 일치하는지 확인하기 위해 verifyCaptcha 메소드가 호출됩니다.
GenerateCaptcha를 호출할 때 첫 번째 매개 변수는 빈 문자열이므로 이번에 생성된 인증 코드는 어떤 데이터와도 연결될 필요가 없다는 의미입니다. 다른 데이터와 연결해야 하는 경우 첫 번째 매개변수(휴대폰 번호, 사용자 이름 등)에 데이터를 전달할 수 있습니다. verifyCaptcha 호출 시 첫 번째 매개변수는 앞서 생성한 인증코드 ID를 전달하고, 두 번째 매개변수는 사용자가 입력한 인증코드를 전달합니다.
Beego와 Captcha가 준비되면 Beego 애플리케이션에서 인증코드 기능을 구현할 수 있습니다. 먼저 인증코드를 생성하고 Beego 컨트롤러에 인증코드 이미지를 표시합니다. 코드는 다음과 같습니다.
// 生成验证码 func (c *MainController) GenerateCaptcha() { config := captcha.ConfigCharacter{ Height: 60, Width: 240, Mode: captcha.CaptchaModeNumber, Complexity: captcha.CaptchaComplexityNormal, CaptchaLen: 4, CaptchaTimeout: 1200, SubPixel: false, Source: "1234567890", BgColor: "#eeeeee", } captchaId, captchaImage := captcha.GenerateCaptcha("", config) // 将验证码及其ID存储到session中,并返回图片 c.SetSession(sessionCaptchaId, captchaId) c.Ctx.ResponseWriter.Header().Set("Cache-Control", "no-store, no-cache") c.Ctx.ResponseWriter.Header().Set("Content-Type", "image/png") captchaImage.WriteTo(c.Ctx.ResponseWriter) } // 验证验证码 func (c *MainController) CheckCaptcha() { publicKey := c.GetString("public_key") inputCaptcha := c.GetString("input_captcha") // 从session中获取验证码ID captchaId := c.GetSession(sessionCaptchaId) if captchaId == nil { c.ResponseError(errNoCaptchaFound) return } // 验证输入的验证码 if !captcha.VerifyCaptcha(captchaId.(string), inputCaptcha) { c.ResponseError(errCaptchaNotMatch) return } // 验证码匹配成功,移除验证码ID c.DelSession(sessionCaptchaId) // TODO: 验证通过,执行其他操作 }
위 코드에서는 인증코드가 먼저 생성된 인증코드와 해당 ID가 저장됩니다. 세션에서. 그런 다음 생성된 인증 코드 이미지를 클라이언트에 반환합니다. CheckCaptcha 메소드에서는 세션에서 인증코드 ID를 획득하고, verifyCaptcha 메소드를 사용하여 사용자가 입력한 인증코드가 맞는지 확인합니다. 인증에 성공하면 인증코드 ID가 제거되고 기타 조치가 수행됩니다.
마지막으로 Beego의 라우팅에 다음 라우팅 규칙을 추가합니다.
beego.Router("/captcha/generate", &controllers.MainController{}, "get:GenerateCaptcha") beego.Router("/captcha/check", &controllers.MainController{}, "post:CheckCaptcha")
이로써 인증 코드 기능 구현이 완료됩니다. /captcha/generate에 접속하면 새로운 인증코드가 생성되고 해당 ID가 세션에 저장되며 인증코드 이미지가 클라이언트에 반환됩니다. /captcha/check 접속 시, 사용자가 입력한 인증코드를 HTTP POST 요청으로 받아 이전에 생성된 인증코드 ID와 일치하는지 확인하게 됩니다. 일치하면 인증코드 ID가 제거되고 다른 작업이 수행됩니다.
요약
본 글에서는 Beego와 Captcha를 활용하여 인증코드 기능을 구현하는 방법을 소개합니다. Beego 프레임워크는 우수한 웹 개발 지원을 제공하고 Captcha 라이브러리는 우수한 확인 코드 생성 및 확인 지원을 제공합니다. 이 두 가지를 결합하면 인증 코드 기능을 쉽게 구현하여 웹 애플리케이션의 보안과 견고성을 향상시킬 수 있습니다.
위 내용은 Beego 및 Captcha를 사용하여 인증 코드 기능 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!