JQuery以JSON方式提交数据到服务端
来源:互联网 发布:mac开机密码 编辑:程序博客网 时间:2024/05/19 06:37
JQuery将Ajax数据请求进行了封装,从而使得该操作实现起来容易许多。以往我们要写很多的代码来实现该功能,现在只需要调用$.ajax()方法,并指明请求的方式、地址、数据类型,以及回调方法等。下面的代码演示了如何将客户端表单数据封装成JSON格式,然后通过JQuery的Ajax请求将数据发送到服务端,并最终将数据存储到数据库中。服务端定义为一个.ashx文件,事实上你可以将服务端定义为任何能接收并处理客户端数据的类型,如Web Service,ASP.NET Page,Handler等。
首先,在客户端,通过JavaScript脚本将页面表单数据封装成JSON格式。GetJsonData()函数完成了这一功能。然后我们通过$.ajax()方法将数据发送到服务端的RequestData.ashx。其中用到了JSON.stringify()方法,它可以将客户端发送的JSON数据对象进行序列化操作,详细的内容可以看这里https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify
$("#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("提交数据失败!"); } });});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.
[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; }}/// <summary>/// Summary description for RequestData/// </summary>public class RequestData : IHttpHandler{ public void ProcessRequest(HttpContext context) { int num = 0; context.Response.ContentType = "application/json"; var data = context.Request; var sr = new StreamReader(data.InputStream); var stream = sr.ReadToEnd(); var javaScriptSerializer = new JavaScriptSerializer(); var PostedData = javaScriptSerializer.Deserialize<RequestDataJSON>(stream); tb_query obj = new tb_query(); obj.classid = PostedData.classid; obj.name = PostedData.name; obj.zlclass = PostedData.zlclass; obj.pname = PostedData.pname; obj.tel = PostedData.tel; obj.ip = context.Request.UserHostAddress.ToString(); obj.posttime = DateTime.Now.ToString(); try { using (var ctx = new dbEntities()) { ctx.tb_query.AddObject(obj); num = ctx.SaveChanges(); } } catch (Exception msg) { context.Response.Write(msg.Message); } context.Response.ContentType = "text/plain"; context.Response.Write(num); } public bool IsReusable { get { return false; } }}
定义一个带有Serializable特征属性的类RequestDataJSON用来将客户端数据进行反序列化,从而获取到数据并存入数据库。上述代码中使用了EntityFramework,从而使得数据库的交互代码变得很简洁。返回结果有两种,对应ajax中的回调函数success()和error()。在success()回调函数中,如果返回结果的值大于0,则表示通过EntityFramework添加到数据库中的记录数;在error()回调函数中,返回结果则显示了失败的具体信息。
RequestData类继承了IHttpHandler接口,表明它是以同步的方式处理客户端请求。当然,你也可以将其改为继承IHttpAsyncHandler接口来处理异步请求,代码接口大同小异。
点击打开链接
- JQuery以JSON方式提交数据到服务端
- JQuery以JSON方式提交数据到服务端
- JQuery以JSON方式提交数据到服务端
- JQuery以JSON方式提交数据到服务端
- jquery提交json数据到mvc4服务端
- AJAX如何以POST的方式提交JSON数据到Form
- 基于JQuery的Form插件---提交表单数据到服务端
- 以Post方式提交并解析json数据
- android以application/json流的方式提交数据
- android 以httpclient方式把数据提交到服务器
- Java 通过HttpURLConnection Post方式提交json,并从服务端返回json数据
- Java 通过HttpClient Post方式提交json,并从服务端返回json数据
- Java 通过HttpURLConnection Post方式提交json,并从服务端返回json数据
- Java 通过HttpURLConnection Post方式提交json,并从服务端返回json数据
- 客户端封装数据为json格式的数据提交到服务端的方法
- Jquery表单提交JSON数据
- jQuery post json数据 服务端异常
- android发送json数据到服务端
- 基本包装类型和自定义对象
- 5_1_1_Qt字符串类QString的基本使用
- jvm排查问题常用命令脚本
- 程序员的青春饭现象真实存在吗?
- leetcode_88. Merge Sorted Array ? 待解决
- JQuery以JSON方式提交数据到服务端
- 最小生成树+dfs
- 学会DOM操作
- Java开发岗位面试题归类汇总(一)
- 如何高速下载百度云资源
- 《java与模式》-12 合成模式
- POJ 3449 Geometric Shapes <几何(简单相交判断)>
- 二、Android安全机制之系统防线
- hadopp 环境搭建