• Ext.js项目(一)


    这个项目整体采用代码生成器生成,具体看下图:

    一、实现登录的思路:

          1.添加系统CSS和JS

          2.构建登录的Login.aspx的页面HTML

          3.编写登录Ext.js的代码

          4.编写CSS 实现登录与密码框前的小图标

          5.实现登录验证码

          6.实现登录的前后台编码

    二、具体代码:

         1.添加系统CSS和JS

        

    <script type="text/javascript" src="/Web/Ext/adapter/ext/ext-base-debug.js"></script>
    <script type="text/javascript" src="/Web/Ext/ext-all-debug.js"></script>
    <script src="/Web/JavaScript/Common/Global.js" type="text/javascript"></script>
    

       2.构建登录的Login.aspx的页面HTML

    <body>
        <div id="hello-win" class="x-hidden">
            <div class="x-window-header">登录入口</div>
            <div id="hello-tabs">
            	    <img src="images/systemBanner.jpg"/>
            </div>
             <div id='loginInfo' style='color:red;padding-left:120px;'>
      
        请输入已经通过审核的用户名与密码进行登陆!
        </div>
        </div>
    </body>
    

     3.编写登录Ext.js的代码

     
      <script type="text/javascript">
            Ext.onReady(function () {
                Ext.BLANK_IMAGE_URL = "/ExtOA.Web/Ext/resources/images/default/s.gif";
                var loginForm = new Ext.FormPanel({
                    el: "hello-tabs",
                    id: "loginForm",
                    name: "loginForm",
                    border: false,
                    //配置项
                    items: {
                        //xtype可作为Ext控件的简写,都会对应一个Ext控件
                        xtype: "tabpanel",
                        //第一项
                        activeTab: 0,
                        defaults: { autoHeight: true, bodyStyle: "padding:10px" },
                        items: [
                            {
                                title: "管理员登录",
                                //显示对应的div
                                contentEl: "loginInfo",
                                //排列的方式
                                layout: "form",
                                defaults: {  230 },
                                //默认的类型
                                defaultType: "textfield",
                                //里面具体的内容
                                items:
                                [
                                    {
                                        //引入css样式的写法
                                       cls: "user",
                                       fieldLabel: "帐号",
                                       name: "staffName",
                                       style: "font-size:15px",
                                        //不允许为空
                                       allowBlank: false,
                                        //提示
                                       blankText: "帐号不允许为空!"
                                    },
                                    {
                                        cls: "key",
                                       fieldLabel: "密码",
                                       name: "staffPwd",
                                       style: "font-size:15px",
                                        //文本类型
                                       inputType: "password",
                                       allowBlank: false,
                                       blankText: "密码不允许为空!"
                                    },
                                    {
                                        fieldLabel: "验证码",
                                         id: "validateCode",
                                         name: "validateCode",
                                         maxlength: 4,
                                          100,
                                        //大小
                                         style: "font-size:15px",
                                         allowBlank: false,
                                         blankText: "请输入验证码!"
                                    },
                                ]
    
                            },
                            //第二块选项卡
                       {
                           title: "关于本系统",
                           layout:"",
                           html: "OA办公平台 v 1.0<br> 版权所有 孙丽媛  © <br/>技术支持:13593372136@163.com"
                       }
                     ]
    
                    }
                });
    
                //创建windows窗体对象
                var win = new Ext.Window({
                    el: "hello-win",
                     490,
                    height: 280,
                    //关闭的时候隐藏
                    closeAction: "hide",
                    //内部为透明的
                    plain: true,
                    //为模态显示
                    modal: true,
                    //是否允许折叠
                    collapsible: true,
                    //是否允许拖动
                    draggable: true,
                    //是否允许关闭
                    closable: false,
                    //登录窗体作为项
                    items: loginForm,
    
                    buttons: [
                        {
                            text: "确定",
                            handler: function () {
                                //判断是否通过验证
                                if (win.getComponent("loginForm").form.isValid()) {
                                    //进行提交
                                    win.getComponent("loginForm").form.submit({
                                        url: "handler/CheckLogin.aspx",
                                        waitTitle: "提示",
                                         waitMsg: "正在登录验证,请稍候...",
                                          method: "POST",
                                          success: function (form,action) {
                                              var loginResult = action.result.success;
                                              if (loginResult) {
                                                  window.location.href = action.result.href;
                                              } else {
                                                  Ext.Msg.alert("提示",action.result.message);
                                              }
                                          },
                                          failure: function (form,action) {
                                              Ext.Msg.alert("提示", action.result.message);
                                              //失败得到图片的对象
                                              var imgSN = Ext.getDom("imgSnCode");
                                              if (imgSN)
                                              {
                                                  //加参数
                                                imgSN.src="handler/VerifyCode.aspx?datetime=" + (new Date()).getTime();
                                              }
                                          },
                                    });
                                }
                               // alert("确定");
                            }
                        },
                        {
                            text: "重置",
                            handler: function () {
                                //获取loginFrom的主建  或者直接获取
                                win.getComponent("loginForm").form.reset();
                              //  loginForm
                                //alert("重置");
                            }
                        }
                    ]
                });
    
                //让窗体显示
                win.show();
                //得到验证码控件
                var db = Ext.getDom("validateCode");
                //得到父节点
                var db2 = Ext.get(db.parentNode);
                //用DomHelper得到getDom 的值
                db2.createChild([{ tag: "span", html: "   " }, { tag: "img", id: "imgSnCode",style:"cursor:pointer",title:"看不清楚?", src: "handler/VerifyCode.aspx", align: "absbottom" }]);
    
                //让验证码刷新
                var imgSN = Ext.get("imgSnCode");
                if (imgSN) {
                    imgSN.on("click", function () {
                        this.dom.src = "handler/VerifyCode.aspx?datetime=" + (new Date()).getTime();
                    });
                }
            })
    
     
    
           
        </script>
    

     5.实现登录验证码

         1.后台验证码的帮助类:

     
     
    
       /// <summary>
       /// 产生一个随机数
       /// </summary>
       /// <param name="codeCount"></param>
       /// <returns></returns>
        private string CreateRandomCode(int codeCount)
        {
            string allChar = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,w,x,y,z";
            string[] allCharArray = allChar.Split(',');
            string randomCode = "";
            int temp = -1;
    
            Random rand = new Random();
            for (int i = 0; i < codeCount; i++)
            {
                if (temp != -1)
                {
                    rand = new Random(i * temp * ((int)DateTime.Now.Ticks));
                }
                int t = rand.Next(35);
                if (temp == t)
                {
                    //不相等的话继续产生
                    return CreateRandomCode(codeCount);
                }
                temp = t;
                randomCode += allCharArray[t];
            }
            return randomCode;
        }
    
    
        private void CreateImage(string checkCode)
        {
            //创建宽度
            int iwidth = (int)(checkCode.Length * 11.5);
            System.Drawing.Bitmap image = new System.Drawing.Bitmap(iwidth, 20);
            Graphics g = Graphics.FromImage(image);
            Font f = new System.Drawing.Font("Arial", 10, System.Drawing.FontStyle.Bold);
            Brush b = new System.Drawing.SolidBrush(Color.Blue);
            //g.FillRectangle(new System.Drawing.SolidBrush(Color.Blue),0,0,image.Width, image.Height);
            g.Clear(Color.White);
            g.DrawString(checkCode, f, b, 3, 3);
    
    
            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());
            g.Dispose();
            image.Dispose();
        }
    

     2.前台js的调用:(动态产生图片)

       //得到验证码控件
                var db = Ext.getDom("validateCode");
                //得到父节点
                var db2 = Ext.get(db.parentNode);
                //用DomHelper得到getDom 的值
                db2.createChild([{ tag: "span", html: "   " }, { tag: "img", id: "imgSnCode", src: "handler/VerifyCode.aspx", align: "absbottom" }]);
    

     3.后台核心代码:

    1.指向的页面: (为aspx页面
    <%Page Language="C#" AutoEventWireup="true" CodeFile="VerifyCode.aspx.cs" Inherits="VerifyCode" %>

    private void Page_Load(object sender, System.EventArgs e) { string checkCode = CreateRandomCode(4);//产生一个数字+字母组合的随机四位数 Session["CheckCode"] = checkCode; //将此四位数保存至Session,供登录验证 CreateImage(checkCode);//根据此验证码产生图片返回到调用端 }

    6.实现登录的前后台编码

    前台:重置按钮:

      win.getComponent("loginForm").form.reset();
    

     确认按钮:(通过Submit提交)

                               //判断是否通过验证
                                if (win.getComponent("loginForm").form.isValid()) {
                                    //进行提交
                                    win.getComponent("loginForm").form.submit({
                                        url: "handler/CheckLogin.aspx",
                                        waitTitle: "提示",
                                         waitMsg: "正在登录验证,请稍候...",
                                          method: "POST",
                                          success: function (form,action) {
                                              var loginResult = action.result.success;
                                              if (loginResult) {
                                                  window.location.href = action.result.href;
                                              } else {
                                                  Ext.Msg.alert("提示",action.result.message);
                                              }
                                          },
                                          failure: function (form,action) {
                                              Ext.Msg.alert("提示", action.result.message);
                                              //失败得到图片的对象
                                              var imgSN = Ext.getDom("imgSnCode");
                                              if (imgSN)
                                              {
                                                  //加参数
                                                imgSN.src="handler/VerifyCode.aspx?datetime=" + (new Date()).getTime();
                                              }
                                          },
                                    });
    

     后台代码:CheckLogin.aspx

     string username = Request["staffName"].ToString();
            string password = Request["staffPwd"].ToString();
            string reqCheckCode = Request["validateCode"].ToString();
            //保存在session中的验证码
            string checkCode = Session["CheckCode"].ToString();
            //思路:先检查验证码是否正确,是否存在用户名,最后判断密码
            if (checkCode != reqCheckCode)
            {
                Response.Write("{success:false,message:'登录失败,您输入的验证码和系统产生的不一致,请重新输入!'}");
            }
            else {
                ExtOA.Biz.UserInfoBiz helper = new ExtOA.Biz.UserInfoBiz();
                ExtOA.Ent.UserInfo userinfo = helper.GetUserInfoByUserName(username);
                if (userinfo != null)
                {
                    if (userinfo.PassWord == password)
                    {
    Session["CurrentUser"]==userinfo; Response.Write("{success:true,href:'/Web/Manage/DeskTop/index.aspx',message:''}"); } else { Response.Write("{success:false,message:'登录失败,您输入的密码不正确,请与管理员联系!'}"); } } else { Response.Write("{success:false,message:'登录失败,您的用户名尚未通过验证,请与管理员联系!'}"); }

    后台代码部分思路:

          1.ExtOA.IDal添加一个新方法

          2. ExtOA.SqlServerDal实现ExtOA.IDal方法

          3.UserInfoBiz业务逻辑层中调用ExtOA.SqlServerDal中的方法

          4.CheckLogin中调用UserInfoBiz

    ExtOA.IDal:

     UserInfo GetUserInfoByUserName(string usernaem);
    

     ExtOA.SqlServerDal:

       /// <summary>
            /// 根据用户名获取用户实体
            /// </summary>
            /// <param name="usernaem"></param>
            /// <returns></returns>
            public UserInfo GetUserInfoByUserName(string usernaem)
            {
                UserInfo result = null;
                string sql = "Get_UserInfo_By_UserName";
                using (System.Data.SqlClient.SqlConnection connection = new System.Data.SqlClient.SqlConnection(ConnectionString))
                {
                    System.Data.SqlClient.SqlCommand command = new System.Data.SqlClient.SqlCommand(sql, connection);
                    command.CommandType = System.Data.CommandType.StoredProcedure;
                    //command.CommandTimeout = 0;
    
                    System.Data.SqlClient.SqlParameter p_userName = command.Parameters.Add("@UserName", SqlDbType.VarChar);
                    p_userName.Direction = ParameterDirection.Input;
                    p_userName.IsNullable = false;
                    p_userName.Value = usernaem;
    
                    connection.Open();
                    using (SqlDataReader dr = command.ExecuteReader())
                    {
                        if (dr.Read())
                        {
                            result = new UserInfo();
                            result = PopulateUserInfoFromIDataReader(dr);
                        }
                        dr.Close();
                    }
    
                    command.Dispose();
                    connection.Close();
                }
                return result;
            }
    

     UserInfoBiz:

       /// <summary>
             /// 根据用户名获取用户的实体 
             /// </summary>
             /// <param name="usernaem"></param>
             /// <returns></returns>
            public UserInfo GetUserInfoByUserName(string usernaem)
            {
                try
                {
                    IUserInfoDR dal = UserInfoDal.Create(Config.Instance().Dal, Config.Instance().MyConnectstring);
                    return dal.GetUserInfoByUserName(usernaem);
                }
                catch (Exception ex)
                {
                    //log.Error("SetUserInfo err:",ex);
                    return null;
                }
            }
    

    效果图:

  • 相关阅读:
    pta建立与遍历二叉树
    Pikachu-SSRF(服务器端请求伪造)
    Pikachu-Sql Inject(SQL注入)
    Pikachu-RCE(远程命令/代码执行漏洞)
    Pikachu-php反序列化
    Pikachu-over permission(越权操作)
    Pikachu-File Inclusion(文件包含漏洞)
    Pikachu-CSRF(跨站请求伪造)
    CMS-熊海网站内容管理系统漏洞测试
    DVWA-命令执行
  • 原文地址:https://www.cnblogs.com/sunliyuan/p/5815096.html
Copyright © 2020-2023  润新知