国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

利用.net反射動態調用指定程序集的中的方法

2019-11-18 16:45:16
字體:
來源:轉載
供稿:網友

    每個.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.survivalescaperooms.com/Files/NetFans/Solution2.rar


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 柞水县| 拉孜县| 淮南市| 西盟| 城口县| 铁岭县| 托里县| 莱西市| 深圳市| 阜康市| 右玉县| 平阴县| 永德县| 临潭县| 青铜峡市| 宁城县| 贺兰县| 渝北区| 鹤岗市| 碌曲县| 甘南县| 同仁县| 淳安县| 博罗县| 吐鲁番市| 宣化县| 五常市| 大足县| 桂东县| 洪江市| 贵州省| 红原县| 仙桃市| 济阳县| 交口县| 静宁县| 寿阳县| 关岭| 五台县| 浦江县| 茂名市|