zoukankan      html  css  js  c++  java
  • 托管dll动态加载

    using System;
    using System.Collections.Generic;
    using System.Text;
    using System.Runtime.InteropServices;

    namespace WebService1
    {
        /// <summary>
        /// DllInvoke 的摘要说明
        /// </summary>
        public class DllInvoke
        {
            [DllImport("kernel32.dll")]
            private extern static IntPtr LoadLibrary(string path);

            [DllImport("kernel32.dll")]
            private extern static IntPtr GetProcAddress(IntPtr lib, string funcName);

            [DllImport("kernel32.dll")]
            private extern static bool FreeLibrary(IntPtr lib);
          

            private IntPtr hLib;       
            public DllInvoke(String DLLPath)
            {
                hLib = LoadLibrary(DLLPath);
            }

            ~DllInvoke()
            {
                FreeLibrary(hLib);           
            }

            //将要执行的函数转换为委托
            public Delegate Invoke (string APIName,Type t) 
            {
                IntPtr api = GetProcAddress(hLib, APIName);
                return (Delegate)Marshal.GetDelegateForFunctionPointer(api, t);
            }

        }
    }

    上面类的主要作用是通过api动态找到要加载的托管dll函数,返回函数的代理(指针),C++里面好像也可以这么加载,下次在c++中实验下

    下面代码是调用:

    public class Test
    {
     public delegate int SetDBConfig(string IpAddress, string DBname, string UserName, string psw);//通过委托来声明方法

     DllInvoke dll;
            SetDBConfig setDBConfig;

     public Test
     {
         dll = new DllInvoke(Server.MapPath(@"~/bin/dllagain.dll")); //实例化dll
                setDBConfig = (SetDBConfig)dll.Invoke("SetDBConfig", typeof(SetDBConfig));           
     }

     public static void Main()
     {
                setDBConfig(string IpAddress, string DBname, string UserName, string psw);//此处进行调用
     }
    }

    转自:http://zhouweigang01.blog.163.com/blog/static/934090720095492458949/

  • 相关阅读:
    [Node.js] CommonJS Modules
    [Node.js] npm init && npm install
    [AngularJS] Hijacking Existing HTML Attributes with Angular Directives
    [Node.js] Level 7. Persisting Data
    [Express] Level 5: Route file
    [Express] Level 5: Route Instance -- refactor the code
    [Express] Level 4: Body-parser -- Delete
    [Express] Level 4: Body-parser -- Post
    [Express] Level 3: Massaging User Data
    [Express] Level 3: Reading from the URL
  • 原文地址:https://www.cnblogs.com/zhangpengshou/p/1699836.html
Copyright © 2011-2022 走看看