动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ ASP.NET技巧 ]的信息

本月文章推荐
.ASP.NET中实现模板页.
.投票结果的图片进度条显示.
.用asp.net还原与恢复sqlserver数.
..NET程序调用SSIS中的DTS包.
.如何改变asp.net项目名称.
.DataGrid和DataList中CommandBut.
.在ASP.NET Atlas中调用Web Servi.
.FCKeditor2.2+ASP.NET2.0不完全攻.
.Asp.net中使用GDI+繪製圖形.
.关闭按钮点击事件的捕捉 .
.一个高效判断字符串是否全数字的.
..NET中如何在调用COM时得到返回参.
.从asp.net页面发送电子邮件 .
.aspx页面中标题单点解决方案.
.利用OpenSmtp.Net发送需要smtp验.
.ASP.NET 2.0 中的母版页详解.
.关于Asp.net页面Page_Load被执行.
..NET环境下几种不同的邮件发送解.
.ASP.NET中17种正则表达式.
.如何实现用ODBC连接MySQL和ASP.N.

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

发表日期:2007-1-8 |


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

上一篇:ASP.NET随机码生成示例 人气:4112
下一篇:RSS 文档中 language 标签中的可选值 人气:3204
浏览全部Asp.Net 2.0的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-4 LPLY CMS 网站管理系统 v5.0
2008-9-4 缤纷互动视频交友 v3.01.902
2008-9-4 ADN视频收藏专家 v3.0 bulid 080
2008-9-4 天空网络电影系统SKYUC v2.5.6 简
2008-9-4 Web Wiz Rich Text Editor(文本编
2008-9-4 幻影动漫网视频系统(Ppdong) v1.
2008-9-4 乐维电脑在线DIY配置系统
2008-9-4 老樊文章管理系统SQL版
2008-9-4 ASP.NET 2.53 缩略图水印组件源码
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵