唐朝程序员

我来自唐朝

[转]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;
  }

    
我这里写的是简单Ajax的实现,你可以密码加密,还可以加验证码之类,如此一来,就达到防止和克截获的可能

posted on 2006-10-09 16:15  唐朝程序员  阅读(373)  评论(0编辑  收藏  举报

导航