绘制微信小程序验证码功能的实例代码
作者:WALL*E 发布时间:2024-04-17 10:30:28
标签:小程序,验证码
1.在 utils
文件中新建 mcaptcha.js
文件,写入以下代码:
module.exports = class Mcaptcha {
//画板
constructor(options) {
this.options = options;
this.fontSize = options.height * 3 / 4;
this.init();
this.refresh(this.options.code);
}
init() {
this.ctx = wx.createCanvasContext(this.options.el);
this.ctx.setTextBaseline("middle");
this.ctx.setFillStyle(this.randomColor(180, 240));
this.ctx.fillRect(0, 0, this.options.width, this.options.height);
}
//绘制彩图
refresh(code) {
let arr = (code + '').split('');
let width = this.options.width;
let height = this.options.height;
let ctx = this.ctx;
if (arr.length === 0) {
arr = ['e', 'r', 'r','o','r'];
};
let offsetLeft = width * 0.6 / (arr.length - 1);
let marginLeft = width * 0.2;
arr.forEach((item, index) => {
ctx.setFillStyle(this.randomColor(0, 180));
let size = this.randomNum(24, this.fontSize);
ctx.setFontSize(size);
let dis = offsetLeft * index + marginLeft - size * 0.3;
let deg = this.randomNum(-30, 30);
ctx.translate(dis, height*0.5);
ctx.rotate(deg * Math.PI / 180);
ctx.fillText(item, 0, 0);
ctx.rotate(-deg * Math.PI / 180);
ctx.translate(-dis, -height * 0.5);
})
//绘制干扰线
for (var i = 0; i < 2; i++) {
ctx.strokeStyle = this.randomColor(40, 180);
ctx.beginPath();
ctx.moveTo(this.randomNum(0, width), this.randomNum(0, height));
ctx.lineTo(this.randomNum(20, width), this.randomNum(2, height));
ctx.stroke();
}
//绘制干扰点
for (var i = 0; i < 30; i++) {
ctx.fillStyle = this.randomColor(0, 255);
ctx.beginPath();
ctx.arc(this.randomNum(0, width), this.randomNum(0, height), 1, 0, 2 * Math.PI);
ctx.fill();
}
ctx.draw();
}
//设置随机数的颜色
randomNum(min, max) {
return Math.floor(Math.random() * (max - min) + min);
}
randomColor(min, max) {
let r = this.randomNum(min, max);
let g = this.randomNum(min, max);
let b = this.randomNum(min, max);
return "rgb(" + r + "," + g + "," + b + ")";
}
}
2.在需要验证码的js
文件中引入
let Mcaptcha = require("../../../utils/mcaptcha.js");
res.data
是要传到mcaptcha.js
中的 code
值,也就是验证码,可以随意写为如:“ho55”,“a2sd”
等等。我这里是从后台传过来的数据,(前人写的代码,不好改动,只在前端加上干扰线和彩图)。
new Mcaptcha({
el: 'canvas',
width: 100,
height: 30,
code: res.data
});
wxml
文件, bindtap="getImgYZM"
是 new Mcaptcha
的方法名,再次点击可以换验证码图片。
<view bindtap="getImgYZM" class="yzm">
<canvas style="width:{{cvs.width}};height:{{cvs.height}};" canvas-id="canvas"></canvas>
</view>
如果是在前端设置随机数,可以在data:{}
里面写
data: {
str:"0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,P,Q,R,S,T,U,V,W,X,Y,Z",
randStr:""
}
//获取随机数
var res = "";
for(var i = 0; i < str.length ; i ++) {
var id = Math.ceil(Math.random()*35);
res += chars[id];
}
return res;
这一步可不看,以下是后端C#语言产生随机数返给前端的代码:
using JobClass;
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Linq;
using System.Web;
using System.Web.SessionState;
namespace WebSite.pcode
{
/// <summary>
/// getcode 的摘要说明
/// </summary>
public class getcode : IHttpHandler, IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string str = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,P,Q,R,S,T,U,V,W,X,Y,Z";
string randStr = "";
//生成随机数 Random
Random randobj = new Random();
string[] arr = str.Split(',');
for (int i = 0; i < 4; i++)
{
randStr += arr[randobj.Next(arr.Length)];
}
context.Response.Write(randStr);
return;
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
来源:https://www.cnblogs.com/cyapi/archive/2021/01/05/14234237.html
0
投稿
猜你喜欢
- 如下所示:import pandas as pd#如果需要的话,需将df中的date列转为datetimedf.date = pd.to_d
- Python字符串问题在arcpy中版本为 python2.x在QGIS中版本为 python2.x 或者 python3.xpython2
- 一、概述现有一个用户表,需要将表数据写入到excel中。环境说明mysql版本:5.7端口:3306数据库:test表名:users表结构如
- 本文实例讲述了php5.4以下版本json不支持不转义内容中文的解决方法。分享给大家供大家参考。具体分析如下:写ERP接口的时候遇到JAVA
- 在flask更新到1.0之后的版本,官方推荐使用flask run的方式运行程序,可是作为开发,如果没有了pycharm的断点调试,这可太难
- 背景接口域名没有写死,而是动态获取。具体实现就是 通过读取一个静态json文件,来设置真实的接口域名。好处是原域名有可能被封,这样可以直接后
- 2.1数据的爬取代码:import pandas as pddata=pd.read_csv("example_data.csv&
- 继打游戏、看视频等摸鱼行为被监控后,现在打工人离职的倾向也会被监控。有网友爆料称知乎正在低调裁员,视频相关部门几乎要裁掉一半。而在知乎裁员的
- 最近对爬虫比较感兴趣,所以就学了一下,看人家都在网上爬取那么多美女图片养眼,我也迫不及待的试了一下,不多说,切入正题。其实爬取图片和你下载图
- 在查询语句中使用 NOLOCK 和 READPAST 处理一个数据库死锁的异常时候,其中一个建议就是使用 NOLOCK 或者 READPAS
- 我一直很难理解Javascript语言的继承机制。它没有"子类"和"父类"的概念,也没有"
- 最近花些时间学习了一下Python,并写了一个多线程的爬虫程序来获取电影天堂上资源的迅雷下载地址,代码已经上传到GitHub上了,需要的同学
- PDO::queryPDO::query — 执行 SQL 语句,返回PDOStatement对象,可以理解为结果集(PHP 5 >=
- append() 方法向列表的尾部添加一个新的元素。只接受一个参数。>>> num = [1,2]>>>
- 这篇文章主要介绍了python几种常用功能实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- QZONE平台的相册功能为保证加载速度一直以来以简洁的图片排列查看模式呈现相片,随着市场上各类相册产品推陈出新,用户越来越强烈的要求个人相册
- 脉冲星假信号频率的相对路径论证。首先看一下演示结果:实例代码:import numpy as npimport matplotlib.pyp
- (1) 单人脸情况import cv2import dlibpath = "1.jpg"img = cv2.imread
- 为了偷个懒,利用这个数据库,但是在附加的时候出错了。错误如下:一开始还以为数据库位置存在问题,所以重新放置了一个位置,仍然无效。最后,上网寻
- Mysql事务操作失败如何解决事务的原子性 :事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做 。要实现事务的原子性,单单