为什么在WCF服务中抛出FaultException?

时间:2013-01-26 19:42:20

标签: c# wcf entity-framework entity-framework-4.1 entity-framework-5

让我澄清一下我的情景。我有一个使用库的WCF服务,在这个库中存在数据库模型(edmx)。

在我的WCF服务中:

[DataContract]
public class QuestionSetInformation
{
    [DataMember]
    public string Id { get; set; }
    [DataMember]
    public string SetName { get; set; }
    [DataMember]
    public string ObjectiveName { get; set; }
}

[ServiceContract]
public interface IService1
{
    [OperationContract]
    QuestionSetInformation[] GetQuestionSets(string objectiveName);
}

public QuestionSetInformation[] GetQuestionSets(string objectiveName)
{
    var query = from r in QuestionRepositoryManager.GetRepositories()
                select new QuestionSetInformation()
                {
                   Id = r.Id,
                   SetName = r.SetName,
                   ObjectiveName = r.ObjectiveName
                };

    return query.ToArray();
}

由于我的库使用EDMX,所以我将连接字符串移动到我的WCF,它使用WCF测试客户端完美地工作。它为我提供了我所期待的。

<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <connectionStrings>
    <add name="ContosoDb" connectionString="metadata=res://*/Entities.Model1.csdl|res://*/Entities.Model1.ssdl|res://*/Entities.Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=X;initial catalog=contoso2_db;persist security info=True;user id=X;password=X;multipleactiveresultsets=True;application name=EntityFramework&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
  </entityFramework>

但是在桌面应用程序中一次使用此WCF时,我遇到以下异常:

        ServiceReference1.Service1Client service = new ServiceReference1.Service1Client("BasicHttpsBinding_IService1");
        ServiceReference1.QuestionSetInformation[] qss = service.GetQuestionSets("something");
  

FaultException`1未处理使用T4模板生成的代码   对于Database First和Model First开发可能无法正常工作   如果在Code First模式下使用。继续使用Database First或Model   首先确保指定了Entity Framework连接字符串   在执行应用程序的配置文件中。要使用这些类,   使用Code从Database First或Model First生成的   首先使用属性或添加任何其他配置   DbModelBuilder API然后删除抛出此代码的代码   异常。

我在网上调查了这个错误,每个人都讲述了使用连接字符串的问题,但我认为这不是同一个案例。我不知道如何解决它

1 个答案:

答案 0 :(得分:0)

这是它使用的连接字符串的问题...它使用某种默认的SqlClient连接字符串(即不是指定三个EF元数据文件的实体框架连接字符串)它认为你在Code First模式下运行。

确保连接字符串的名称相同,或者将要使用的连接字符串名称传递给DbContext构造函数。