asp.net mvc接收安卓post的json字符串
筛选器:
- 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字符串的更多相关文章
- spring mvc接收ajax提交的JSON数据,并反序列化为对象
需求:spring mvc接收ajax提交的JSON数据,并反序列化为对象,代码如下: 前台JS代码: //属性要与带转化的对象属性对应 var param={name:'语文',price:16}; ...
- asp.net mvc 接收jquery ajax发送的数组对象
<script type="text/javascript"> $(function () { var obj = { name: "军需品", m ...
- asp.net mvc实现rest风格返回json
实现类似:http://localhost:1799/rest/person/1方式返回一个json内容: 在asp.net mvc中新建一个control rest,然后在其中新增方法: publi ...
- JAVA 后台SSM框架接收安卓端的json数据
最近项目上与安卓端做JSON数据交互,使用的SSM框架,刚开始的时候感觉很简单,想着不就是把安卓端的JSON数据封装为Bean类对象吗? 于是就这样写了 可是这样一直报400,百度原因是因为请求url ...
- 160506、Spring mvc新手入门(11)-返回json 字符串的其他方式
Spring MVC返回 json字符串的方式有很多种方法,这里介绍最简单,也是最常使用的两种方式 一.使用 PrintWriter printWriter 直接输出字符串到返回结果中 不需 ...
- asp.net MVC 给Controler传一个JSon集合,后台通过List<Model>接收
需求情景 View层经常需要通过Ajax像后台发送一个json对象的集合,但是在后台通过List<Model>无法接收,最后只能通过妥协的方式,在后台获取一个json的字符串,然后通过Js ...
- spring mvc接收参数方式,json格式返回请求数据
1 使用方法形参使用变量接收提交的数据 2 在方法的形参中使用模型接收数据 3 如果在提交的表单中有多个数据模型,需要创建一个新的Bean,里面的属性是要接收的对象变量. 4 接收提交的日期字符串,转 ...
- ASP.NET MVC获取微信返回的json数据分页
View @model JiaYe.WeiXin.Models.ViewModels.UserViewModel <div class="pull-left pagination&qu ...
- Asp.net C# 把 Datatable转换成JSON 字符串
First of all, we have to fetch the records from the database (MS Sqlserver) into the C# DataTable, o ...
随机推荐
- C# 异步编程3 TPL Task 异步程序开发
.Net在Framework4.0中增加了任务并行库,对开发人员来说利用多核多线程CPU环境变得更加简单,TPL正符合我们本系列的技术需求.因TPL涉及内容较多,且本系列文章为异步程序开发,所以本文并 ...
- 使用mysqladmin extended-status查看MySQL的运行状态脚本
一个好用的使用mysqladmin extended-status查看MySQL的运行状态脚本: mysqladmin -P3306 -uroot -p -h127. -r -i extended-s ...
- centos7安装rabbitmq 总结
centos7下安装rabbitmq 折腾了三天最后做了以下总结 先查看一电脑名 :示例 #hostname name 查看一下hosts配置文件:如果如下结果,就要修改下 #cat /etc/ho ...
- 前端使用 validate , 根据条件进行动态的验证添加
需求如下: 审核操作的时候,选择“通过” 就不需要验证审核意见,但是选择的是“不通过”,那么需要进行审核意见验证 <script> $(function () { InitValidate ...
- 26_ArrayList_HashSet的比较及Hashcode分析
实体类: package com.itcast.day1; public class ReflectPoint { private int x; public int y; public Reflec ...
- Hive-1.2.1_01_安装部署
前言:该文章是基于 Hadoop2.7.6_01_部署 进行的. 1. Hive基本概念 1.1. 什么是Hive Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库 ...
- Alpha冲刺 - 事后诸葛亮
Alpha冲刺 - 事后诸葛亮 Alpha完成情况表 Stardust(安卓端) 模块 预期计划 现实进展 完成度 登录/注册 登录时,从服务器拉取的数据并同步数据库.获取的数据有:用户名.密码.记录 ...
- SAP CRM 忠诚度相关表的关系图
这是一张有关会员,积分,活动等内容的相关表的关系图,对相关的开发工作会有帮助. 原文标题:Table schema for managing customer loyality 本文链接:http:/ ...
- 【数据库】事务,ACID,CAP和一致性
什么是事务 事务是指由一系列数据库操作组成的一个完整的逻辑过程,这个过程中的所有操作要么都成功,要么都不成功.比如:常见的例子就是银行转账的例子,一次转账操作会包含多个数据库操作,而这些数据库操作需要 ...
- cenos下配置Apache+PHP最新版7.1.6+MySQL最新版(5.7.18)
一.安装Apache,略. 二.安装PHP 1.下载php7 wget -O php7.tar.gz http://cn2.php.net/distributions/php-7.1.6.tar.gz ...