伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

Python-web验证码的实现

来源:本站原创 浏览:76次 时间:2022-07-11

此代码是需要依赖:

  • sanic==19.9.0

  • Pillow==7.0.0

马哥教育Python网络班企业教练思路:

import randomimport stringimport uuidimport base64import platformfrom PIL import Image, ImageDraw,ImageFontfrom io import BytesIOfrom sanic import Sanicfrom sanic.response import HTTPResponse,textfrom sanic.views import HTTPMethodView
app = Sanic()
session = {}
class VerifyCode:    def __init__(self, numbers:int):        """        指定:生成的数量        """        self.number = numbers
   def draw_lines(self, draw, num, width, height):        """划线"""
       x1 = random.randint(0, width / 2)        y1 = random.randint(0, height / 2)        x2 = random.randint(0, width)        y2 = random.randint(height / 2, height)        draw.line(((x1, y1), (x2, y2)), fill='black', width=1)
   def random_color(self):        """随机颜色"""        return (random.randint(32, 127), random.randint(32, 127), random.randint(32, 127))    def gene_text(self):        """生成验证码"""        return "".join(random.sample(string.ascii_letters+string.digits, self.number))
   def get_verify_code(self):        """        draw.text():            文字的绘制,第一个参数指定绘制的起始点(文本的左上角所在位置),第二个参数指定文本内容,第三个参数指定文本的颜色,第四个参数指定字体(通过ImageFont类来定义)        """        code = self.gene_text()        width, height = 130, 30        im = Image.new("RGB", (width, height), "white")        sysstr = platform.system()        font = None        if sysstr == "Windows":            font = ImageFont.truetype("C:\WINDOWS\Fonts\STXINGKA.TTF", 25)        elif sysstr == "Darwin":            font = ImageFont.truetype('/Library/Fonts/AppleMyungjo.ttf', 25)        draw = ImageDraw.Draw(im)        for item in range(self.number):            draw.text((5+random.randint(-5,5)+23*item, 5+random.randint(-5, 5)), text=code[item],                      fill=self.random_color(), font=font)            self.draw_lines(draw, self.number, width, height)        return im, code

class SimpleView(HTTPMethodView):    body = """        <html>            <head>                <meta charset="UTF-8">                    <title>登录</title>                    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">                    <!-- 可选的 Bootstrap 主题文件(一般不用引入) -->                    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">                    <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->                    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>            </head>            <body>                <form class="form-inline" method="post" action="/code">                    <div>                        <div class="form-group">{error}                                                        </div>                        <div class="form-group">                                <label for="exampleInputName2">验证码</label>                                <input type="text" class="form-control" id="captcha" name="code">                        </div>                        <div class="form-group">                            <img src="data:image/jpeg;base64,{base64_data}" class="img-img-rounded">                        </div>                        <div>                            <button type="submit">验证</button>                        </div>                    </div>                </form>            </body>        </html>        """
   async def get(self, request):        return self.response(error="")
   async def post(self, request):        uuid = request.cookies.get("uuid", "1")        verfy_code = request.form.get("code", "2").lower()        code = session.get(uuid, "").lower()        if code == verfy_code:            return text('验证码正确')        return self.response(error='<input class="form-control" id="disabledInput" type="text" placeholder="验证码错误" disabled>')
   def response(self, error):        im, code = VerifyCode(5).get_verify_code()        buf = BytesIO()        im.save(buf, "jpeg")        buf_str = buf.getvalue()        base64_data = base64.b64encode(buf_str).decode()        id = uuid.uuid1().__str__()        session[id] = code        body = self.body.format(base64_data=base64_data, error=error)        response = HTTPResponse(body, content_type="text/html; charset=utf-8")        response.cookies["uuid"] = id        return response

app.add_route(SimpleView.as_view(), '/code')
if __name__ == "__main__":    app.run(host="0.0.0.0", port=8000)
简单的实现了验证码,没有实现点击刷新,点击刷新的原理不难:
异步请求+刷新接口就好了,记得更新对应的session的key里面的value


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net