筛选器:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Runtime.Serialization.Json; namespace BP_RFID_WMS.Controllers
{
/// <summary>
/// Request.InputStream流筛选器
/// </summary>
public class JsonStringFilter : ActionFilterAttribute
{
/// <summary>
/// 参数
/// </summary>
public string Param
{
get;
set;
} /// <summary>
/// 接受Request.InputStream流的POST数据Encoding为utf-8编码的字符串
/// </summary>
/// <param name="filterContext"></param>
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
if ((filterContext.HttpContext.Request.ContentType ?? string.Empty).Contains("application/json"))
{
try
{
byte[] byts = new byte[filterContext.HttpContext.Request.InputStream.Length];
filterContext.HttpContext.Request.InputStream.Read(byts, 0, byts.Length);
string req = System.Text.Encoding.UTF8.GetString(byts);
req = filterContext.HttpContext.Server.UrlDecode(req);
filterContext.ActionParameters[Param] = req;
}
catch (Exception ex)
{
Com.DataCool.DotNetExpand.LogHelper.Error(ex);
}
}
}
}
}

  Controller(注意写法,写个标签就OK了 [JsonStringFilter(Param = "entity")]

):

  [JsonStringFilter(Param = "entity")]
public JsonResult SaveGridDataToExcelFile(string entity)
{
if (!string.IsNullOrEmpty(entity))
{
JObject jsonParams = JObject.Parse(entity);
var gridRows = (JArray)jsonParams["GridRows"];
var gridOptions = (JArray)jsonParams["GridColumnOptions"];
var gridOptionList = (JArray)gridOptions;
//可见的列
List<JObject> gridCols = new List<JObject>();
foreach (JObject j in gridOptionList)
{
if (j.ToString().IndexOf("hidden") == -1)
{
gridCols.Add(j);
}
}
var fileName = jsonParams["ExportFileName"].Value<string>();
string tempFileName = HttpContext.Server.MapPath("~/") + "TemplateFiles\\" + "CommonExcelFile.xls";
FileStream fs = new FileStream(tempFileName, FileMode.Open, FileAccess.Read);
var workBook = new HSSFWorkbook(fs);
workBook.SetSheetName(0, "sheet1");
var sheet = workBook.GetSheetAt(0);
//表头(列),第一行
int newColIndex = 0;
var titleRow = sheet.CreateRow(newColIndex);
int cIndex = 0;
foreach (JObject j in gridCols)
{
titleRow.CreateCell(cIndex).SetCellValue(j["title"].Value<String>());
int width = j["width"].Value<int>() / 6;
if (width > 255)
width = 250;
sheet.SetColumnWidth(cIndex, width * 256);
cIndex++;
}
//行记录
for (int rowIndex = 0; rowIndex < gridRows.Count; rowIndex++)
{
newColIndex++;
var row = sheet.CreateRow(newColIndex);
var jsonEntity = gridRows[rowIndex] as JObject;
for (int colIndex = 0; colIndex < gridCols.Count; colIndex++)
{
string cellValue = string.Empty;
JObject colOption = (JObject)gridCols[colIndex];
string field = colOption["field"].Value<string>();
if (jsonEntity[field].ToString().Length != 0)
cellValue = jsonEntity[field].Value<String>();
row.CreateCell(colIndex).SetCellValue(cellValue);
}
}
MemoryStream newFile = new MemoryStream();
sheet.Workbook.Write(newFile);
using (Reserve_DbEntities db = new Reserve_DbEntities())
{
var resultFile = new AppExportFile();
resultFile.FileGuid = Guid.NewGuid();
resultFile.FileName = fileName;
resultFile.FileCreateDateTime = DateTime.Now;
resultFile.FileStreamByte = newFile.GetBuffer();
db.AddToAppExportFile(resultFile);
db.SaveChanges();
var data = new { fileID = resultFile.FileGuid.ToString() };
return Json(data, JsonRequestBehavior.AllowGet);
}
}
else return Json(string.Empty, JsonRequestBehavior.AllowGet);
}

  

asp.net mvc接收安卓post的json字符串的更多相关文章

  1. spring mvc接收ajax提交的JSON数据,并反序列化为对象

    需求:spring mvc接收ajax提交的JSON数据,并反序列化为对象,代码如下: 前台JS代码: //属性要与带转化的对象属性对应 var param={name:'语文',price:16}; ...

  2. asp.net mvc 接收jquery ajax发送的数组对象

    <script type="text/javascript"> $(function () { var obj = { name: "军需品", m ...

  3. asp.net mvc实现rest风格返回json

    实现类似:http://localhost:1799/rest/person/1方式返回一个json内容: 在asp.net mvc中新建一个control rest,然后在其中新增方法: publi ...

  4. JAVA 后台SSM框架接收安卓端的json数据

    最近项目上与安卓端做JSON数据交互,使用的SSM框架,刚开始的时候感觉很简单,想着不就是把安卓端的JSON数据封装为Bean类对象吗? 于是就这样写了 可是这样一直报400,百度原因是因为请求url ...

  5. 160506、Spring mvc新手入门(11)-返回json 字符串的其他方式

    Spring MVC返回 json字符串的方式有很多种方法,这里介绍最简单,也是最常使用的两种方式 一.使用  PrintWriter printWriter  直接输出字符串到返回结果中    不需 ...

  6. asp.net MVC 给Controler传一个JSon集合,后台通过List<Model>接收

    需求情景 View层经常需要通过Ajax像后台发送一个json对象的集合,但是在后台通过List<Model>无法接收,最后只能通过妥协的方式,在后台获取一个json的字符串,然后通过Js ...

  7. spring mvc接收参数方式,json格式返回请求数据

    1 使用方法形参使用变量接收提交的数据 2 在方法的形参中使用模型接收数据 3 如果在提交的表单中有多个数据模型,需要创建一个新的Bean,里面的属性是要接收的对象变量. 4 接收提交的日期字符串,转 ...

  8. ASP.NET MVC获取微信返回的json数据分页

    View @model JiaYe.WeiXin.Models.ViewModels.UserViewModel <div class="pull-left pagination&qu ...

  9. Asp.net C# 把 Datatable转换成JSON 字符串

    First of all, we have to fetch the records from the database (MS Sqlserver) into the C# DataTable, o ...

随机推荐

  1. 皮肤控件IrisSkin4.dll调用样例-vs2010-c#

    http://blog.csdn.net/wy7980/article/details/41933095

  2. Java jni字符串转换

    1.jstring转QString 对于Qt5.2以上(含)可以用QAndroidJniObject::toString(),详见这里:https://stackoverflow.com/questi ...

  3. MySQL之慢查询日志分析

    在MySQL命令行中查看慢查询日志是否打开了: mysql> show variables like '%slow_query%'; +---------------------------+- ...

  4. Unity3d粒子系统详解

  5. IO流_PrintWriter(字符打印流)与PrintStream(字节打印流)

    PrintStream:  1.提供了打印方法可以对多种数据类型值进行打印,并保持数据的表示形式  2.它不抛IOException  3.构造函数接受三种类型的值:  字符串路径  File对象   ...

  6. Linux基础第五课——用户管理

    用户管理 一个用户必须有一个主组 一个用户可以拥有多个组 但是必须一个主组 其它组是临时组 一个组可以拥有多个用户 用户的信息放到 /etc/passwd 用户的密码 存入 /etc/shadow 组 ...

  7. Spring Cloud Eureka 属性作用

    配置参数 默认值 说明 服务注册中心配置 Bean类:org.springframework.cloud.netflix.eureka.server.EurekaServerConfigBean eu ...

  8. php获取两个数组相同的元素(交集)以及比较两个数组中不同的元素(差集)

    (一)php获取两个数组相同元素 array  array_intersect(array  $array1, array $array2, [, array $...]) array  array_ ...

  9. KVM虚拟化图

  10. QT 11 鼠标键盘事件添加

    鼠标事件 void mousePressEvent(QMouseEvent *event); //单击 void mouseReleaseEvent(QMouseEvent *event); //释放 ...