asp.net返回JSON格式数据总结

栏目: ASP.NET · 发布时间: 5年前

内容简介:我发现自己写过好几篇相关主题的文章:asp.net中如何返回JSON格式的数据、asp.net中如何返回JSON格式的数据。现在回过头来看看这些文章,五花八门。尽管如此,每次遇到要返回JSON,我仍然一脸茫然,需要翻出这些文章查阅一番。来个总结吧。一、

我发现自己写过好几篇相关主题的文章:asp.net中如何返回JSON格式的数据、asp.net中如何返回JSON格式的数据。现在回过头来看看这些文章,五花八门。尽管如此,每次遇到要返回JSON,我仍然一脸茫然,需要翻出这些文章查阅一番。

来个总结吧。

一、 asp.net web api

这是for api的,有别于mvc

using System.Web.Http;
using System.Web.Http.Results;
public class HyzController : ApiController
{
	[HttpGet]
	[Route("api/base/hyz/zxz")]
	public JsonResult<List<Zxz>> GetZxz()
	{
		var data = new List<Zxz>()
		{
			new Zxz()
			{
				Id = 1,
				Name = "广州",
				Parent = "天河区",
				SubNum = 9,
				Subs = new List<Hyz>()
				{
					new Hyz()
					{
						Id = 2,
						Name = "天园街"
					},
					new Hyz()
					{
						Id = 3,
						Name = "棠下街"
					}
				}
			}
		};
		return Json(data);
	}

二、 asp.net web api中强制返回格式为JSON

asp.net web api 默认的结果传送方式是XML。但可以设置为JSON。方法为在WebApiConfig里加入一句:

public static class WebApiConfig  
{  
    public static void Register(HttpConfiguration config)  
    {  
        // Web API 路由  
        config.MapHttpAttributeRoutes();  
  
        config.Routes.MapHttpRoute(  
            name: "DefaultApi",  
            routeTemplate: "api/{controller}/{action}/{id}",  
            defaults: new { id = RouteParameter.Optional }  
        );  
        config.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));//改为JSON方式  
    }  
}

三、 asp.net MVC

public ContentResult GetUser()
{
	return new ContentResult {
		ContentEncoding = Encoding.GetEncoding("utf-8")
		,ContentType = "application/json"//<-----------------------------------
		,Content = @"{
			""code"" : ""0",
			""desc"" : ""请求数据成功!",
			""dataobj"" : [ {
			""action"" : ""I",
			""userCode"" : ""001",
			""userName"" : ""张三""
			}, {
			""action"" : ""U",
			""userCode"" : ""002",
			""userName"" : ""李四""
		} ]}" 
	};
}

返回类型用JsonResult也可以,但无法应用预先拼好的json字符串

参考文章: ASP.NET MVC 提供与访问 Web Api

四、不管是WEB API还是MVC,直接返回JSON对象

using Newtonsoft.Json;
 
[System.Web.Http.HttpGet]
public JObject GetTags(string account)
{
    JObject jobj = new JObject();
 
	//ViewTag是自定义类
    IList<ViewTag> list = customViewService.GetTags(ProjectId,account);
    jobj.Add("total", (JToken)list.Count());
    jobj.Add("rows", JArray.FromObject(list));
 
    return jobj;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

PHP and MySQL for Dynamic Web Sites : Visual QuickPro Guide

PHP and MySQL for Dynamic Web Sites : Visual QuickPro Guide

Larry Ullman / Peachpit Press / 2005 / USD 39.99

It hasn't taken Web developers long to discover that when it comes to creating dynamic, database-driven Web sites, MySQL and PHP provide a winning open source combination. Add this book to the mix, an......一起来看看 《PHP and MySQL for Dynamic Web Sites : Visual QuickPro Guide》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

SHA 加密
SHA 加密

SHA 加密工具