ASP.NET MVC+Easyui 实现验证码登录

效果预览:点击验证码图片可以更换验证码

点击验证码图片,验证码会及时改变。

1.创建实现验证码图片的工具类(ValidCodeUtils.cs)

	/// <summary>
    /// 验证码
    /// </summary>
    public static class ValidCodeUtils
    {
        /// <summary>
        /// 获得随机字符串
        /// </summary>
        /// <param name="intLength">随机数的长度</param>
        /// <returns>随机数字符串</returns>
        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;
        }

        /// <summary>
        /// 根据字符串创建验证码图片 
        /// </summary>
        /// <param name="strRandom">字符串</param>
        /// <returns>图片的二进制数组</returns>
        public static byte[] CreateImage(string strRandom)
        {
            //新增图片
            Bitmap newBitmap = new Bitmap(strRandom.Length * 20, 38);

            Graphics g = Graphics.FromImage(newBitmap);
            g.Clear(Color.White);
            //在图片上绘制文字
            SolidBrush solidBrush = new SolidBrush(Color.Red);
            g.DrawString(strRandom, new Font("Aril", 18), solidBrush, 12, 4);
            //在图片上绘制干扰线
            Random random = new Random();
            for (int i = 0; i < 10; i++)
            {
                //产生一条线,并绘制到画布。 起始点(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数组返回
        }
    }

2.Web.Config连接数据库(这里是连接的是本地数据库)

Data Source:连接数据源
Initial Catalog:连接的数据库名称
User ID:用户名
Password:密码
max pool size:最大连接池,默认为100,最大为32767

<connectionStrings>
    <add name="connString" connectionString="Data Source=.;Initial Catalog=SMDBWeb;User ID=sa;Password=123;max pool size=512" providerName="System.Data.SqlClient" />
  </connectionStrings>

3.SQLHelper.cs(通用数据访问类)

   /// <summary>
   /// 通用数据访问类
   /// </summary>
   public class SQLHelper
   {
       //定义连接字符串
       private static string connString = ConfigurationManager.ConnectionStrings["connString"].ToString();
       
       //执行增删改
       public static int ExecuteNonQuery(string sql, params SqlParameter[] pms)
       {
           using (SqlConnection con = new SqlConnection(connString))
           {
               using (SqlCommand cmd = new SqlCommand(sql, con))
               {

                   if (pms != null)
                   {
                       cmd.Parameters.AddRange(pms);

                   }
                   con.Open();
                   return cmd.ExecuteNonQuery();
               }
           }
       }
       //执行返回SqlDataReader
       public static SqlDataReader ExecuteReader(string sql,  params SqlParameter[] pms)
       {
           SqlConnection con = new SqlConnection(connString);

           using (SqlCommand cmd = new SqlCommand(sql, con))
           {
               if (pms != null)
               {
                   cmd.Parameters.AddRange(pms);
               }
               try
               {
                   con.Open();
                   return cmd.ExecuteReader(CommandBehavior.CloseConnection);
               }
               catch (Exception)
               {
                   con.Close();
                   con.Dispose();
                   throw;
               }

           }

       }
       //执行返回单个值:第一列第一行
       public static object ExecuteScalar(string sql, params SqlParameter[] pms)
       {
           using (SqlConnection con = new SqlConnection(connString))
           {
               using (SqlCommand cmd = new SqlCommand(sql, con))
               {
                   if (pms != null)
                   {
                       cmd.Parameters.AddRange(pms);
                   }
                   con.Open();
                   return cmd.ExecuteScalar();
               }
           }
       }
       //执行返回datatable
       public static DataTable ExecuteDataTable(string sql, params SqlParameter[] pms)
       {
           DataTable dt = new DataTable();
           using (SqlDataAdapter adapter = new SqlDataAdapter(sql, connString))
           {
               if (pms != null)
               {
                   adapter.SelectCommand.Parameters.AddRange(pms);

               }
               adapter.Fill(dt);
               return dt;
           }

       }
   }

4.实体类(Sys_user.cs)

	/// <summary>
    /// 用户
    /// </summary>
    public class Sys_user
    {
        public int userid { get; set; }
        public string username { get; set; }
        public string password { get; set; }
    }

5.Service层(Sys_userService.cs)

public class Sys_userService
    {
        //登录
        public Sys_user Login(string username,string password)
        {
            Sys_user sys_User = null;
            //编写Sql语句
            string sql = " select userid,username,password" +
                         " from sys_user" +
                         " where username=@username and password=@password";
             //编写参数
            SqlParameter[] pms = { new SqlParameter("username", username), new SqlParameter("password", password) };
            //调用SQLHelper类中的查询方法
            SqlDataReader reader = SQLHelper.ExecuteReader(sql, pms);
            if (reader.Read())
            {
                sys_User = new Sys_user();
                sys_User.userid =Convert.ToInt32(reader["userid"]);
                sys_User.username = reader["username"].ToString();
                sys_User.password = reader["password"].ToString();
            }
            reader.Close();
            return sys_User;
        }
    }

6.登录页面(Login.cshtml)


@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Login</title>
    <link rel="stylesheet" type="text/css" href="~/Content/themes/default/easyui.css" />
    <link rel="stylesheet" type="text/css" href="~/Content/themes/icon.css">
    <script type="text/javascript" src="~/Scripts/jquery.min.js"></script>
    <script type="text/javascript" src="~/Scripts/jquery.easyui.min.js"></script>
</head>
<body>
    <div style="margin:200px 400px;">
        <form action="/Sys_user/Login" method="post" id="loginForm">
            <div class="easyui-panel" title="Login" style="width:100%;max-width:400px;padding:30px 60px;">
                <div style="margin-bottom:10px">
                    <input class="easyui-textbox" required name="username" label="工号:" labelPosition="left" prompt="请输入工号" style="width:250px;">
                </div>
                <div style="margin-bottom:10px">
                    <input class="easyui-passwordbox" required name="password" label="密码:" labelPosition="left" prompt="请输入密码" iconWidth="28" style="width:250px;">
                </div>
                <div style="margin-bottom:10px">
                    <input type="text" name="validCode" id="validCode" label="验证码:" labelPosition="left" class="easyui-textbox" prompt="验证码" />
                    <img style="position:relative;top:10px;" src="/Sys_user/CreateValidCodeImage" width="80" height="30" id="validCodeImg" />
                </div>
                @if (Session["username"] != null && Session["username"].ToString() != "")
                {
                    <div style="margin-bottom:10px;">
                        <button onclick="login()" disabled class="easyui-linkbutton" style="width:250px;">登录</button>
                    </div>
                }
                else
                {
                    <div style="margin-bottom:10px;">
                        <button onclick="login()" class="easyui-linkbutton" style="width:250px;">登录</button>
                    </div>
                }
                <div style="text-align:center">
                    <a href="/Sys_user/Register">没有账号?去注册</a>
                </div>
            </div>
        </form>
        
        <input type="hidden" value="@ViewData["info"]" id="hiddenInfo" />
    </div>
</body>
</html>

jQuery代码

	<script type="text/javascript">
        $(function () {
            var info = $('#hiddenInfo').val();
            if (info.length > 0) {
                alert(info);
            }

            //验证码换图
            $('#validCodeImg').click(function () {
                //拼接一个参数t,后面加上时间(以毫秒计),每一毫秒更改一次验证码切换的路径。从而克服缓存机制的干扰
                $(this).prop("src", "/Sys_user/CreateValidCodeImage?t=" + new Date().getTime());
            });
        });

        //登录
        function login() {
            var validCodeImg = $('#validCode').val();
            //判断是否填写数据
            if (validCodeImg != null && validCodeImg != "" && validCodeImg != undefined) {
                $('#loginForm').submit();
            }
            else {
                alert("请输入验证码!");
            }
        }
    </script>

7.Controller层(Sys_userController.cs)

	public class Sys_userController : Controller
    {
        //实例化Sys_userService
        private Sys_userService sys_userService = new Sys_userService();
        // GET: Sys_user
        public ActionResult Index()
        {
            return View("Login");
        }

        //生成验证码
        public ActionResult CreateValidCodeImage()
        {
            //1.生成长度为4的随机验证码字符串
            var strRandom = ValidCodeUtils.GetRandomCode(4);
            //2.根据生成的验证码字符串生成验证码图片
            byte[] byteImg = ValidCodeUtils.CreateImage(strRandom);
            //3.将验证码字符串存入session中
            Session["validCode"] = strRandom;
            //4.将图片返回到视图
            return File(byteImg, @"image/jpeg");
        }

        //登录
        public ActionResult Login(Sys_user sys_user, string validCode)
        {
            string sessionValidCode = Session["validCode"].ToString();
            //比较验证码,忽略大小写
            if (sessionValidCode.Equals(validCode, StringComparison.CurrentCultureIgnoreCase))
            {
                sys_user.password = new MD5Util().JM(sys_user.password);
                sys_user = sys_userService.Login(sys_user.username,sys_user.password);
                if (sys_user != null)
                {
                	//登录成功,去到想去的页面即可
                    Session["username"] = sys_user.username;
                    return View("Index");
                }
                else
                {
                    ViewData["info"] = "工号或密码错误,请重新登录!";
                    return View("Login");
                }
            }
            else
            {
                ViewData["info"] = "验证码输入错误!";
                return View("Login");
            }
        }
    }

本文完,希望对你有帮助!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值