为了账号安全,请及时绑定邮箱和手机立即绑定

用jquery验证用户名是否有效或重复荐

标签:
JQuery

最近在做毕业设计的时候,新增管理员用到jquery的ajax验证用户名是否存在,本人初次使用jquery的ajax,发了挺长时间的去网上找相关东西,现在和大家共享我的做法,多多指教。


在代码中使用jquery-1.3.2的vsdoc版本:

<script class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="/js/jquery/jquery-1.3.2-vsdoc.js" type="text/javascript"></script>      <script type="text/javascript" language="javascript">          $(function() {              $("#txtUserName").focus(function() {                  $(this).addClass("focus");              }).blur(function(){                  $.ajax({                      type: "GET",                      url: "valideUserName_ajax.aspx",                      dataType: "html",                      data: "userName=" + $("#txtUserName").val(),                      beforeSend: function(XMLHttpRequest) {                          $("#showResult").text("正在查询。。。");                      },                      success: function(msg) {                          $("#showResult").html(msg);                          $("#showResult").css("color", "red");                      },                      complete: function(XMLHttpRequest, textStatus) {                          //隐藏正在查询图片                      },                      error: function() {                          //错误处理                      }                  });              });          });      </script>

其中上面引用的js代码中的就是id为txtUserName的textbox先聚焦,失去焦点时,验证使用ajax判断用户名是否存在。

<asp:TextBox ID="txtUserName" size="25" Height="20px" runat="server"></asp:TextBox>

ajax获取的页面:valideUserName_ajax.aspx
前台页面的代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server">     <title>验证用户名是否存在</title> </head> <body>     <form id="form1" runat="server">     <div>           </div>     </form> </body> </html>

.cs的代码:本人使用三层架构,如用其他方法,请相应的转换:

public partial class valideUserName_ajax : System.Web.UI.Page  {      protected void Page_Load(object sender, EventArgs e)      {          if (!string.IsNullOrEmpty(Request.QueryString["userName"]))          {              if(new zwx.BLL.adminUsers().ExistsUserName(Request.QueryString["userName"].ToString()))              {                  Response.Write("<span class='error'>&nbsp;</span>" + "用户名已经存在,请重新输入。");              }              else             {                  Response.Write("<span class='success'>&nbsp;</span>" + "恭喜该用户可以使用,请继续。");              }          }          else         {              Response.Write("<span class='error'>&nbsp;</span>" + "用户名不能为空!");          }      }  }

当完成上面的步骤之后,可以实现判断用户名是否重复,但是新的问题出现了?

“/”应用程序中的服务器错误。  --------------------------------------------------------------------------------   此页的状态信息无效,可能已损坏。   说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。    异常详细信息: System.Web.HttpException: 此页的状态信息无效,可能已损坏。   源错误:     [没有相关的源行]      源文件: c:\Windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root\bab5ae03\ea433214\App_Web_asfn-zfc.1.cs    行: 0    堆栈跟踪:     [FormatException: Base-64 字符串中的无效字符。]     System.Convert.FromBase64String(String s) +0     System.Web.UI.ObjectStateFormatter.Deserialize(String inputString) +77     System.Web.UI.ObjectStateFormatter.System.Web.UI.IStateFormatter.Deserialize(String serializedState) +4     System.Web.UI.Util.DeserializeWithAssert(IStateFormatter formatter, String serializedState) +37     System.Web.UI.HiddenFieldPageStatePersister.Load() +113   [ViewStateException: 无效的视图状态。      Client IP: 127.0.0.1      Port:       User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0;  Embedded Web Browser from: http://bsalsa.com/; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E; Tablet PC 2.0; 360SE)      ViewState: /wEPDwUJNzMxNjYzNjkwZBgBBR5fX0NvbnRyb2xzUmVxdWlyZVBvc3RCYWNrS2V5X18WHQULY2JsTWFuYWdlJDAFC2NibE1hbmFnZSQwBQxjYmxBcnRpY2xlJDAFDGNibEFydGljbGUkMQUMY2JsQXJ0aWNsZSQyBQxjYmxBcnRpY2xlJDMFDGNibEFydGljbGUkMwUQY2JsQXJ0aWNsZUtpbmQkMAUQY2JsQXJ0aWNsZUtpbmQkMQUQY2JsQXJ0aWNsZUtpbmQkMgUQY2JsQXJ0aWNsZUtpbmQkMwUQY2JsQXJ0aWNsZUtpbmQkMwUIY2JsUGljJDAFCGNibFBpYyQxBQhjYmxQaWMkMgUIY2JsUGljJDMFCGNibFBpYyQzBQxjYmxQaWNLaW5kJDAFDGNibFBpY0tpbmQkMQUMY2JsUGljS2luZCQyBQxjYmxQaWNLaW5kJDMFDGNibFBpY0tpbmQkMwUKY2JsVmlkZW8kMAUKY2JsVmlkZW8kMQUKY2JsVmlkZW8kMgUKY2JsVmlkZW8kMwUKY2JsVmlkZW8kMwUMaW1nQnRuU3VibWl0BQxpbWdCdG5DYW5jbGUzgcuA+4V7gkvpf3QO5Zd66FFRMQ==,/wEPDwUJNzgzNDMwNTMzZGT4DI9jhwcGjbIzQJAyCccg/Xoh1g==      Referer: http://localhost:53227/site_ma...]   [HttpException (0x80004005): 此页的状态信息无效,可能已损坏。]     System.Web.UI.ViewStateException.ThrowError(Exception inner, String persistedState, String errorPageMessage, Boolean macValidationError) +106     System.Web.UI.ViewStateException.ThrowViewStateError(Exception inner, String persistedState) +14     System.Web.UI.HiddenFieldPageStatePersister.Load() +217     System.Web.UI.Page.LoadPageStateFromPersistenceMedium() +105     System.Web.UI.Page.LoadAllState() +43     System.Web.UI.Page.Proce***equestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +6785     System.Web.UI.Page.Proce***equest(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +242     System.Web.UI.Page.Proce***equest() +80     System.Web.UI.Page.Proce***equestWithNoAssert(HttpContext context) +21     System.Web.UI.Page.Proce***equest(HttpContext context) +49     ASP.site_mag_manage_editmanage_aspx.Proce***equest(HttpContext context) in c:\Windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root\bab5ae03\ea433214\App_Web_asfn-zfc.1.cs:0     System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +181     System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +75        --------------------------------------------------------------------------------  版本信息: Microsoft .NET Framework 版本:2.0.50727.5448; ASP.NET 版本:2.0.50727.5456

后来又发了很多时间去网上找解决方案。最后找到一个比较满意的。且决解问题的,方案如下:

 通过上网查询,给出以下解决方案:            

在该工程中的web.config中添加如下代码:

<pages enableEventValidation="False" viewStateEncryptionMode="Never" />

来源: http://www.cnblogs.com/ufo0303/archive/2008/04/10/1146026.html

但是,按照网上给出的方法并没有解决问题.

于是, 参见: http://blog.csdn.net/Yamzef/archive/2007/03/26/1541160.aspx .其中说:

如果你在回调前不加这两句的话 __theFormPostData就会在原来的基础上再添加现有的网页状态post数据,这样可以说现在回调时你已包含了两份post数据,但回调时,服务器方仍然把它当作一份看待,结果服务器分析不出post数据,只给你返回了一个网页状态已损坏的消息 

分析,可能是B页面,包含form表单才造成问题出现.于是删除B.aspx中的Form标签.问题解决.


于是我就将我ajax引用页面的form删掉。代码变成如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server">     <title>验证用户名是否存在</title> </head> <body>  </body> </html>

对比发现了什么不一样了吗?少了form以及下面的div。

这时你再尝试一下,发现就这样实现了添加新的管理员吧。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消