WCF 클라이언트 계약을 프로그래밍 방식으로 생성하는 플러그 인을 사용하는 앱을 얻은 다음 생성 된 계약을 재사용 할 수있는 방법을 찾기 위해 고심하고 있습니다. 플러그인 DLL에 있습니다.프로그래밍 방식으로 WCF 클라이언트 계약을 생성 할 때 유형 재사용
정의 된 어셈블리에서 유형을 다시 사용하기 위해 ServiceContractGenerator를 설정하는 방법을 아는 사람이 있습니까?
이
내가 계약 코드 기압을 생성하는 데 사용할 것입니다 : public Assembly CreateProxy(String url)
{
MetadataExchangeClient mexClient = new MetadataExchangeClient(new Uri(url + "/mex"), MetadataExchangeClientMode.MetadataExchange);
mexClient.ResolveMetadataReferences = true;
MetadataSet metaDocs = mexClient.GetMetadata();
WsdlImporter importer = new WsdlImporter(metaDocs);
ServiceContractGenerator generator = new ServiceContractGenerator();
generator.NamespaceMappings.Add("*", "NameSpace123");
Collection<ContractDescription> contracts = importer.ImportAllContracts();
ServiceEndpointCollection endpoints = importer.ImportAllEndpoints();
foreach (ContractDescription contract in contracts)
generator.GenerateServiceContractType(contract);
if (generator.Errors.Count != 0)
throw new Exception("There were errors during code compilation.");
CodeDomProvider codeDomProvider = CodeDomProvider.CreateProvider("C#");
CompilerParameters parameters = new CompilerParameters();
parameters.CompilerOptions = string.Format(@" /lib:{0}", "\"C:\\Program Files\\Reference Assemblies\\Microsoft\\Framework\\v3.0\"");
parameters.ReferencedAssemblies.Add("System.ServiceModel.dll");
parameters.ReferencedAssemblies.Add("System.Runtime.Serialization.dll");
parameters.GenerateExecutable = false;
parameters.GenerateInMemory = true;
parameters.IncludeDebugInformation = true;
parameters.OutputAssembly = "WCFGenerated.dll";
CodeCompileUnit codeUnit = generator.TargetCompileUnit;
CompilerResults results = codeDomProvider.CompileAssemblyFromDom(parameters, codeUnit);
foreach (CompilerError oops in results.Errors)
throw new Exception("Compilation Error Creating Assembly: " + oops.ErrorText);
//Must load it like this otherwise the assembly wont match the one used for the generated code below
return Assembly.LoadFile(Directory.GetCurrentDirectory() + "\\WCFGenerated.dll");
}
편집 :이 그러나 내가 어셈블리로 EXE 파일을로드 관리 않았고, 아주 잘 작동하고 생성하는 것을 사용하는 것이 없었어 프록시 :
try
{
Thread.CurrentThread.CurrentUICulture = CultureInfo.CurrentUICulture.GetConsoleFallbackUICulture();
if (Console.OutputEncoding.CodePage != Encoding.UTF8.CodePage && Console.OutputEncoding.CodePage != Thread.CurrentThread.CurrentUICulture.TextInfo.OEMCodePage)
{
Thread.CurrentThread.CurrentUICulture = new CultureInfo("en-US");
}
var assembly = Assembly.LoadFile(Path.Combine(info.TempDir, SVCUTIL_EXE));
var optionsType = assembly.GetType("Microsoft.Tools.ServiceModel.SvcUtil.Options");
var runtimeType = assembly.GetType("Microsoft.Tools.ServiceModel.SvcUtil.ToolRuntime");
//Options option = Options.ParseArguments(args);
var options = optionsType.InvokeMember("ParseArguments", BindingFlags.Static | BindingFlags.NonPublic | BindingFlags.InvokeMethod, null, null, new object[] { info.Args });
//ToolRuntime toolRuntime = new ToolRuntime(option);
ConstructorInfo c = runtimeType.GetConstructor(BindingFlags.NonPublic | BindingFlags.Instance, null, new Type[] { optionsType }, null);
var runtime = c.Invoke(new Object[] { options });
//var runtime = Activator.CreateInstance(runtimeType, , null, options);
//toolRuntime.Run();
var exitCode = (int)runtimeType.InvokeMember("Run", BindingFlags.InvokeMethod | BindingFlags.NonPublic | BindingFlags.Instance, null, runtime, null);
if (exitCode != 0)
throw new Exception(String.Format("Failed to generate wcf contract code [Bad Result: {0}]", exitCode));
}
catch (Exception e)
{
if (e is TargetInvocationException)
e = e.InnerException;
info.E = e;
}
여기서 질문은 무엇입니까? – MrWuf
질문을 추가 할 편집 됨 – Lodle