我在我的站点中使用 ServiceStack 来允许用户下载系统数据集之一的 csv。在我的 AppHost 的配置方法中,我为 DateTime 提供了一个自定义序列化程序。看起来像这样
JsConfig<DateTime>.SerializeFn = time =>
{
var result = time;
if (time.Kind == DateTimeKind.Unspecified)
{
result = DateTime.SpecifyKind(result, DateTimeKind.Local);
}
return result.ToString(CultureInfo.InvariantCulture);
};
使用 csv 格式时,结果中的所有日期都包含在额外的引号中;例如结果是 """06/24/2015 16:22:16""" 当我期望它是 "06/24/2015 16:22:16"
在我看来,这一定是 ServiceStack 序列化中的一个错误。有没有办法防止这种情况发生?下面是一个完整的示例,展示了向 /csv/oneway/Request 发出请求时出现的问题
public class AppHost : AppHostBase
{
/// <summary>
/// Default constructor.
/// Base constructor requires a name and assembly to locate web service classes.
/// </summary>
public AppHost()
: base("CSVBug", typeof(MyService).Assembly)
{
}
public override void Configure(Container container)
{
JsConfig<DateTime>.SerializeFn = time =>
{
var result = time;
if (time.Kind == DateTimeKind.Unspecified)
{
result = DateTime.SpecifyKind(result, DateTimeKind.Local);
}
return result.ToString(CultureInfo.InvariantCulture);
};
}
}
public class Request
{
}
public class Response
{
public DateTime DateTime { get; set; }
}
public class MyService : Service
{
public object Any(Request reuqest)
{
return new Response()
{
DateTime = DateTime.Now
};
}
}
和 Global.asax.cs
public class Global : System.Web.HttpApplication
{
protected void Application_Start(object sender, EventArgs e)
{
new AppHost().Init();
}
}