利用.net反射动态调用指定程序集的中的方法

      每个.net程序集除了代码外都额外包含了元数据。元数据包括了程序集本身的信息,比如版本号,引用了什么程序集,所有类型的信息,包括其方法、属性、字段。使用.net反射,可以在运行时读取这些信息,并且可以动态地调用方法。
       项目快完了,终于有时间来写blog了,,
       做一个动态调用程序集指定方法的例子。
       项目1(Demo)中包含一个Test类,Test类中写了一个getList方法,这个方法返回的数据是手工加入的。源代码如下:
        项目1
  using System;
  using System.Collections.Generic;
  using System.Text;
  using System.Data;

  namespace Demo
  {
      public class Test
      {
          public DataTable getList(string id)
          {
              DataTable dt = new DataTable();
              dt.Columns.Add(new DataColumn(“id”));
              dt.Columns.Add(new DataColumn(“name”));
              dt.Columns.Add(new DataColumn(“sex”));
              DataRow dr = dt.NewRow();
              dr[“id”] = “zl”;
              dr[“name”] = “张铃”;
              dr[“sex”] = “男”;
              dt.Rows.Add(dr);
              dr = dt.NewRow();
              dr[“id”] = “zl”;
              dr[“name”] = “李四”;
              dr[“sex”] = “女”;
              dt.Rows.Add(dr);
              return dt;
          }
      }
  }

       项目2(DemoXml)中包含一个Test类,Test类中写了一个getList方法,这个方法返回的数据是从数据库读取的。源代码如下:
  项目2
  using System;
  using System.Collections.Generic;
  using System.Text;
  using System.Data;
  using System.Data.SqlClient;
  using System.Xml;
  namespace DemoXml
  {
      public class Test
      {
          private SqlConnection cn;
          public DataTable getList(string id)
          {
              try
              {
                  cn = new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings[“pubs”]);
                  SqlCommand cmd = new SqlCommand();
                  SqlDataAdapter da = new SqlDataAdapter();
                  cmd.CommandText = “SELECT au_id as id,au_lname as name,au_fname as sex from authors”;
                  cmd.CommandType = CommandType.Text;
                  cmd.Connection = cn;
                  da.SelectCommand = cmd;
                  DataTable dt = new DataTable();
                  da.Fill(dt);
                  return dt;
              }
              catch (Exception ex)
              {
                  throw new ApplicationException(“出现异常:”+ex.Message+ex.StackTrace);
              }
              finally
              {
                  cn.Close();
                  cn = null;
              }
          }
      }
  }

        项目3(WebDemo)中演示动态用指定程序集中getList的方法返回一个DataTable,用一个gridview显示其返回的数据。
  调用演示
  using System;
  using System.Data;
  using System.Configuration;
  using System.Web;
  using System.Web.Security;
  using System.Web.UI;
  using System.Web.UI.WebControls;
  using System.Web.UI.WebControls.WebParts;
  using System.Web.UI.HtmlControls;
  using System.Reflection;

  public partial class _Default : System.Web.UI.Page
  {
      protected void Page_Load(object sender, EventArgs e)
      {
          if (!IsPostBack)
          {
              DropBind();
          }
      }
      数据初始化,可配置在web.config文件中#region 数据初始化,可配置在web.config文件中
      public void DropBind()
      {
          DataTable dt = new DataTable();
          dt.Columns.Add(new DataColumn(“name”));
          dt.Columns.Add(new DataColumn(“filepath”));
          DataRow dr = dt.NewRow();
          dr[“name”] = “加载自己定义数据”;
          dr[“filepath”] = Server.MapPath(@”FilesDemo.dll”);
          dt.Rows.Add(dr);
          dr = dt.NewRow();
          dr[“name”] = “加载xml数据”;
          dr[“filepath”] = Server.MapPath(@”FilesDemoXml.dll”);
          dt.Rows.Add(dr);
          this.DropDownList1.DataSource = dt;
          this.DropDownList1.DataTextField = “name”;
          this.DropDownList1.DataValueField = “filepath”;
          this.DropDownList1.DataBind();
      }
      #endregion

      protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
      {
          try
          {
              //读取选择指定的dll文件
              string strPath = (sender as DropDownList).SelectedValue.Trim();
              string NameSpace = this.DropDownList1.SelectedIndex == 0 ? “Demo.Test” : “DemoXml.Test”;
              //加载指定的程序集之内存中
              Assembly assembly = Assembly.LoadFrom(strPath);
              //返加程序集中的一个指定的对象,哪果是返回所有对象,则用GetTypes()返回一个Typt对象的数组.
              Type T = assembly.GetType(NameSpace);
              //返回方法信息(公共方法)
              MethodInfo mi = T.GetMethod(“getList”);
              //根据前面type类型创建一个对象
              object o = Activator.CreateInstance(T);
              //参数
              object[] par = new object[] { “E01” };
              //通过MethodInfo对象的Invoke方法,动态调用此方法,参数o是因为实例方法需要在调用时有一个实例存在
              DataTable dt = (DataTable)mi.Invoke(o, par);
              this.GridView1.DataSource = dt;
              this.GridView1.DataBind();
          }
          catch (Exception ex)
          {
              //do Exception
          }
      }
  }

         通过Assembly.LoadFrom方法返回的Assembly对象,可以读取其中的元数据。其中的GetType会返回一个用于表示指定程序集的type对象(读取程序集中的所有类型用GetTypes会返回一个type对象的数组)。
         返回方法信息(公共方法)
         MethodInfo mi = T.GetMethod(“getList”);
         根据前面type类型创建一个对象
         object o = Activator.CreateInstance(T);
         参数
         object[] par = new object[] { “E01” };
         通过MethodInfo对象的Invoke方法,动态调用此方法,参数o是因为实例方法需要在调用时有一个实例存在.
         DataTable dt = (DataTable)mi.Invoke(o, par);
         调用返回的数据显示列表中。
  示例下载:http://www.cnblogs.com/Files/NetFans/Solution2.rar

转载请注明:代码学堂>编程开发 > ASP.NET > 利用.net反射动态调用指定程序集的中的方法

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!10210454@qq.com
2. 本站不保证所提供所有下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理,有奖励!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有RB奖励和额外RMB收入!

磊宇堂正在使用的服务器 维护管理由磊宇云服务器提供支持

磊宇堂 » 利用.net反射动态调用指定程序集的中的方法

提供最优质的资源集合

立即查看 了解详情