打印

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

利用.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(@"files\demo.dll");
   dt.rows.add(dr);
   dr = dt.newrow();
   dr["name"] = "加载xml数据";
   dr["filepath"] = server.mappath(@"files\demoxml.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

TOP

返回顶部
AYBlue

Processed in 0.052791 second(s), 7 queries.

当前时区 GMT+8, 现在时间是 2009-1-10 10:49 京ICP备06054220号

清除 Cookies - 联系我们 - 163K.com - Archiver - WAP