首页 > 其他分享 >后端生成验证码图片

后端生成验证码图片

时间:2023-09-11 18:11:15浏览次数:62  
标签:code int image random 验证码 生成 new 图片

后端生成验证码

一、前端请求

/**
 * 获取验证码
 */
export async function getCaptcha() {
    // 这是前端的请求,用的是axios
  const res = await request.get('/Commons/getCaptcha');
  if (res.data.code == 200) {
    return res.data.data;
  }
  return Promise.reject(new Error(res.data.message));
}

二、后端实现

请求方法控制器

[HttpGet]
public JObject getCaptcha()
{
    
    JObject json = new JObject();
    string code = "";
    var imageBase64 = GenerateCode(out code); // 生成验证码

    CaptchaObj captchaObj = new CaptchaObj();
    captchaObj.base64 = "data:image/png;base64,"+imageBase64.ToString();
    captchaObj.text = code;

    string result = JsonConvert.SerializeObject(captchaObj);
    var obj = JObject.Parse(result);
    json.Add("code", "200");
    json.Add("data", obj);
    json.Add("message", "操作成功!");

    return json;
}

二、生成验证码

/// <summary>
/// 生成验证码
/// </summary>
/// <param name="codeLen">验证码长度</param>
/// <returns></returns>
private string GenerateCode(out string code,int codeLen = 5)
{
    string letters = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
    code = string.Empty;
    Random random = new Random();
    //生成四位验证码
    for (int i = 0; i < 5; i++)
    {
        code+= letters[random.Next(0, letters.Length)];
    }

    /*这里将code保存下来做比对验证*/

    //生成验证码图片并显示到pictureBox1
    byte[] bytes = GenerateImg(code); // 生成图片字节
    MemoryStream ms = new MemoryStream(bytes);
    return Convert.ToBase64String(bytes);
    //pictureBox1.Image = image;
}

三、生成验证码图片

public byte[] GenerateImg(string code)
{
    Bitmap image = new Bitmap(code.Length * 12, 25);
    Graphics g = Graphics.FromImage(image);
    try
    {
        //清空图片背景色
        g.Clear(Color.White);

        //增加背景干扰线
        Random random = new Random();
        for (int i = 0; i < 30; i++)
        {
            int x1 = random.Next(image.Width);
            int x2 = random.Next(image.Width);
            int y1 = random.Next(image.Height);
            int y2 = random.Next(image.Height);
            //颜色可自定义
            g.DrawLine(new Pen(Color.FromArgb(255, 212, 231)), x1, y1, x2, y2);
            //g.DrawLine(new Pen(Color.FromArgb(120, 150, 210)), x1, y1, x2, y2);
        }

        //定义验证码字体
        Font font = new Font("Arial", 10, (FontStyle.Bold | FontStyle.Italic | FontStyle.Strikeout));
        //定义验证码的刷子,这里采用渐变的方式,颜色可自定义
        LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.FromArgb(67, 93, 230), Color.FromArgb(70, 128, 228), 1.5f, true);

        //增加干扰点
        for (int i = 0; i < 100; i++)
        {
            int x = random.Next(image.Width);
            int y = random.Next(image.Height);
            //颜色可自定义
            image.SetPixel(x, y, Color.FromArgb(random.Next()));
        }

        //将验证码写入图片
        g.DrawString(code, font, brush, 5, 5);


        //图片边框
        g.DrawRectangle(new Pen(Color.FromArgb(93, 142, 228)), 0, 0, image.Width - 1, image.Height - 1);

        //保存图片数据
        MemoryStream stream = new MemoryStream();
        //image.Save("C:/Users/admin/Desktop/省平台/a.jpeg", System.Drawing.Imaging.ImageFormat.Jpeg);
        image.Save(stream, System.Drawing.Imaging.ImageFormat.Jpeg);
        return stream.ToArray();
    }
    finally
    {
        g.Dispose();
        image.Dispose();
    }

}

四、最后效果图

标签:code,int,image,random,验证码,生成,new,图片
From: https://www.cnblogs.com/zbfoot/p/17694177.html

相关文章

  • Vue、element图片上传回显
    需求:使用element的上传组件,上传图片,回显图片(可无实际上传:不调后台接口)   ......
  • 暂时保留的图片滑动验证不完整的代码,
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><title>图片滑动验证</title><metaname="viewport"content="width=device-width,initial-scale=1.0"/>......
  • 使用Cpolar内网穿透与Lightpicture组合将个人电脑改造成能随时上传、下载或访问,并能生
    1.前言现在的手机越来越先进,功能也越来越多,而手机的摄像功能也愈发强大,所拍摄的照片越来越清晰,但也让数码照片的体积暴涨。对于像笔者这样经常拍照的人来说,手机容量经常告警,因此笔者将家里的电脑改造成能随时上传下载和访问的图片服务器。今天,笔者就为大家展示,如何使用Cpolar内网......
  • 智慧安防/视频分析云平台EasyCVR不显示告警图片该如何解决?
    安防视频监控平台EasyCVR可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安防视频监控的能力,也具备接入AI智能分析的能力,可拓展性强、视频能力灵活,能......
  • 电脑上怎么修改图片的尺寸和大小?修改图片尺寸和大小的方法
    修改图片的尺寸和大小是在处理图片时常见的需求。如果您需要将图片用于不同的用途,例如在网页上显示或者打印,那么您可能需要调整图片的尺寸和大小以适应特定的要求。本节内容小编就以智能抠图助手软件为例来给分享一下修改图片尺寸和大小的方法,一起来看看吧!智能抠图助手不仅可以帮......
  • 年级成绩分析只看排名?在线学生成绩分析软件推荐
     当进行年级成绩分析时,排名是其中的一个重要指标,但不应只局限于排名,还需要综合考虑其他因素和使用适当的工具。在进行成绩分析时,以下是一些常用的方法和工具,可以帮助事半功倍。一、排名分析排名是一种常见且直观的评估学生成绩的方法,通过对学生按照成绩进行排序来确定他们在班......
  • 亚马逊云科技与德勤中国推出新工具,有效缓解生成式AI时代下的安全问题
    随着人工智能技术的飞速发展,生成式AI应用越发广泛,在各领域迎来了新的机遇,但同时也在安全层面给企业带来了新的挑战。网络、数据泄露、隐私侵犯等安全威胁,以及法律法规的不断更新,使跨区域运营过程中的网络安全和合规成为企业持续发展不可或缺的一环。 亚马逊云科技与全球核心级咨询......
  • 智慧安防/视频分析云平台EasyCVR不显示告警图片该如何解决?
    安防视频监控平台EasyCVR可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安防视频监控的能力,也具备接入AI智能分析的能力,可拓展性强、视频能力灵活,能......
  • 如何进行学生成绩分析?
     学生成绩分析是对学生的学习成绩进行深入研究和解读,以揭示学习情况、评估教学效果和提供个性化教学等方面的信息。下面是一个详细的学生成绩分析过程,希望对您有所帮助。一、数据收集与预处理学生成绩数据收集:从教务系统或成绩管理系统中获取学生成绩数据,包括各科目成绩、考试......
  • index.html在webpack打包时动态生成index模板
    通过<%=BASE_URL%>包裹环境变量通过<%if(process.env.NODE_ENV==='production'){%><%}%>包裹条件判断<!DOCTYPEhtml><html><head><metacharset="utf-8"/><metacontent="IE=edge,chrome=1&qu......