C#动态编译

        /// <summary>
        /// 根据Net字符串,动态编译DLL文件
        /// </summary>
        /// <param name="dllFileName">DLL文件名称</param>
        /// <param name="source">Net字符串</param>
        /// <param name="message">消息</param>
        /// <returns>是否成功</returns>
        public static int CompilerDllFileBySource(string dllFileName, string source, ref string message)
        {
            string[] sources = new string[1];
            sources[0] = source;

            return SystemHelper.CompilerDllFileBySource(dllFileName, sources, ref message);
        }

        /// <summary>
        /// 根据Net字符串,动态编译DLL文件
        /// </summary>
        /// <param name="dllFileName">DLL文件名称</param>
        /// <param name="sources">Net字符串数组</param>
        /// <param name="message">消息</param>
        /// <returns>是否成功</returns>
        public static int CompilerDllFileBySource(string dllFileName, string[] sources, ref string message)
        {
            int returnInt = -1;

            Microsoft.CSharp.CSharpCodeProvider objCSharpCodeProvider = new Microsoft.CSharp.CSharpCodeProvider();
            ICodeCompiler objICodeCompiler = objCSharpCodeProvider.CreateCompiler();
            CompilerParameters objCompilerParameters = new CompilerParameters();
            objCompilerParameters.ReferencedAssemblies.Add("System.dll");
            objCompilerParameters.GenerateExecutable = false;
            objCompilerParameters.GenerateInMemory = true;
            objCompilerParameters.OutputAssembly = dllFileName;

            //编译字符串
            CompilerResults cr = objICodeCompiler.CompileAssemblyFromSourceBatch(objCompilerParameters, sources);

            //判断是否成功
            if (cr.Errors.HasErrors)
            {
                returnInt = -1;

                StringBuilder errors = new StringBuilder();
                foreach (CompilerError ce in cr.Errors)
                {
                    if (errors.Length > 0)
                    {
                        errors.Append(Environment.NewLine + ce.ErrorText);
                    }
                    else
                    {
                        errors.Append(ce.ErrorText);
                    }
                }
            }
            else
            {
                returnInt = 1;
                message = "";
            }

            return returnInt;
        }

        /// <summary>
        /// 根据Net文件,动态编译DLL文件
        /// </summary>
        /// <param name="dllFileName">DLL文件名称</param>
        /// <param name="fileName">Net文件名称</param>
        /// <param name="message">消息</param>
        /// <returns>是否成功</returns>
        public static int CompilerDllFileByFile(string dllFileName, string fileName, ref string message)
        {
            string[] fileNames = new string[1];
            fileNames[0] = fileName;

            return SystemHelper.CompilerDllFileByFile(dllFileName, fileNames, ref message);
        }

        /// <summary>
        /// 根据Net文件,动态编译DLL文件
        /// </summary>
        /// <param name="dllFileName">DLL文件名称</param>
        /// <param name="fileNames">Net文件名称数组</param>
        /// <param name="message">消息</param>
        /// <returns>是否成功</returns>
        public static int CompilerDllFileByFile(string dllFileName, string[] fileNames, ref string message)
        {
            int returnInt = -1;

            Microsoft.CSharp.CSharpCodeProvider objCSharpCodeProvider = new Microsoft.CSharp.CSharpCodeProvider();
            ICodeCompiler objICodeCompiler = objCSharpCodeProvider.CreateCompiler();
            CompilerParameters objCompilerParameters = new CompilerParameters();
            objCompilerParameters.ReferencedAssemblies.Add("System.dll");
            objCompilerParameters.GenerateExecutable = false;
            objCompilerParameters.GenerateInMemory = true;
            objCompilerParameters.OutputAssembly = dllFileName;

            //编译字符串
            CompilerResults cr = objICodeCompiler.CompileAssemblyFromFileBatch(objCompilerParameters, fileNames);

            //判断是否成功
            if (cr.Errors.HasErrors)
            {
                returnInt = -1;

                StringBuilder errors = new StringBuilder();
                foreach (CompilerError ce in cr.Errors)
                {
                    if (errors.Length > 0)
                    {
                        errors.Append(Environment.NewLine + ce.ErrorText);
                    }
                    else
                    {
                        errors.Append(ce.ErrorText);
                    }
                }
            }
            else
            {
                returnInt = 1;
                message = "";
            }

            return returnInt;
        }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# 动态编译可以让我们在运行时动态编译代码并生成可执行程序集。这在某些情况下非常有用,例如在我们需要根据用户输入来生成代码的情况下。 以下是一个简单的示例,演示了如何使用 C# 动态编译: ```csharp using System; using System.CodeDom.Compiler; using System.Reflection; using Microsoft.CSharp; class Program { static void Main() { // 定义代码片段 string code = @" using System; namespace MyNamespace { public class MyClass { public static void SayHello() { Console.WriteLine(""Hello, World!""); } } }"; // 编译代码 CSharpCodeProvider provider = new CSharpCodeProvider(); CompilerParameters parameters = new CompilerParameters(); parameters.GenerateInMemory = true; CompilerResults results = provider.CompileAssemblyFromSource(parameters, code); // 检查是否有编译错误 if (results.Errors.HasErrors) { Console.WriteLine("编译错误:"); foreach (CompilerError error in results.Errors) { Console.WriteLine(error.ErrorText); } return; } // 从程序集中获取类和方法 Assembly assembly = results.CompiledAssembly; Type type = assembly.GetType("MyNamespace.MyClass"); MethodInfo method = type.GetMethod("SayHello"); // 调用方法 method.Invoke(null, null); } } ``` 该示例中,我们首先定义了一个字符串变量 `code`,其中包含要编译的代码片段。然后使用 `CSharpCodeProvider` 类创建一个编译器实例,并使用 `CompileAssemblyFromSource` 方法将代码编译成程序集。我们还需要指定 `CompilerParameters`,其中包括一些编译选项,例如是否将程序集生成到内存中。 如果编译成功,则可以通过程序集中的 `GetType` 方法获取类的类型,并使用 `GetMethod` 方法获取类中的方法。最后,使用 `Invoke` 方法调用该方法,并在控制台输出 "Hello, World!"。 需要注意的是,动态编译可能存在安全性问题,因为用户可以利用它来注入恶意代码。因此,在使用动态编译时,需要进行严格的输入验证和安全性检查。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值