jQuery 調(diào)用WebService 實例講解
1.首先建一個WebService程序
/// <summary>
/// WebService1 的摘要說明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[ToolboxItem(false)]
// 若要允許使用 ASP.NET AJAX 從腳本中調(diào)用此 Web 服務(wù),請取消對下行的注釋。
[System.Web.Script.Services.ScriptService]
public class WebService1 : System.Web.Services.WebService
{
[WebMethod]
public string HelloWorld()
{
CommonData.Json.ObjectSerialization ser = new CommonData.Json.ObjectSerialization();
Student stu = new Student();
stu.Id = 1;
stu.Name = "hechen";
string json = ser.EntityToJson(stu);
return json;
}
}
[System.Web.Script.Services.ScriptService] 這里得注意,默認情況下這個特性是注釋起來的,如果想用Javascript來調(diào)用WebService 就要取消這個注釋
WebService 的內(nèi)容不必多說,用Jquery調(diào)用WebService 返回肯定是一個xml。而xml是說明文件,而不是具體方法返回的值,所以我們做適當(dāng)?shù)奶幚?。我們這里WebService方法返回的是JSON數(shù)據(jù),以便在前臺解析。下載是實體類序列化JSON的代碼。
2. 實體對象序列化JSON
/**
*
* 2009-5-26
* 賀 臣
*
* 將某個對象轉(zhuǎn)化為Json數(shù)據(jù)格式
* */
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Data;
using System.ServiceModel.Web;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
namespace CommonData.Json
{
public class ObjectSerialization
{
private object _entity;
/// <summary>
/// 被序列化得實體對象
/// </summary>
public object Entity
{
get { return _entity; }
set { _entity = value; }
}
private string _jsonData;
/// <summary>
/// 被轉(zhuǎn)化為json格式數(shù)據(jù)的對象
/// </summary>
public string JsonData
{
get { return _jsonData; }
set { _jsonData = value; }
}
/// <summary>
/// 無參數(shù)構(gòu)造方法
/// </summary>
public ObjectSerialization()
{
}
/// <summary>
/// 有參數(shù)構(gòu)造方法
/// </summary>
/// <param name="entity">要被序列化得實體對象</param>
public ObjectSerialization(object entity)
{
this._entity = entity;
}
/// <summary>
/// 序列化實體對象
/// </summary>
/// <returns></returns>
public string EntityToJson()
{
var serializer = new DataContractJsonSerializer(Entity.GetType());
MemoryStream ms = new MemoryStream();
serializer.WriteObject(ms, Entity);
byte[] myByte = new byte[ms.Length];
ms.Position = 0;
ms.Read(myByte, 0, (int)ms.Length);
string dataString = Encoding.UTF8.GetString(myByte);
return dataString;
}
/// <summary>
/// 序列化實體對象
/// </summary>
/// <param name="entity">要被序列化得實體對象</param>
/// <returns></returns>
public string EntityToJson(object entity)
{
this._entity = entity;
return EntityToJson();
}
/// <summary>
/// 將Json格式數(shù)據(jù)轉(zhuǎn)換為對象
/// </summary>
/// <returns></returns>
public T GetObjectJson<T>()
{
MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(JsonData));
var serializer = new DataContractJsonSerializer(typeof(T));
T t = (T)serializer.ReadObject(ms);
return t;
}
/// <summary>
/// 將Json格式數(shù)據(jù)轉(zhuǎn)換為對象
/// </summary>
/// <param name="jsonData">json數(shù)據(jù)格式</param>
/// <returns></returns>
public T GetObjectJson<T>(string jsonData)
{
this._jsonData = jsonData;
return GetObjectJson<T>();
}
}
}
注意序列化實體必須用可序列化特性修飾,如Serialiable,否則它不能序列化為JSON數(shù)據(jù)字符串
3.前臺程序Jquery調(diào)用
<script src="jquery-1[1].2.3.min.js" type="text/javascript"></script>
<script src="json2.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function() {
$("#btnClick").click(function() {
$.ajax({
url:"http://localhost:10168/WebService1.asmx/HelloWorld",
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
data:{},
dataType:"json",
type:"POST",
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
//alert(x.responseText);
} ,
success:function(data){
var msg=data.d;
var json=JSON2.parse(msg);
alert(json.id);
}
});
});
});
</script>
這里進入了Jquery的核心文件和一個JSON2.js文件
url:"http://localhost:10168/WebService1.asmx/HelloWorld" 這個是調(diào)用WebService方法的路徑,HelloWorld 是WebService 中的方法。
同時還要設(shè)置WebService請求后返回的參數(shù)格式(json),data是用于解釋返回的值。這里值得注意的是data是一個json格式的字符串,而且對象名為d,所以我們用到了后面的var msg=data.d;
如果我們要能夠像JSON那個以 . 操作來訪問鍵值,我們就使用到了 JSON2.js 中的方法將 json字符串轉(zhuǎn)化為json對象,這樣就可以以. 操作來訪問對象了。
如果我們需要調(diào)用帶參數(shù)的WebService ,則我們可以再data 中指定傳遞的參數(shù),參數(shù)名要和WebService中方法參數(shù)名相同。
在這里應(yīng)該說是沒有問題,我在寫這個例子的時候,并不是這么順利,后來查了很多關(guān)于WebService的資料,原來我們要修改WebService中Web.config 的配置,否則我們不能以Url 那種格式訪問WebService。
配置如下:
在System.web 這個節(jié)點中添加如下配置即可
<webServices> <protocols> <add name="HttpGet"/> <add name="HttpPost"/> </protocols> </webServices>
以上就是本文的全部內(nèi)容,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery動態(tài)添加.active 實現(xiàn)導(dǎo)航效果代碼思路詳解
這篇文章主要介紹了jQuery動態(tài)添加.active 實現(xiàn)導(dǎo)航效果代碼思路詳解,需要的朋友可以參考下2017-08-08
讓新消息在網(wǎng)頁標(biāo)題閃爍提示的jQuery代碼
可能有一些站長會注意到這樣的效果,到收到的新消息會閃爍標(biāo)題提示,那么新消息在網(wǎng)頁標(biāo)題閃爍顯示的效果如何實現(xiàn),下面有個不錯的示例,感興趣的朋友可以參考下2013-11-11
Jquery動態(tài)更改一張位圖的src與Attr的使用
用Jquery想動態(tài)更改一張位圖的src發(fā)現(xiàn)css不好用而attr貌似是能操作所有屬性,包括Jquery未封裝的屬性,具體實現(xiàn)如下,感興趣的朋友可以參考下2013-07-07
jquery ajax jsonp跨域調(diào)用實例代碼
今天研究了AJAX使用JSONP進行跨域調(diào)用的方法,發(fā)現(xiàn)使用GET方式和POST方式都可以進行跨域調(diào)用,這里簡單分享下,方便需要的朋友2013-12-12
jquery插件canvaspercent.js實現(xiàn)百分比圓餅效果
這篇文章主要為大家詳細介紹了jquery插件canvaspercent.js實現(xiàn)百分比圓餅效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

