ASP.NET Web API将JSON作为对象返回
目前,查询Oracle数据库的Web API以下面的格式返回JSON中的结果。
[{"CATEGORY":"Internal Study","SESSION_NUMBER":7,"SESSION_START_DATE":"2015-02-13T00:00:00","SESSION_START_TIME":"2015-02-13T10:33:59.288394"}]
以下是我们正在使用的代码
public class SampleController : ApiController
{
public HttpResponseMessage Getdetails([FromUri] string[] id)
{
using (OracleConnection dbconn = new OracleConnection("DATA SOURCE=J;PASSWORD=C;PERSIST SECURITY INFO=True;USER ID=T"))
{
var inconditions = id.Distinct().ToArray();
var srtcon = string.Join(",", inconditions);
DataSet userDataset = new DataSet();
var strQuery = @"SELECT * from STCD_PRIO_CATEGORY where STPR_STUDY.STD_REF IN(" + srtcon + ")";
OracleCommand selectCommand = new OracleCommand(strQuery, dbconn);
OracleDataAdapter adapter = new OracleDataAdapter(selectCommand);
DataTable selectResults = new DataTable();
adapter.Fill(selectResults);
var response = Request.CreateResponse(HttpStatusCode.OK, selectResults,MediaTypeHeaderValue.Parse("application/json"));
ContentDispositionHeaderValue contentDisposition = null;
if (ContentDispositionHeaderValue.TryParse("inline; filename=ProvantisStudyData.json", out contentDisposition))
{
response.Content.Headers.ContentDisposition = contentDisposition;
}
return response;
}
}
但是具有使用该文件的脚本的客户端说JSON结构是一个数组而不是一个对象,这是一个安全漏洞。
{"data":[{"CATEGORY":"Internal Study","SESSION_NUMBER":7,"SESSION_START_DATE":"2015-02-13T00:00:00","SESSION_START_TIME":"2015-02-13T10:33:59.288394"}]}
我对这个JSON结构不熟悉,不确定我们如何将返回的数据作为JSON文件中的对象进行操作
我没有听说JSON中的数组存在任何安全问题,但是如果您需要将其转换为JSON对象,则可以使用您定义的通用对象:
var returnObject = new
{
selectResults = selectResults
};
这会将包含所需的JSON对象添加到响应中,然后使用此代码构建响应:
var response = Request.CreateResponse(HttpStatusCode.OK, returnObject,MediaTypeHeaderValue.Parse("application/json"));
对不起,如果我误解了你的要求 - 希望这有助于/工作。
链接地址: http://www.djcxy.com/p/47773.html上一篇: ASP.NET Web API Return JSON as an object
下一篇: Can an array be top