1

我有一个可以工作的 WCF 服务,但它使用标准 ADO.net 来调用一些存储过程。

维护起来有点混乱和烦人,因为我调用的任何存储过程,我必须映射到我必须手动创建的 DataContracts,然后以 JSON 形式返回。

我想将 WCF 服务转换为返回 EntityFramework 实体(因此我不必手动保持映射和创建数据合同)。

我的方法中有这样的东西,例如:

public List<GetStuff_Result> GetStuff(string param1)
{
            ...

            StuffEntities ctx = new DataContracts.StuffEntities();

            List<GetStuff_Result> list = ctx.GetStuff(5463, "test").ToList();

            return list;
}

我已经在 edmx 模型中设置了存储过程以返回 GetStuff_Result(我导入了存储过程并使用了“创建复杂函数”)

我已经对此进行了调试,并且在列表中得到了 2 个结果,但是当通过浏览器调用我的 WCF 方法时,我在浏览器(chrome)上收到一条消息:

No data received
Unable to load the web page because the server sent no data.
Here are some suggestions:
Reload this web page later.
Error 324 (net::ERR_EMPTY_RESPONSE): The server closed the connection without sending any data. 

谁能告诉我如何解决这个问题,或者至少为什么会这样?

注意(1):我还右键单击了 edmx 文件并禁用了延迟加载。

注意(2):我已经设置了一个 DbContext 生成器

注意(3):我使用 WebMessageFormat.Json 的响应格式

谢谢

4

3 回答 3

4

这个问题实际上非常适合 WCF 数据服务(与 WCF SOAP 无关)。

http://msdn.microsoft.com/en-us/library/dd744841.aspx

默认情况下,WCF 数据服务将返回 XML 格式的数据,但是有一个请求参数告诉它返回 JSON

http://blogs.msdn.com/b/writingdata_services/archive/2011/02/25/getting-json-out-of-wcf-data-services.aspx

于 2013-02-01T16:56:11.120 回答
1

1) 在部署之前在 WCF 测试客户端中测试您的应用程序总是一个好主意,这样您就可以查看服务调用是否有效

2) 发生这种情况的原因是,如果您运行直接存储过程或使用 EF GetStuff_Result 执行它并不重要,您仍然必须分配 [DataMember]给 GetStuff_Result 类中的每个变量,因此它将被序列化 EF 存储过程确实不会自动为您序列化结果。

于 2013-01-30T02:42:58.257 回答
1

实际上我找到了更好的方法

我可以设置 edmx 代码生成器来使用这个:http: //visualstudiogallery.msdn.microsoft.com/32c4660d-7e66-4c3a-b516-584f4f72b838

它的 DbContext 具有 WCF 支持(因此它生成的对象已经具有 DataMember 和 DataContract 属性)

这允许在服务中返回对象,而无需像 COLD TOLD 所建议的那样将 EF 对象映射到 WCF 对象。

于 2013-07-05T00:22:11.233 回答