动态引用WebService,建立WebService虚拟机

//建立WebService虚拟代理,使用xml登记WebService的引用地址。实现动态引用WebService.

 

//使用技术

//1、动态编译

 

//2、反射技术

 

//实现代码

using System;

using System.Reflection ;

using System.Web .Services .Description ;

using Microsoft.CSharp;

using System.CodeDom ;

using System.CodeDom.Compiler ;

using System.IO ;

using System.Text ;

using System.Xml ;

using System.Net ;

using WebServiceProxy;

 

namespace WebServiceProxy

{

     public class WebServiceProxy

     {

          private Assembly _ass = null;

          private string _protocolName = "Soap";

          private string _srcWSProxy = string.Empty;

         public Assembly Assembly{ get{ return _ass; }}

         public string ProtocolName

          { get{ return _protocolName; }set{_protocolName = value; }}

         public string SrcWSProxy{ get{ return _srcWSProxy; }}

         public WebServiceProxy ()

         {

         }

         public WebServiceProxy (string wsdlSourceName)

         {

              AssemblyFromWsdl(GetWsdl(wsdlSourceName));

         }

         public string WsdlFromUrl(string url)

         {

              WebRequest req = WebRequest.Create(url);

              WebResponse result = req.GetResponse();

              Stream ReceiveStream = result.GetResponseStream();

              Encoding encode = System.Text.Encoding.GetEncoding("utf-8");

              StreamReader sr = new StreamReader( ReceiveStream, encode );

              string strWsdl = sr.ReadToEnd();

              return strWsdl;

         }

         public string GetWsdl(string source)

         {

              if(source.StartsWith("<?xml version") == true)

              {

                   return source;

              }

              else

                   if(source.StartsWith("http://") == true)

              {

                   return WsdlFromUrl(source);

              }

              return WsdlFromFile(source);

         }

         public string WsdlFromFile(string fileFullPathName)

         {

              FileInfo fi = new FileInfo(fileFullPathName);

              if(fi.Extension == "wsdl")

              {

                   FileStream fs = new FileStream(fileFullPathName, FileMode.Open,FileAccess.Read);

                   StreamReader sr = new StreamReader(fs);

                   char[] buffer = new char[(int)fs.Length];

                   sr.ReadBlock(buffer, 0, (int)fs.Length);

                   return new string(buffer);

              }

              throw new Exception("This is no a wsdl file");

         }

         public Assembly AssemblyFromWsdl(string strWsdl)

         {

              // Xml text reader

              StringReader wsdlStringReader = new StringReader(strWsdl);

              XmlTextReader tr = new XmlTextReader(wsdlStringReader);

              ServiceDescription sd = ServiceDescription.Read(tr);

              tr.Close();

              // WSDL service description importer

              CodeNamespace cns = new CodeNamespace("WebServiceProxy.WebServiceAccessor");

              ServiceDescriptionImporter sdi = new ServiceDescriptionImporter();

              sdi.AddServiceDescription(sd, null, null);

              sdi.ProtocolName = _protocolName;

              sdi.Import(cns, null);

              // source code generation

              CSharpCodeProvider cscp = new CSharpCodeProvider();

              ICodeGenerator icg = cscp.CreateGenerator();

              StringBuilder srcStringBuilder = new StringBuilder();

              StringWriter sw = new StringWriter(srcStringBuilder);

              icg.GenerateCodeFromNamespace(cns, sw, null);

              _srcWSProxy = srcStringBuilder.ToString();

              sw.Close();

              // assembly compilation.

              CompilerParameters cp = new CompilerParameters();

              cp.ReferencedAssemblies.Add("System.dll");

              cp.ReferencedAssemblies.Add("System.Xml.dll");

              cp.ReferencedAssemblies.Add("System.Web.Services.dll");

              cp.GenerateExecutable = false;

              cp.GenerateInMemory = true;

              cp.IncludeDebugInformation = false;

              ICodeCompiler icc = cscp.CreateCompiler();

              CompilerResults cr = icc.CompileAssemblyFromSource(cp, _srcWSProxy);

              if(cr.Errors.Count > 0)

                   throw new Exception(string.Format("Build failed: {0} errors",

                        cr.Errors.Count));

              return _ass = cr.CompiledAssembly;

         }

         public object CreateInstance(string objTypeName)

         {

              Type t = _ass.GetType("WebServiceProxy.WebServiceAccessor" + "." + objTypeName);

              return Activator.CreateInstance(t);

         }

 

         public object Invoke(object obj, string methodName, params object[] args)

         {

              MethodInfo mi = obj.GetType().GetMethod(methodName);

              return mi.Invoke(obj, args);

         }

     }

}

内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值