3

我是 WCF 的新手,所以我认为这是非常基本的。我有一个简单的方法,它返回一个“订单”对象。使用默认 XML 时它工作得很好,但是,当我应用

ResponseFormat = WebMessageFormat.Json

属性,返回失败JSON。代码成功执行并点击返回行,但随后立即再次调用该方法,最后在浏览器返回错误之前第三次调用,说明与 localhost 的连接已中断

当我删除 时ResponseFormat = WebMessageFormat.Json,调用该方法并返回 XML 就好了。不确定我是否缺少 JSON。

IProductSales.cs

namespace ProductsSalesService
{
    [ServiceContract(Name = "ProductsSales")]
    public interface IProductsSales
    {

        [OperationContract]
        [WebGet(UriTemplate = "Orders/{orderID}", ResponseFormat = WebMessageFormat.Json)]
        [Description("Returns the details of an order")]
        SalesOrderHeader GetOrder(string orderID);

    }
}

产品销售

public SalesOrderHeader GetOrder(string orderID)
{
    SalesOrderHeader header = null;

    try
    {
        int id = Convert.ToInt32(orderID);
        AdventureWorksEntities database = new AdventureWorksEntities();

            header = (from order in database.SalesOrderHeaders
                      where order.SalesOrderID == id
                      select order).FirstOrDefault();

    }
    catch
    {
        throw new WebFaultException(HttpStatusCode.BadRequest);
    }

    return header;
}

我正在研究 WCF 书中的一个示例,所以他们让我构建了一个小型控制台应用程序作为主机,所以这是我为主机客户端提供的 app.config 文件。

<?xml version="1.0"?>
<configuration>
  <connectionStrings>
    <add name="AdventureWorksEntities" connectionString="metadata=res://*/ProductsSalesModel.csdl|res://*/ProductsSalesModel.ssdl|res://*/ProductsSalesModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=BINGBONG;Initial Catalog=AdventureWorks;Integrated Security=True;MultipleActiveResultSets=True&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/></startup><system.serviceModel>
    <services>
      <service name="ProductsSalesService.ProductsSales">
        <endpoint address="http://localhost:8000/Sales" binding="webHttpBinding"
          bindingConfiguration="" name="ProductsSalesService.ProductsSales"
          contract="ProductsSalesService.IProductsSales" />
      </service>
    </services>
  </system.serviceModel>
</configuration>

最后,这只是主机客户端代码。

public class Program
    {
        static void Main(string[] args)
        {
            WebServiceHost host = new WebServiceHost(typeof(ProductsSalesService.ProductsSales));
            host.Open();
            Console.WriteLine("Service running");
            Console.WriteLine("Press ENTER to stop the service");
            Console.ReadLine();
            host.Close();
        }
    }

因此,当我去http://localhost:8000/Sales/Orders/43659拉起我的订单时,它点击了三次,并且页面在 Chrome 中取消,并出现以下错误:

此网页不可用 与 localhost 的连接已中断。以下是一些建议: 稍后重新加载此网页。检查您的互联网连接。重新启动您可能正在使用的任何路由器、调制解调器或其他网络设备。在防火墙或防病毒软件的设置中将 Google Chrome 添加为允许的程序。如果它已经是允许的程序,请尝试将其从允许的程序列表中删除并重新添加。如果您使用代理服务器,请检查您的代理设置或联系您的网络管理员以确保代理服务器正常工作。如果您认为您不应该使用代理服务器,请调整您的代理设置:转到扳手菜单 > 设置 > 显示高级设置... > 更改代理设置...

LAN 设置并取消选中“为 LAN 使用代理服务器”复选框。错误 101 (net::ERR_CONNECTION_RESET):连接已重置。

如果我删除WebMessageFormat.Json一切正常!

感谢您的帮助!

4

3 回答 3

5

对于初学者,请尝试 WCF 跟踪/日志记录,看看它是否能说明问题。

将其放入服务器的配置文件中(<configuration>元素内的某处):-

<system.diagnostics>
 <sources>
  <source name="System.ServiceModel" switchValue="Error" propagateActivity="true">
    <listeners>
      <add name="traceListener" type="System.Diagnostics.XmlWriterTraceListener" initializeData="C:\Temp\server.svclog"/>
    </listeners>
  </source>
  <source name="System.ServiceModel.MessageLogging">
    <listeners>
      <add name="messages"
      type="System.Diagnostics.XmlWriterTraceListener"
      initializeData="C:\Temp\server_messages.svclog" />
    </listeners>
  </source>
 </sources>
</system.diagnostics>

并将其放入<system.serviceModel>元素中:-

<diagnostics>
  <messageLogging
       logEntireMessage="true"
       logMalformedMessages="false"
       logMessagesAtServiceLevel="true"
       logMessagesAtTransportLevel="false"
       maxMessagesToLog="3000"
       maxSizeOfMessageToLog="2000"/>
</diagnostics>

尝试再次点击您的服务并检查此(希望)生成的 .svclog 文件以寻找线索。这些文件将在“服务跟踪查看器”工具中打开 - 如果没有,它可以从 MS 下载(我认为是 Win SDK 的一部分)。

于 2012-06-13T13:59:08.000 回答
1

虽然我的错误实际上是无关的,但这是我在调查我的问题时发现的第一篇文章,即我的服务失败并且我看到错误连接已中断

我的错是因为我从我的WebGet方法输出的类具有具有属性的DataContract属性,但我没有Set为每个属性添加访问器(因为我认为它们只是输出,我没有看到重点) .

将跟踪添加到我的配置文件中很快发现错误是没有Set访问器,所以我private set为每个DataContract属性添加了访问器,现在一切都按预期工作。

我在这里添加了这个,以防其他人遵循相同的搜索路径并遇到相同的问题

于 2015-11-22T11:40:31.420 回答
0

这行代码将在不考虑配置的情况下构建服务主机,因此您将拥有服务,但它会侦听不同的 URL。

WebServiceHost host = new WebServiceHost(typeof(ProductsSalesService.ProductsSales));

在下面添加基地址new WebServiceHost和代码:

    WebChannelFactory<ProductsSalesService.IProductsSales> cf = 
    new WebChannelFactory<ProductsSalesService.IProductsSales>("ProductsSalesService.ProductsSales");
ProductsSalesService.IProductsSales channel = cf.CreateChannel();

在此处查看完整代码 - http://msdn.microsoft.com/en-us/library/bb919583

于 2012-06-13T14:22:16.850 回答