• [原]Ajax简单客户登陆验证


       
    服务器端操作方便之处我就不吹了,地球人都知道,它最烦莫过于页面刷新,头都被刷晕了,而且
    他在刷新的时候,还触发服务器端的事件(解决方案:http://skylaugh.cnblogs.com/archive/2006/06/05/418010.html),现在Ajax的出现,他们的结合是发展的必然!

        一、介绍一下Ajax在Asp.Net中的基本使用
        1、在工程中引入Ajax.dll文件。
      Ajax.dll实现XmlHttpRequest请求服务器的实现细节。.net项目中,添加上对其的引用,就可以进

    行相应封装操作了。

        2、在web.config中设置HttpHandle
        <httpHandlers>
          <add verb="POST,GET" path="ajax/*.ashx" type="Ajax.PageHandlerFactory, Ajax"/>
        </httpHandlers>
        3、在 <HEAD>与</HEAD>间加入一些引用如下:
        <script src=js/Xml.js></script> 
        <link href="css/myStyle.css" type="text/css" rel="stylesheet"> 
        <script src="/HttpForAjax/ajax/common.ashx" type="text/javascript"></script> 
        <script src="/HttpForAjax/ajax/Ttyu.AjaxData,HttpForAjax.ashx" type="text/javascript"></
    script> 

        二、介绍正题-用户登录验证
        1、前台Html:
    <form id="Form1" method="post" runat="server" action="" onsubmit="login.GetLogin();return 
    false;">   
        <TABLE id="Table1"  cellSpacing="1" cellPadding="1" 
    width="300" border="1">
         <TR>
          <TD></TD>
          <TD><INPUT type="text" 
    id="txtUsername">usename</TD>
         </TR>
         <TR>
          <TD></TD>
          <TD><INPUT type="password" 
    id="txtPassword">pwd</TD>
         </TR>
         <TR>
          <TD></TD>
          <TD><INPUT type="submit" value="登
    陆"></TD>
         </TR>
        </TABLE>
      </form>

        2、引用Js文件

    <SCRIPT language="javascript" src="login.js" type="text/javascript"></SCRIPT>
      <script language="javascript">
      window.onload = function()
        {
           login=new Login(testAjax);
          }
      </script>

       login.Js文件
    // 提取控件值
    function getValueById(pObjID){
     var obj=document.getElementById(pObjID);
     try{
      return obj.value;
     }catch(e){
      alert("控件:"+pObjID+" 不存在,或没有value属性");
     }
    }

    function Login(obj)
    {
     this.OBJ = obj;
     this.GetLogin=function()
     {
      var returnValue;
      var username=getValueById('txtUsername');
      var password=getValueById('txtPassword');
      if(!username||!password)
      {
       alert('请输入用户名与密码!');
       return;
      }  
      try
      {
       returnValue=this.OBJ.Login(username,password).value;
      }catch(e)
      {
       alert('登录出错,请稍后再试或与管理员联系');
      }
      switch(returnValue)
      { 
       
       case 1:
        alert('对不起,您输入的用户名或密码不正确或者不是管理员!');
        break;   
       case 0:
        alert('管理员登录成功!');
        window.document.location.href('../Error.aspx');
        break;   
       default:
        alert('登录失败,请稍后再试或与管理员联系'+returnValue);
        break;
      }
     }
    }

    3、.cs文件

    private void Page_Load(object sender, System.EventArgs e)
      {
       Ajax.Utility.RegisterTypeForAjax(typeof(testAjax));
      }

      [Ajax.AjaxMethod()]
      public int Login(string username,string password)
      {   
       // 管理员登陆入口
       Action.Common.CDB cdb = new Action.Common.CDB();
       if("admin"==cdb.ExeScalar("select upower from users where 

    uname='"+username+"' and upwd='"+password+"'"))
        return 0;
       else
        return 1;
      }

        
       

  • 相关阅读:
    设计模式之工厂模式
    东方通 部署项目 报错 内存溢出解决
    java8提取对象集合中的一项属性
    vue 函数节流
    ALINK(三十一):特征工程(十)特征选择(二)卡方选择器 (ChiSqSelectorBatchOp)
    ALINK(三十):特征工程(九)特征选择(一)主成分分析(PcaTrainBatchOp/PcaPredictBatchOp)
    ALINK(二十九):特征工程(八)特征组合与交叉(三)Hash Cross特征 (HashCrossFeatureBatchOp)
    ALINK(二十八):特征工程(七)特征组合与交叉(二)Cross特征预测/训练 (CrossFeaturePredictBatchOp)
    ALINK(二十七):特征工程(六)特征组合与交叉(特征组合也叫特征交叉)(一)
    ALINK(二十六):特征工程(五)特征离散化(五)二值化 (BinarizerBatchOp)
  • 原文地址:https://www.cnblogs.com/skylaugh/p/426029.html
Copyright © 2020-2023  润新知