C#Json数据交互
问题:写项目时,难免会遇到前台和后台要进行数据交换,往前台传一个对象或一个对象集,往后台传一个对象,一个对象集。怎么传,你当然不能直接去传递一个对象或对象集,我们可以利用JSON数据相互之间传值。
Json在跨域之间传数据也非常方法,这是它的优点。
你需要知道:传递数据我们用JSON,JSON,JSON,前台传递JSON数据格式到后台,后台需要反序列化。后台传前台,需要序列化后传。
简单了解 JSon数据。
Json语法:
- 对象表示为键值对
- 数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
JSON 键/值对
<script>
var obj = { a: 'Hello', b: 'World' }; //这是一个对象,注意键名也是可以使用引号包裹的
var json = '{"a": "Hello", "b": "World"}'; //这是一个 JSON 字符串,本质是一个字符串
console.log(obj);
console.log(obj.a);//JS对象可以直接用 console.log(json); //就是一个字符串
console.log(json.a); //JSON格式不好直接用,需要转型
</script>

<script>
// 要实现从对象转换为 JSON 字符串,使用 JSON.stringify() 方法:
//序列化
var json = JSON.stringify({ a: 'Hello', b: 'World' }); //结果是 '{"a": "Hello", "b": "World"}'
console.log(json);
// 要实现从 JSON 转换为对象,使用 JSON.parse() 方法:
//反序列化
var obj = JSON.parse('{"a": "Hello", "b": "World"}'); //结果是 {a: 'Hello', b: 'World'}
console.log(obj);
</script>

<script>
//表示对象
// JSON最常用的格式是对象的 键值对。例如下面这样:
var dd = { "firstName": "Brett", "lastName": "McLaughlin" };
console.log(dd.firstName);
// 表示数组
//和普通的 JS 数组一样,JSON 表示数组的方式也是使用方括号 []
var ff = {
"people": [{
"firstName": "Brett",
"lastName": "McLaughlin"
},
{
"firstName": "Jason",
"lastName": "Hunter"
}
]
};
console.log(ff.people[].firstName);
</script>

配合Aajx。
一条数据:
后台返回JSon数据,前台用
①字符串
<script>
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "",
dataType: "json", //既然用到json,你就规定数据类型为json格式的
async: true,
success: function (data) {
console.log(data);
console.log(data.Name);
}
})
</script>
public void ProcessRequest(HttpContext context) //一般处理程序
{
context.Response.ContentType = "text/plain";
//返回JSon格式数据
string aa = "{\"Name\":\"李某\",\"Age\":\"18\"}"; //json格式必须为这个
context.Response.Write(aa); //这里返回JSon数据,前台接受变成了Object,如果前台是string类型就转成对象。
}

如果我们的JSON字符串很复咋,这样写字符串不太好。
②自带命名空间序列化

context.Response.ContentType = "text/plain";
//可以序列化和反序列化
JavaScriptSerializer json = new JavaScriptSerializer();
FunctionDemo.Model.Users usModel = new FunctionDemo.BLL.Users().GetModel();
context.Response.Write(json.Serialize(usModel));
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "ob="+JSON.stringify(ob)+"&js="+js,
dataType: "json",
async: true,
success: function (data) {
console.log(typeof (data));
console.log(data);
alert(data.LoginName);
},
error: function () {
alert(" 错了");
}
})

③借助我们的
这个dll ———> 下载地址
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
////返回JSon格式数据
// string aa = "{\"Name\":\"李某\",\"Age\":\"18\"}"; //json格式必须为这个
//context.Response.Write(aa); //这里返回JSon数据,前台接受变成了Object
//可以把一张表的字段和值这样写
JsonData jd = new JsonData(); JsonData.doc介绍
jd["Name"] = "李某";
jd["Age"] = ;
context.Response.Write(jd.ToJson()); //这个跟上面的字符串JSon效果是一样的 可以简化我们的JSon字符串
}
可以返回嵌套的
//返回JSon格式数据
string aa = "{\"Name\":\"李某\",\"Age\":\"18\",\"Love\":[{\"one\":\"运动\",\"two\":\"哦哦\"},{\"one\":\"看电影\"}]}"; //json格式必须为这个
context.Response.Write(aa); //这里返回JSon数据,前台接受变成了Object
<script>
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "",
dataType: "json",
async: true,
success: function (data) {
console.log(data);
console.log(data.Name);
console.log(data.Love[].one);
}
})
</script>

发现问题:
不管是我们手写Json字符串,还是利用JsonData转成JSON格式,你会发现都需要你去构造,如果你需要得到一张表,并且列很多,你要写到什么。并且有个很严重的缺点,就是获取多条数据的时候改怎么处理,很麻烦。以上的只能使用与小量数据,还好我们知道一个dll可以很好的解决这个问题。
④这个dll之前也用过,就是 Newtonsoft.Json 下载地址:点击
我们的来看看列子。
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
// DataSet ds = new FunctionDemo.BLL.Users().GetList("");
FunctionDemo.Model.Users usModel = new FunctionDemo.BLL.Users().GetModel();
// JsonConvert.SerializeObject 这个静态方法 翻译就是序列化对象
context.Response.Write(JsonConvert.SerializeObject(usModel)); //不能直接返回一个对象,或一个数据集
}
<script>
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "",
dataType: "json",
async: true,
success: function (data) {
console.log(typeof(data));
console.log(data);
},
error: function () {
alert(" 错了");
}
})
</script>

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
DataSet ds = new FunctionDemo.BLL.Users().GetList("");
FunctionDemo.Model.Users usModel = new FunctionDemo.BLL.Users().GetModel();
// JsonConvert.SerializeObject 这个静态方法 翻译就是序列化对象
//可以自己打造一个对象,把需要的数据填写进去 这个位子很灵活需要根据你想要的进行处理
//也可以打造一张表 就可以添加很多数据了
var dd= new { Name = usModel.LoginName, Age = , Sex = "男" }; context.Response.Write(JsonConvert.SerializeObject(dd));
}
多条数据
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
DataSet ds = new FunctionDemo.BLL.Users().GetList("");
FunctionDemo.Model.Users usModel = new FunctionDemo.BLL.Users().GetModel();
// JsonConvert.SerializeObject 这个静态方法 翻译就是序列化对象 context.Response.Write(JsonConvert.SerializeObject(ds.Tables[]));
}
<script>
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "",
dataType: "json",
async: true,
success: function (data) {
console.log(typeof(data));
console.log(data);
console.log(`姓名:${data[].LoginName}`);
},
error: function () {
alert(" 错了");
}
})
</script>

总结:在后台获取数据返回时需要序列化成JSON格式的数据,在前台接收时可用先看下数据类型,如果是JSON数据格式就转下型,无非就是Eval(data)和JSon.Pase(data)。
在后台我们返回JSON字符串,在前台我们需要变成Object.
前台返回JSON数据后台接收
这个前台都是一样的,下面主要看看后台怎么反序列化数据
<script>
var ob = { "LoginName": "李某", "PassWord": "" }; //对象 这里的属性跟你的类字段一样的,不要自己瞎起名字
var js = '{"LoginName":"社会我李哥","PassWord":"哦"}'; //JSON
//传递的数据必须为JSON格式的
//把对象转成JSon字符串传进入
$.ajax({
type: "Post",
url: "GetJson.ashx",
data: "ob="+JSON.stringify(ob)+"&js="+js, //测试传一个对象,不转型的时候,后台无法处理,所以传递必须为JSON数据格式 一个,数组都可以
dataType: "json",
async: true,
success: function (data) {
console.log(typeof (data));
console.log(data);
alert(data.LoginName);
},
error: function () {
alert(" 错了");
}
})
</script>
后台:
string ob = context.Request.Form["ob"];// "{\"LoginName\":\"李某\",\"PassWord\":\"159\"}"
string js = context.Request.Form["js"];// "{\"LoginName\":\"社会我李哥\",\"PassWord\":\"哦\"}"
//下面需要做的就是把JSON转成对象(一个确定的对象)
//①自带的
JavaScriptSerializer json = new JavaScriptSerializer();
//反序列化,主要他需要的参数,如果是数据集 就换成 List<T>
FunctionDemo.Model.Users one = json.Deserialize(ob, typeof(FunctionDemo.Model.Users)) as FunctionDemo.Model.Users;
//②dll typeof(T) 这个参数一个要带,不然成功不了
FunctionDemo.Model.Users model = JsonConvert.DeserializeObject(js, typeof(FunctionDemo.Model.Users)) as FunctionDemo.Model.Users;
//或者 JsonConvert.DeserializeObject<FunctionDemo.Model.Users>(js);
//如果你传递的JSON数据没有确切的类型来接受,你自己可以在上面写一个 class ,属性值更你传递过来的属性是一一对应的就行
经过测试获取成功
总结:前台传数据之前就需要转成JSON格式,后台才好反序列化。
到此Json传递数据就完了。
C#Json数据交互的更多相关文章
- json数据交互
springmvc 的json数据交互 - 哎幽的成长 - CSDN博客--和老师讲课相同http://blog.csdn.net/u012373815/article/details/4720818 ...
- spring-boot json数据交互
SpringBoot学习之Json数据交互 最近在弄监控主机项目,对javaweb又再努力学习.实际的项目场景中,前后分离几乎是所以项目的标配,全栈的时代的逐渐远去,后端负责业务逻辑处理,前端负责数据 ...
- SpringMVC JSON数据交互
本节内容: @RequestBody @ResponseBody 请求json,响应json实现 前端可以有很多语言来写,但是基本上后台都是java开发的,除了c++(开发周期长),PHP和#Net( ...
- springMVC学习(11)-json数据交互和RESTful支持
一.json数据交互: json数据格式在接口调用中.html页面中较常用,json格式比较简单,解析还比较方便. 比如:webservice接口,传输json数据. springMVC进行json交 ...
- SpringMVC入门(二)—— 参数的传递、Controller方法返回值、json数据交互、异常处理、图片上传、拦截器
一.参数的传递 1.简单的参数传递 /* @RequestParam用法:入参名字与方法名参数名不一致时使用{ * value:传入的参数名,required:是否必填,defaultValue:默认 ...
- Spring MVC之JSON数据交互和RESTful的支持
1.JSON概述 1.1 什么是JSON JSON(JavaScript Object Notation,JS对象标记)是一种轻量级的数据交换格式.它是基于JavaScript的一个子集,使用了C.C ...
- springmvc的json数据交互
准备 @RequestBody 作用: @RequestBody注解用于读取http请求的内容(字符串),通过springmvc提供的HttpMessageConverter接口将读到的内容(json ...
- 1.4(Spring MVC学习笔记)JSON数据交互与RESTful支持
一.JSON数据交互 1.1JSON简介 JSON(JavaScript Object Notation)是一种数据交换格式. 1.2JSON对象结构 {}代表一个对象,{}中写入数据信息,通常为ke ...
- SprimgMVC学习笔记(八)—— SpringMVC与前台json数据交互
一.两种交互形式 可以看出,前台传过来的方式有两种,一种是传json格式的数据过来,另一种就是在url的末尾传普通的key/value串过来,针对这两种方式,在Controller类中会有不同的解析, ...
- springmvc学习笔记(18)-json数据交互
springmvc学习笔记(18)-json数据交互 标签: springmvc springmvc学习笔记18-json数据交互 springmvc进行json交互 环境准备 加入json转换的依赖 ...
随机推荐
- std::ref() 与 &
引言 之前因为调整样式把博客园的样式毁了,所以一直在自己的另一个博客上更新,有兴趣的可以去观望一下:http://blog.yunlambert.top/最近还是把博客园拾起来吧..... 最近看到一 ...
- Eugeny and Array(水题,注意题目描述即可)
Eugeny has array a = a1, a2, ..., an, consisting of n integers. Each integer ai equals to -1, or to ...
- Floyed-Warshall算法(求任意两点间最短距离)
思路:感觉有点像暴力啊,反正我是觉得很暴力,比如求d[i][j],用这个方法求的话,就直接考虑会不会经过点k(k是任意一点) ,最终求得最小值 看代码 #include<iostream> ...
- Git bash 生产 ssh key
ssh-keygen -t rsa -C "youremail@example.com"
- SpringBoot | 第一章:第一个SpringBoot应用
springboot简单介绍 概述 SpringBoot的核心功能 优缺点 优点 缺点 工程搭建 创建项目 项目结构 pom依赖 主入口 编写controller 启动应用 总结 老生常谈 sprin ...
- Authentication to host '***‘' for user 'root' using method 'mysql_native_password' failed with message: Reading from the stream has failed.
如下场景: 一个页面中需要用户填入文字信息,并上传图片,上传图片是单独调用上传文件接口的,当用户上传图片后,马上点保存,就会报错. Authentication to host '***‘' for ...
- JNI教程
一.什么是JNI JNI(Java Native Interface ),它是Java SDK的一部分,主要用于实现Java对其他语言编写的代码和库的调用,比如C和C++.JNI提供的API也能让JV ...
- android-上下文菜单的创建 - 随心
//Menu设置//覆盖两个方法onCreateOptionsMenu(Menu menu).onOptionsItemSelected(MenuItem Item)//onCreateOptions ...
- 【ros-kinetic iai_kinect2 opencv2 3 】注意事项
iai_kinect2 : https://github.com/code-iai/iai_kinect2/tree/master/kinect2_registration kinect2_brid ...
- 【MATLAB】设定坐标的轴的范围
set(gca,'XLim',[0 1.5]);%X轴的数据显示范围set(gca,'XTick',[0:0.1:1.5]);%设置要显示坐标刻度set(gca,'XTickLabel',[0:0.1 ...