用jquery驗證使用者名稱是否有效或重複
最近在做畢業設計的時候,新增管理員用到jquery的ajax驗證使用者名稱是否存在,本人初次使用jquery的ajax,發了挺長時間的去網上找相關東西,現在和大家共享我的做法,多多指教。
實現的效果如下圖:
實現的效果
在程式碼中使用jquery-1.3.2的vsdoc版本:
<script src="/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" "
<html xmlns=" >
<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'> </span>" + "使用者名稱已經存在,請重新輸入。");
}
else
{
Response.Write("<span class='success'> </span>" + "恭喜該使用者可以使用,請繼續。");
}
}
else
{
Response.Write("<span class='error'> </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: 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: ]
[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" "
<html xmlns=" >
<head runat="server">
<title>驗證使用者名稱是否存在</title>
</head>
<body>
</body>
</html>
對比發現了什麼不一樣了嗎?少了form以及下面的div。
這時你再嘗試一下,發現就這樣實現了新增新的管理員吧。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69976881/viewspace-2722810/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 利用JS驗證使用者名稱是否合法JS
- Java+Ajax實現使用者名稱重複檢驗Java
- 17.django新增檢查使用者名稱和手機號數量介面+vue檢查使用者名稱,手機號是否重複DjangoVue
- JQuery表單驗證(包括:使用者名稱,手機號,密碼,確認密碼,驗證碼60s)jQuery密碼
- 未能找到型別或名稱空間名稱“MySql”(是否缺少 using 指令或程式集引用?)型別MySql
- 檢查使用者名稱是否使用介面
- Vue檢查使用者名稱是否使用Vue
- 關於登入(使用者名稱,密碼,驗證碼)密碼
- 使用Ajax技術檢測使用者名稱是否被佔用
- jQuery Validate驗證確認密碼是否相同jQuery密碼
- 重複的縣級行政區劃名稱
- Git中git pull/push 老是重複輸入使用者名稱密碼Git密碼
- 用Servlet進行使用者名稱和密碼校驗Servlet密碼
- 驗證碼機制之驗證碼重複使用
- 根據教程中,輸錯密碼或使用者名稱後,卻不能返回‘使用者名稱或密碼錯誤’密碼
- JavaWeb學習篇10_JQuery初級、高階、Ajax、json簡單學習、校驗使用者名稱是否存在案例、JavaWebjQueryJSON
- Spring竟然可以建立“重複”名稱的bean?—一次專案中存在多個bean名稱重複問題的排查SpringBean
- jQuery Validate表單驗證(使用者註冊簡單應用)jQuery
- html+JS+php實現簡單的註冊使用者名稱驗證HTMLJSPHP
- 使用代理通過使用者名稱和密碼驗證優缺點介紹密碼
- 驗證是否成功
- Spring Security小教程 Vol 4. 使用使用者名稱和密碼驗證身份-UsernamePasswordAuthenticationFilterSpring密碼Filter
- jQuery記住使用者名稱和密碼效果程式碼例項jQuery密碼
- jQuery 判斷使用者是否存在jQuery
- git配置使用者名稱和郵箱 git設定使用者名稱郵箱有什麼用Git
- Kafka怎麼配置SASL使用者名稱密碼認證Kafka密碼
- 校驗使用者名稱合法性正規表示式
- jQuery如何用正規表示式驗證手機號、身份證號、中文名稱jQuery
- 如何將Windows作業系統使用者名稱的中文名稱修改為英文名稱【親測有效】Windows作業系統
- 04 . Go+Vue開發一個線上外賣應用(使用者名稱密碼和圖形驗證碼)GoVue密碼
- dataset 判斷整列是否有重複,找出重複資料
- 透過使用者名稱密碼認證保障 MQTT 接入安全密碼MQQT
- 驗證資料是否存在
- iOS證書籤名機制&重簽名&防止重簽名iOS
- github修改使用者名稱Github
- python 使用者註冊使用者名稱Python
- WordPress使用者名稱能改幾次?附更改使用者名稱4種方法
- jQuery Validate checkbox和radio驗證jQuery