C#.net验证码问题

 

使用了无效参数。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.ArgumentException: 使用了无效参数。
{"Parameter is not valid."}

源文件: public partial class ValidateImage : System.Web.UI.Page
{
    private readonly string ImagePath = "~/Images/validator.jpg";
    private string sValidator = "";
    private Brush[] BrushList = new Brush[32];

    private void Page_Load(object sender, System.EventArgs e)
    {
        ///初始化
        InitBrushList();

        if (Request.Params["Validator"] != null)
        {
            ///获取验证字符串
            sValidator = Request.Params["Validator"].ToString();
        }

        ///创建Bmp位图
      Bitmap bitMapImage = new System.Drawing.Bitmap(Server.MapPath(ImagePath));
        Graphics graphicImage = Graphics.FromImage(bitMapImage);


        ///设置画笔的输出模式
        graphicImage.SmoothingMode = SmoothingMode.AntiAlias;
        ///添加文本字符串
        for (int i = 0; i < sValidator.Length; i++)
        {
            graphicImage.DrawString(sValidator[i].ToString(),
                new Font("Arial", 20, (FontStyle)CreateRandomFontStyle(GetRandomint(0, 1000))),
                BrushList[GetRandomint(0, BrushList.Length - 1)],
                new PointF(i * 15, GetRandomint(-5, 5)));
        }

        //graphicImage.DrawString(sValidator, new Font("Arial", 20, (FontStyle)GetRandomint(0,4)),SystemBrushes.WindowText, new Point(0, 0));

        ///设置图像输出的格式
        Response.ContentType = "image/jpeg";

        ///保存数据流
        bitMapImage.Save(Response.OutputStream, ImageFormat.Jpeg);

        ///释放占用的资源
        graphicImage.Dispose();
        bitMapImage.Dispose();
        Response.End();
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!感谢您的提问。关于 C# ASP.NET 验证码的生成和验证,可以使用以下代码。 生成验证码: ```csharp // 生成验证码 string CheckCode = string.Empty; Random random = new Random(); for (int i = 0; i < 4; i++) { int number = random.Next(); char code = (char)('0' + (char)(number % 10)); CheckCode += code.ToString(); } // 将验证码存储到 Session 中 Session["CheckCode"] = CheckCode; // 生成验证码图片 System.Drawing.Bitmap image = new System.Drawing.Bitmap((int)Math.Ceiling((CheckCode.Length * 15.5)), 22); System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(image); try { // 清空图片背景色 g.Clear(System.Drawing.Color.White); // 画图片的背景噪音线 for (int i = 0; i < 25; 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 System.Drawing.Pen(System.Drawing.Color.Silver), x1, y1, x2, y2); } // 画图片的前景噪音点 for (int i = 0; i < 100; i++) { int x = random.Next(image.Width); int y = random.Next(image.Height); image.SetPixel(x, y, System.Drawing.Color.FromArgb(random.Next())); } // 画图片的验证码 System.Drawing.Font font = new System.Drawing.Font("Arial", 12, (System.Drawing.FontStyle.Bold)); System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new System.Drawing.Rectangle(0, 0, image.Width, image.Height), System.Drawing.Color.Blue, System.Drawing.Color.DarkRed, 1.2f, true); g.DrawString(CheckCode, font, brush, 2, 2); // 画图片的边框线 g.DrawRectangle(new System.Drawing.Pen(System.Drawing.Color.Silver), 0, 0, image.Width - 1, image.Height - 1); // 将验证码图片写入内存流并输出到页面 System.IO.MemoryStream ms = new System.IO.MemoryStream(); image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); Response.ClearContent(); Response.ContentType = "image/Jpeg"; Response.BinaryWrite(ms.ToArray()); } finally { // 释放资源 g.Dispose(); image.Dispose(); } ``` 验证验证码: ```csharp // 获取用户输入的验证码 string userCode = txtCheckCode.Text.Trim(); // 获取 Session 中保存的验证码 string checkCode = Session["CheckCode"].ToString(); // 验证验证码 if (string.Compare(userCode, checkCode, true) == 0) { // 验证码输入正确 } else { // 验证码输入错误 } ``` 以上代码可以生成包含随机验证码的图片,并将图片输出到页面。在页面中添加一个图片控件即可显示验证码图片。同时,将验证码存储到 Session 中,以便在验证时使用。在用户输入验证码后,将用户输入的验证码和 Session 中保存的验证码进行比较,以验证验证码是否输入正确。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值