zoukankan      html  css  js  c++  java
  • 非常好用的验证码模块

    https://github.com/dchest/captcha
    代码库文档齐全,有示例代码,方便学习,推荐大家使用。

    这是一款非常棒的验证码模块,支持自定义存储方式,支持语音播报,最重要的是使用起来非常简单。

    安装

    go get -u "github.com/dchest/captcha"
    go get -u "github.com/astaxie/beego"   #如果您要使用 beego 的话,或者需要运行下面的示例代码
    

    Captcha 在 beego 中的简单示例

    package main
    
    import (
        "strconv"
        "strings"
    
        "github.com/astaxie/beego"
        "github.com/dchest/captcha"
    )
    
    const HTML_TPL string = `
    <!doctype html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>Captcha by Golang</title>
    </head>
    
    <body>
    <form method="post">
        <p><img src="/captcha/{{.CaptchaId}}.png" /></p>
        <p><input name="captcha" placeholder="请输入验证码" type="text" /></p>
        <input name="captcha_id" type="hidden" value="{{.CaptchaId}}" />
        <input type="submit" />
    </form>
    </body>
    </html>`
    
    // Main 控制器
    type MainController struct {
        beego.Controller
    }
    
    func (this *MainController) Get() {
        captchaId := captcha.NewLen(6) //验证码长度为6
        html := strings.Replace(HTML_TPL, "{{.CaptchaId}}", captchaId, -1)
        this.Ctx.WriteString(html)
    }
    
    func (this *MainController) Post() {
        id, value := this.GetString("captcha_id"), this.GetString("captcha")
        b := captcha.VerifyString(id, value) //验证码校验
        this.Ctx.WriteString(strconv.FormatBool(b))
    }
    
    //设置beego和路由注册
    func init() {
        beego.AutoRender = false //禁止 beego 的模板自动渲染
    
        beego.Router("/", &MainController{})
        beego.Handler("/captcha/*.png", captcha.Server(240, 80)) //注册验证码服务,验证码图片的宽高为240 x 80
    }
    
    func main() {
        beego.Run() //打开浏览器并访问 http://localhost:8080
    }
    

    验证码示例图片

  • 相关阅读:
    vim 末行模式简单练习
    末行模式
    vim 简单用法
    sed用法
    在原有的基础之上,启用NAT模型
    启用隔离模型
    一个前端的自我修养
    如何提升我的HTML&CSS技术,编写有结构的代码
    MVC缓存
    MVC分页
  • 原文地址:https://www.cnblogs.com/bing-l/p/4140081.html
Copyright © 2011-2022 走看看