jQuery ajax調(diào)用webservice注意事項(xiàng)
jquery ajax調(diào)用webservice(C#)要注意的幾個(gè)事項(xiàng):
1、web.config里需要配置2個(gè)地方
<httpHandlers> <remove verb="*" path="*.asmx"/> <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/> </httpHandlers>
在<system.web></system.web>之間加入
<webServices>
<protocols>
<add name="HttpPost" />
<add name="HttpGet" />
</protocols>
</webServices>
2.正確地編寫webserivce的代碼
/// <summary>
/// UserValidate 的摘要說明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
// 若要允許使用 ASP.NET AJAX 從腳本中調(diào)用此 Web 服務(wù),請(qǐng)取消對(duì)下行的注釋。
[System.Web.Script.Services.ScriptService]
public class UserValidate : System.Web.Services.WebService
{
DFHon.Content.Common.rootPublic rp = new DFHon.Content.Common.rootPublic();
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string ValidateUserLogState()
{
string result = "";
HttpCookie cookie = HttpContext.Current.Request.Cookies["DHFonMenberInfo"];
if (cookie != null)
{
string username = System.Web.HttpUtility.UrlDecode(cookie["MenberName"]);
int ipoint = 0;
int gpoint = 0;
try
{
DataTable dt = UserBll.ExecuteUserAllInfo(username);
if (dt.Rows.Count > 0)
{
ipoint = int.Parse(dt.Rows[0]["iPoint"].ToString());
gpoint = int.Parse(dt.Rows[0]["gPoint"].ToString());
}
}
catch
{ }
result = "{'user':{'id':'" + cookie["UserId"] + "','name':'" + username + "','message':'" + rp.getUserMsg(DFHon.Global.CurrentCookie.UserName) + "','ipoint':'" + ipoint.ToString() + "','gpoint':'" + gpoint.ToString() + "'}}";
}
else
{
result = "{'user':{'id':'0','name':'','message':'0','ipoint':'0','gpoint':'0'}}";
}
return result;
}
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string UserLogin(string userName, string userPwd)
{
string returnVal = "";
try
{
GlobalUserInfo info;
DFHon.Content.UserLogin _UserLogin = new DFHon.Content.UserLogin();
EnumLoginState state = _UserLogin.PersonLogin(HttpUtility.UrlDecode(userName), userPwd, out info);
if (state == EnumLoginState.Succeed)
{
DFHon.Global.CurrentCookie.Set(info);
DFHon.API.PDO.DiscuzNT.PassportLogin.UserLogin(Server.UrlDecode(userName), userPwd, -1);
int ipoint = 0;
int gpoint = 0;
DataTable dt = UserBll.ExecuteUserAllInfo(userName);
if (dt.Rows.Count > 0)
{
ipoint = int.Parse(dt.Rows[0]["iPoint"].ToString());
gpoint = int.Parse(dt.Rows[0]["gPoint"].ToString());
}
returnVal = "{'user':{'id':'" + info.UserId.ToString() + "','name':'" + info.UserName + "','message':'" + rp.getUserMsg(userName) + "','ipoint':'" + ipoint.ToString() + "','gpoint':'" + gpoint.ToString() + "'}}";
}
else
{
int ids = 0;//狀態(tài):-2用戶被鎖定 -1用戶名密碼錯(cuò)誤
switch (state)
{
case EnumLoginState.Err_Locked:
ids = -2;
break;
case EnumLoginState.Err_UserNameOrPwdError:
ids = -1;
break;
default:
break;
}
returnVal = "{'user':{'id':'" + ids + "','name':'','message':'0','ipoint':'0','gpoint':'0'}}";
}
}
catch
{
returnVal = "{'user':{'id':'0','name':'','message':'0','ipoint':'0','gpoint':'0'}}";
}
return returnVal;
}
[WebMethod]
public string UserLogout()
{
if (HttpContext.Current.Request.Cookies["DHFonMenberInfo"] != null)
{
HttpCookie cookie = new HttpCookie("DHFonMenberInfo");
cookie.Expires = System.DateTime.Now.AddDays(-1);
cookie.Domain = DFHon.Config.BaseConfig.getV("weblogin");
HttpContext.Current.Response.AppendCookie(cookie);
}
return "1";
}
DFHon.Content.user UserBll = new DFHon.Content.user();
[WebMethod]
public string ValidateUserEmail(string email)
{
string result = "0";//返回的結(jié)果 -2郵箱為空 -1郵箱格式不正確 0郵箱存在 1填寫正確
if (string.IsNullOrEmpty(email))
{
result = "-2";//郵箱為空
}
else if (!IsValidEmail(email))
{
result = "-1";//郵箱格式不正確
}
else if (UserBll.sel_useremail(email) > 0)
{
result = "0";//郵箱存在
}
else
{
result = "1";//可以注冊(cè)
}
return result;
}
[WebMethod]
public string ValidateUserName(string username)
{
string result = "0";//返回值:-1用戶名長(zhǎng)度為2-16;0用戶名存在;1可以注冊(cè)
if (username == "" || username == null || username.Length < 2 || username.Length > 16)
{
result = "-1";
}
else if (UserBll.sel_username(username) != 0)
{
result = "0";
}
else
{
result = "1";
}
return result;
}
public bool IsValidEmail(string strIn)
{ // Return true if strIn is in valid e-mail format.
return System.Text.RegularExpressions.Regex.IsMatch(strIn, @"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$");
}
}
WebService
<script>
$(function() {
$("#userloging").show();
//登錄框處理開始
//加載登錄狀態(tài)
$.ajax({
type: "POST", //訪問WebService使用Post方式請(qǐng)求
contentType: "application/json;charset=utf-8", //WebService 會(huì)返回Json類型
url: "/API/Service/UserValidate.asmx/ValidateUserLogState", //調(diào)用WebService
data: "{}", //Email參數(shù)
dataType: 'json',
beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },
error: function(x, e) { },
success: function(response) { //回調(diào)函數(shù),result,返回值
$("#userloging").hide();
var json = eval('(' + response.d + ')');
var userid = json.user.id;
if (userid > 0) {
$("#spanusername").html(json.user.name);
$("#spanmessagenum").html(json.user.message);
$("#userloginsucced").show();
$("#userloginbox").hide();
}
}
});
//登錄
$("#userlogbutton").click(function() {
var username = $("#username").val();
var userpwd = $("#userpassword").val();
if (username != "" && userpwd != "") {
$("#userloging").show();
$.ajax({
type: "POST", //訪問WebService使用Post方式請(qǐng)求
contentType: "application/json;charset=utf-8", //WebService 會(huì)返回Json類型
url: "/API/Service/UserValidate.asmx/UserLogin", //調(diào)用WebService
data: "{userName:'" + username + "',userPwd:'" + userpwd + "'}", //Email參數(shù)
dataType: 'json',
beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },
error: function(x, e) {
},
success: function(result) { //回調(diào)函數(shù),result,返回值
$("#userloging").hide();
var json = eval('(' + result.d + ')');
var userid = json.user.id;
if (userid > 0) {
$("#spanusername").html(json.user.name);
$("#spanmessagenum").html(json.user.message);
$("#userloginsucced").show();
$("#userloginbox").hide();
}
else {
switch (userid) {
case -2:
alert("用戶被鎖定!請(qǐng)30分鐘后再登錄!");
$("#username").focus();
break;
case -1:
alert("用戶名或密碼錯(cuò)誤!請(qǐng)核對(duì)您的用戶名和密碼!");
$("#userpassword").focus();
break;
default:
alert("登錄失?。≌?qǐng)核對(duì)您的用戶名和密碼之后重試!");
$("#userpassword").focus();
break;
}
}
}
});
}
else if (username == "") {
alert("用戶名不能為空!");
$("#username").focus();
}
else if (userpwd == "") {
alert("密碼不能為空!");
$("#userpassword").focus();
}
});
//退出
$("#logout").click(function() {
$("#userloging").show();
$.ajax({
type: "POST", //訪問WebService使用Post方式請(qǐng)求
contentType: "application/json;utf-8", //WebService 會(huì)返回Json類型
url: "/API/Service/UserValidate.asmx/UserLogout", //調(diào)用WebService
data: "{}", //Email參數(shù)
dataType: 'json',
beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },
success: function(result) { //回調(diào)函數(shù),result,返回值
$("#userloging").hide();
if (result.d > 0) {
$("#userloginsucced").hide();
$("#userloginbox").show();
}
}
});
}); //登錄框處理結(jié)束
});
</script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jquery中ajax調(diào)用json數(shù)據(jù)的使用說明
- JQuery與Ajax調(diào)用新浪API獲取短網(wǎng)址的代碼
- jQuery Ajax調(diào)用WCF服務(wù)詳細(xì)教程
- Jquery + Ajax調(diào)用webService實(shí)例代碼(asp.net)
- jQuery ajax調(diào)用后臺(tái)aspx后臺(tái)文件的兩種常見方法(不是ashx)
- jQuery ajax+PHP實(shí)現(xiàn)的級(jí)聯(lián)下拉列表框功能示例
- JQuery打造PHP的AJAX表單提交實(shí)例
- php+ajax+jquery實(shí)現(xiàn)點(diǎn)擊加載更多內(nèi)容
- jquery與php結(jié)合實(shí)現(xiàn)AJAX長(zhǎng)輪詢(LongPoll)
- jQuery實(shí)現(xiàn)簡(jiǎn)單的Ajax調(diào)用功能示例
相關(guān)文章
jquery.alert 彈出式復(fù)選框?qū)崿F(xiàn)代碼
jquery alert 彈出式 復(fù)選框,需要的朋友可以參考下,代碼有點(diǎn)亂。2009-06-06
基于jquery實(shí)現(xiàn)表格無(wú)刷新分頁(yè)
這篇文章主要介紹了基于jquery實(shí)現(xiàn)表格無(wú)刷新分頁(yè),功能實(shí)現(xiàn)了前端排序功能,增加了前端搜索功能,感興趣的小伙伴們可以參考一下2016-01-01
基于jquery實(shí)現(xiàn)的可編輯下拉框?qū)崿F(xiàn)代碼
昨天看到QQ登錄的時(shí)候,可以選擇以前登錄過的賬戶,這個(gè)東西也可以在網(wǎng)站登錄的時(shí)候用到,所以我就想做一個(gè)這樣的插件;在網(wǎng)上查了很多,沒有找到合適自己的,所以決定自動(dòng)制作一個(gè)2014-08-08
jQuery中select與datalist制作下拉菜單時(shí)的區(qū)別淺析
一般我們通常使用select制作下拉菜單,但是H5之后,datalist也可以充當(dāng)select的角色,而且兩者還有一點(diǎn)小的不同。具體區(qū)別詳解小編通過本文給簡(jiǎn)單介紹下2016-12-12
jQuery實(shí)現(xiàn)的個(gè)性化返回底部與返回頂部特效代碼
這篇文章主要介紹了jQuery實(shí)現(xiàn)的個(gè)性化返回底部與返回頂部特效代碼,涉及jQuery結(jié)合動(dòng)畫函數(shù)響應(yīng)鼠標(biāo)事件動(dòng)態(tài)改變頁(yè)面元素樣式的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10
jQuery模擬完美實(shí)現(xiàn)經(jīng)典FLASH導(dǎo)航動(dòng)畫效果【附demo源碼下載】
這篇文章主要介紹了jQuery模擬完美實(shí)現(xiàn)經(jīng)典FLASH導(dǎo)航動(dòng)畫效果,通過jQuery響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素樣式實(shí)現(xiàn)flash切換的效果,非常經(jīng)典實(shí)用,文末還提供了demo源碼供讀者下載學(xué)習(xí)或使用,需要的朋友可以參考下2016-11-11

