2024年最新ASP(6),2024年最新三面头条+四面阿里+五面腾讯拿offer分享面经总结

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!


img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

    public void ProcessRequest(HttpContext context)
    {

    }

    public bool IsReusable
    {
        get
        {
            return false;
        }
    }
}

}


VerCode 类实现了 IHttpHandler 接口,用于处理 HTTP 请求。




---


### **2、创建验证码生成方法**



///
/// 随机构建验证码方法
///
/// 返回验证码字符串
public string CreateCode()
{
char code;
string checkCode = string.Empty;
Random rd = new Random();

for (int i = 0; i < 4; i++)
{
    int num = rd.Next();
    int _temp;

    if (num % 2 == 0)
    {
        _temp = ('0' + (char)(num % 10));
        if (_temp == 48 || _temp == 49)
        {
            _temp += rd.Next(2, 9);
        }
    }
    else
    {
        _temp = ('A' + (char)(num % 10));
        if (rd.Next(0, 2) == 0)
        {
            _temp = (char)(_temp + 32);
        }
        if (_temp == 66 || _temp == 73 || _temp == 79 || _temp == 108 || _temp == 111)
        {
            _temp++;
        }
    }
    code = (char)_temp;
    checkCode += code;
}
return checkCode;

}


CreateCode 方法用于生成随机验证码,包含数字和字母,并进行了一些特殊字符的处理,以增加验证码的复杂性。




---


### 3、 绘制验证码图片


#### ① 配置验证码参数


我们先定义验证码图像的宽度、高度、字体大小以及用于生成随机数的 Random 对象。



int codeWeight = 80;
int codeHeight = 22;
int fontSize = 16;
Random rd = new Random();




---


#### ② 生成验证码字符串


这一步很简单,我们直接调用之前写好的 CreateCode 方法。



string checkCode = CreateCode();




---


#### ③ 构建验证码背景


创建一个位图对象,并在其上创建图形对象,然后用白色填充图像背景。



Bitmap image = new Bitmap(codeWeight, codeHeight);
Graphics g = Graphics.FromImage(image);
g.Clear(Color.White);




---


#### **④ 画噪音线**


在图像上绘制两条随机颜色的噪音线,增加验证码的复杂性。



for (int i = 0; i < 2; i++)
{
int x1 = rd.Next(image.Width);
int x2 = rd.Next(image.Width);
int y1 = rd.Next(image.Height);
int y2 = rd.Next(image.Height);
g.DrawLine(new Pen(color[rd.Next(color.Length)]), new Point(x1, y1), new Point(x2, y2));
}




---


#### ⑤ 画验证码


使用循环逐个绘制验证码字符串中的字符,每个字符使用随机颜色和字体。



for (int i = 0; i < checkCode.Length; i++)
{
Color clr = color[rd.Next(color.Length)];
Font ft = new Font(font[rd.Next(font.Length)], fontSize);
g.DrawString(checkCode[i].ToString(), ft, new SolidBrush(clr), (float)i * 18 + 2, 0);
}




---


#### ⑥ 画噪音点


在图像上绘制100个随机颜色的噪音点,增加验证码的随机性。 



for (int i = 0; i < 100; i++)
{
int x = rd.Next(image.Width);
int y = rd.Next(image.Height);
image.SetPixel(x, y, Color.FromArgb(rd.Next()));
}




---


#### ⑦ 画边框线


在图像周围绘制银色边框线,使验证码更加清晰。



g.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);




---


#### ⑧ 将验证码图像保存到内存流


将生成的验证码图像保存到内存流中,准备输出到客户端。



MemoryStream ms = new MemoryStream(); image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);




---


#### **⑨ 将验证码保存到Session中**


将生成的验证码字符串保存到Session中,以便后续验证。



context.Session[ConstantValues.VerCodeSessionName] = checkCode;




---


#### ⑩ 输出图像到客户端


配置HTTP响应,将验证码图像输出到客户端。



context.Response.ContentType = “Image/Gif”;
context.Response.ClearContent();
context.Response.BinaryWrite(ms.ToArray());


最后,别忘记释放图像和图形资源,防止内存泄漏。



finally { image.Dispose(); g.Dispose(); }




---


### 4、完整后端代码


完整的 VerCode.cs 代码如下:



using TestMoudle.Common;
using System;
using System.Drawing;
using System.IO;
using System.Web;

namespace Handlers
{
public class VerCode : IHttpHandler, System.Web.SessionState.IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
int codeWeight = 80;
int codeHeight = 22;

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

[外链图片转存中…(img-tWAgjMPv-1715705059035)]
[外链图片转存中…(img-JT3E1bm4-1715705059035)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值