分享
 
 
 

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

王朝c#·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

每个.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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有