验证码

开发工具与关键技术:VS   ,   ASP.NET.MVC;

作者:吴维杰

撰写时间:2019.06.05

控制器部分:

public ActionResult ValideCode()

           1.{string strValideCode = Common.ValidCodeUtils.GetRandomCode(5);

           2. Session["ValideCode"] = strValideCode.Trim();

           3. byte[] imgByte = Common.ValidCodeUtils.CreateImage(strValideCode);

           4.return File(imgByte, @"image/jpeg");}

  1.调用封装好的方法生成5位数随机字符串

  2.将生成的字符串保存到session中

  3.将生成的字符串转换成图片

  4.将生成的图片返回到浏览器

封装的实体类方法:

   1. public static string GetRandomCode(int intLength)

        {/*产生数字和密码混合的随机数*/

            string strReturn = string.Empty;

            Random random = new Random();//随机数

            for (int i = 0; i < intLength; i++)

            {char cRerult;

                int intRandom = random.Next();//产生一个非负随机整数

                /*根据当前随机数来确定字符串*/

                //intRandom % 3 获取的是intRandom/3 得到的余数

                if (intRandom % 3 == 0)

                {//产生数字//位数来产生数字

                    cRerult = (char)(0x30 + (intRandom % 10));}

                else if (intRandom % 3 == 1)

                { //位数产生大写字母:大写字符 65-97 A 65

                    //68 D  25 Z

                    cRerult = (char)(0x41 + (intRandom % 0x1a)); }else

                {/余数为2//产生小写字母 98-116

                 cRerult = (char)(0x61 + (intRandom % 0x1a)); }

                strReturn += cRerult.ToString();}

return strReturn; }

     2. public static byte[] CreateImage(string strRandom)

        {//新增图片

            Bitmap newBitmap = new Bitmap(strRandom.Length * 20, 30);

            Graphics g = Graphics.FromImage(newBitmap);

            g.Clear(Color.White);

            //在图片上绘制文字

            SolidBrush solidBrush = new SolidBrush(Color.Red);

            g.DrawString(strRandom, new Font("Aril", 17), solidBrush, 12, 1);

            //在图片上绘制干扰线(这里可以绘制其它类型的干扰)

            Random random = new Random();

            for (int i = 0; i < 10; i++)(利用for循环绘制多条线)

            {//产生一条线,并绘制到画布。 起始点(x,y)  总结点

                int x1 = random.Next(newBitmap.Width);

                int y1 = random.Next(newBitmap.Height);

                int x2 = random.Next(newBitmap.Width);

                int y2 = random.Next(newBitmap.Height);

                g.DrawLine(new Pen(Color.DarkGray), x1, y1, x2, y2); }

            //绘制图片的前景干扰点

            for (int i = 0; i < 100; i++){

                int x = random.Next(newBitmap.Width);

                int y = random.Next(newBitmap.Height);

                newBitmap.SetPixel(x, y, Color.FromArgb(random.Next()));}

            //在最外边绘制边框

g.DrawRectangle(new Pen(Color.Blue), 0, 0, newBitmap.Width, newBitmap.Height);

g.DrawRectangle(new Pen(Color.Blue), -1, -1, newBitmap.Width, newBitmap.Height);

            //将图转保存到内存流中

            MemoryStream ms = new MemoryStream();

            newBitmap.Save(ms, ImageFormat.Jpeg);

            return ms.ToArray();//将流内容写入byte数组返回}

页面部分:

//点击验证码图片,切换验证码,加上参数ts,解决浏览器缓存问题

$("#vcImg").click(function () {

            $("#vcImg").attr("src", "/Main/ValideCode?ts="+new Date().getTime());});

        //验证登录

        $("#btnSubmit").click(function () {

            //序列化表单

            var dataForm = $("#fmLogin").serializeArray();

           //提交数据

            $.post("/Main/CheckLogin", dataForm, function (msg) {

                if (msg == "success") {window.location.href = "/Main/Main";}

                else {layer.alert(msg, {icon:0,title:"提示"});}

                //清空验证码文本框&密码

                $("#PassWord").val("");$("#VerificationCode").val("");

                //刷新验证码 $("#vcImg").click();});});

效果图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值