【转】JQuery以JSON方式提交数据到服务端

JQuery将Ajax数据请求进行了封装,从而使得该操做实现起来容易许多。以往咱们要写不少的代码来实现该功能,如今只须要调用$.ajax()方法,并指明请求的方式、地址、数据类型,以及回调方法等。下面的代码演示了如何将客户端表单数据封装成JSON格式,而后经过JQuery的Ajax请求将数据发送到服务端,并最终将数据存储到数据库中。服务端定义为一个.ashx文件,事实上你能够将服务端定义为任何能接收并处理客户端数据的类型,如Web Service,ASP.NET Page,Handler等。html

  首先,在客户端,经过JavaScript脚本将页面表单数据封装成JSON格式。GetJsonData()函数完成了这一功能。而后咱们经过$.ajax()方法将数据发送到服务端的RequestData.ashx。其中用到了JSON.stringify()方法,它能够将客户端发送的数据转换成JSON对象,详细的内容能够看这里https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringifyjava

$("#btnSend").click(function() {
$("#request-process-patent").html("正在提交数据,请勿关闭当前窗口...");
$.ajax({
type: "POST",
url: "RequestData.ashx",
contentType: "application/json; charset=utf-8",
data: JSON.stringify(GetJsonData()),
dataType: "json",
success: function (message) {
if (message > 0) {
alert("请求已提交!咱们会尽快与您取得联系");
}
},
error: function (message) {
$("#request-process-patent").html("提交数据失败!");
}
});
});ajax

function GetJsonData() {
var json = {
"classid": 2,
"name": $("#tb_name").val(),
"zlclass": "测试类型1,测试类型2,测试类型3",
"pname": $("#tb_contact_people").val(),
"tel": $("#tb_contact_phone").val()
};
return json;
}数据库

再来看看服务端的代码,RequestData.ashx.json

[Serializable]
public class RequestDataJSON
{
public int classid { get; set; }
public string name { get; set; }
public string zlclass { get; set; }
public string pname { get; set; }
public string tel { get; set; }
}app

/// <summary>
/// Summary description for RequestData
/// </summary>
public class RequestData : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{函数

 

context.Response.ContentType = "application/json";
var data = context.Request;
var sr = new StreamReader(data.InputStream);
var stream = sr.ReadToEnd();
var javaScriptSerializer = new JavaScriptSerializer();
//将提交的数据封装到实体对象StudentEntity里
var PostedData = javaScriptSerializer.Deserialize<StudentEntity>(stream);测试


int sid= PostedData.sid;
string name = PostedData.sname;url

context.Response.ContentType = "text/plain";htm

 

}

public bool IsReusable { get { return false; } }}

相关文章
相关标签/搜索