首页 > 编程语言 >node实现登录图片验证码

node实现登录图片验证码

时间:2023-04-21 15:24:55浏览次数:35  
标签:node 登录 res req 验证码 captcha cookie svg

实现这里的图形验证码我是用的node里svg-captcha模块,可以全部支持字符和数字,全平台支持,用起来很简单。

安装

cnpm i svg-captcha --save

在使用的地方导入

var svgCaptcha = require('svg-captcha');

获取验证码

  • 安装 cookie-parser ,作用是将获取到的session保存到cookie,方便前端访问验证
cnpm i cookie-parser --save
  • 使用 cookie-parser
const cookieParase = require('cookie-parser');

app.use(cookieParase());

这样就可以在项目里使用cookie了

  • 获取验证码
function getCaptcha(req, res, next) {
    var captcha = svgCaptcha.create({
        // 验证码长度
        size: 5,
        // 要排除的字符
        ignoreChars: 'o0i1',
        // 干扰线条数量
        noise: 1,
        // 验证码的字符是否有颜色,默认没有,如果设定了背景,则默认有
        color: true,
        // 验证码图片背景颜色
        background: '#4dffc9',
        // 宽度
        width: 150,
        // 高度
        height: 50,
        // viewBox
        viewBox: '0,0,150,50'
    });
    // 保存到session,忽略大小写
    req.session = captcha.text.toLowerCase();
    console.log(req.session); //0xtg 生成的验证码
    //保存到cookie 方便前端调用验证
    res.cookie('captcha', req.session);
    // res.setHeader('Content-Type', 'image/svg+xml');
    // res.write(String(captcha.data));
    // console.log(String(captcha.data), '111')
    // res.end();
    res.send({
        code: '0',
        data: captcha.data
    });
}

//console.log(String(captcha.data), '111')

做到这只是实现了生成验证码的功能,那么要访问呢?

编写后台路由

// 获取验证码

app.get('/getCaptcha', (req, res, next) => {
    getCaptcha(req, res, next)
})

当前端调用 /api/getCaptcha 这个接口的时候,返回验证码信息,是svg格式

前端访问

发请求获取到的是svg标签,用v-html展示

效果:

标签:node,登录,res,req,验证码,captcha,cookie,svg
From: https://www.cnblogs.com/hxy--Tina/p/17340164.html

相关文章

  • Node.js
     nodejs到底是什么?nodejs是一个开源的,跨平台的JavaScript运行环境;是JavaScript运行的平台,类似于浏览器。不是框架,不是库,也不是语言。通俗来说,就是一款应用程序,它可以运行JavaScript。运行平台:一般就是指一个代码的运行环境;作用是:开发者可以使用指定的编程语言,基于某个环境......
  • CentOS强制指定用户下线并禁止用户再次登录
    CentOS强制指定用户下线并禁止用户再次登录强制指定用户下线可以使用pkill命令kill该用户所有的进程pkill-utom执行上面的命令会将名为“tom”的用户踢下线禁止用户登录使用pkill命令将用户踢下线后该用户可以再次登录,我们要禁止这种行为,有两种方法可以办到锁定用户......
  • Jenkins 忘记登录密码怎么办
    在安装Jenkins中遇到忘记登录密码该怎么呢?方法有很多,我这里记录一下我找的方法1、先停止jenkins服务systemctlstopjenkins2、找到config.xml文件find/-nameconfig.xml命令执行后找到如下结果:/root/.jenkins/config.xml/root/.jenkins/users/admin_83999305795......
  • Node + Express 后台开发 —— 起步
    Node+Express后台开发——起步前面陆续学习了一下node、npm、模块,也稍尝试Express,感觉得换一个思路加快进行。比如笔者对前端的开发已较熟悉,如果领导给一个内部小网站的需求,难道说你得给我配置一个后端?又不是做一个复杂的后端,只是简单的数据存储(增删改查)、上传文件、下......
  • gitlab命令行修改登录页
    现象误操作修改了登录页的url,导致无法登录的问题修改进入gitlab容器dockerexec-itgitlab/bin/bash进入postgresql数据库命令行gitlab-psql执行更改语句UPDATEapplication_settingssethome_page_url='';重启gitlabgitlab-ctlrestart执行截图......
  • 磁盘空间占满问题---------------inode资源问题
    LINUX实战--inode资源问题原创 梦想家-kk 技术梦想家 2023-01-1719:30 发表于福建收录于合集#linux9个 LINUX操作系统 1问题现象目录中创建文件提示本地空间不足,但是通过df-Th发现本地目录下仍有剩余空间  2什么是inode在linux操作系统中,实际每......
  • 管理员登录解析
    控制器文件:admins/controllers/login.gopackagecontrollersimport("github.com/gin-gonic/gin""github.com/gorilla/sessions""goadmin/common""goadmin/modes""net/http""os"......
  • 管理中心,显示管理员信息,修改密码,退出登录
    前言:管理员登录到管理后台后,显示管理员信息,修改管理员密码,退出登录功能正文:管理中心显示  个人信息页面: 修改密码页: 文件:admins/controllers/admins.go管理后台首页控制器后台首页,退出登录vardb=common.DB//后台首页funcAdminIndex(c*gin.Context)......
  • Linux 安装 Node Exporter
    1.下载安装cdsrcwgethttps://github.com/prometheus/node_exporter/releases/download/v1.5.0/node_exporter-1.5.0.linux-amd64.tar.gztarxfnode_exporter-1.5.0.linux-amd64.tar.gzmvnode_exporter-1.5.0.linux-amd64/node_exporter/usr/binuseradd-s/sbin/nologin......
  • Node版本如何升级
    华为云开发者联盟 更新方式1、安装N#查看当前版本node-v#清理本地包缓存npmcacheclean-f#安装npmi-gn#查看n是否安装成功n-V2、更新node版本nstable//把当前系统的Node更新成最新的“稳定版本”nlts//长期支持版nlatest//最新版n16.13.1//指定安装......