zoukankan      html  css  js  c++  java
  • 使用Gird++打印出现“Retrieving the COM class factory for component with CLSID”的解决办法

    我们的接口需要返回一个gird++生成PDF文件的二进制数据,在本地测试都很好,发布到服务器上一直出现“Retrieving the COM class factory for component with CLSID”问题。

    最后终于找到问题的解决方法:把程序池里的Enable 32-Bit Applications 设置为True

     (ps: 服务器上要安装Grid++的客户端)

    另外 附上代码

        public struct MatchFieldPairType
        {
            public IGRField grField;
            public int MatchColumnIndex;
        }
        public class PrintHelper
        {
            // 将 DataTable 的数据转储到 Grid++Report 的数据集中
            public static void FillRecordToReport(IGridppReport Report, DataTable dt)
            {
                MatchFieldPairType[] MatchFieldPairs = new MatchFieldPairType[Math.Min(Report.DetailGrid.Recordset.Fields.Count, dt.Columns.Count)];
    
                //根据字段名称与列名称进行匹配,建立DataReader字段与Grid++Report记录集的字段之间的对应关系
                int MatchFieldCount = 0;
                for (int i = 0; i < dt.Columns.Count; ++i)
                {
                    foreach (IGRField fld in Report.DetailGrid.Recordset.Fields)
                    {
                        if (String.Compare(fld.Name, dt.Columns[i].ColumnName, true) == 0)
                        {
                            MatchFieldPairs[MatchFieldCount].grField = fld;
                            MatchFieldPairs[MatchFieldCount].MatchColumnIndex = i;
                            ++MatchFieldCount;
                            break;
                        }
                    }
                }
    
    
                // 将 DataTable 中的每一条记录转储到 Grid++Report 的数据集中去
                Report.PrepareRecordset();
                foreach (DataRow dr in dt.Rows)
                {
                    //Report.PrepareRecordset();
                    Report.DetailGrid.Recordset.Append();
    
                    for (int i = 0; i < MatchFieldCount; ++i)
                    {
                        if (!dr.IsNull(MatchFieldPairs[i].MatchColumnIndex))
                            MatchFieldPairs[i].grField.Value = dr[MatchFieldPairs[i].MatchColumnIndex];
                    }
                    Report.DetailGrid.Recordset.Post();
                }
            }
    }
                      

                      var report = new GridppReport();
                      report.LoadFromFile(Server.MapPath("~/eExpressReportbulk.grf"));

                     PrintHelper.FillRecordToReport(report, printDt);
                                string fileName = ConfigurationSettings.AppSettings["pdfPath"] + shipmentNumber + ".pdf";
                                //直接调用ExportDirect方法执行导出任务
                                report.ExportDirect(GRExportType.gretPDF, fileName, false, false);
    
                                FileStream stream = new FileStream(fileName, FileMode.OpenOrCreate);
                                byte[] buffer = new byte[stream.Length];
                                stream.Read(buffer, 0, Convert.ToInt32(stream.Length));
                                stream.Close();

    附上Grid++破解dll:  下载

      

    依旧做最初的自己,坦然做最真实的自己,努力做最好的自己。你若盛开,清风自来。
  • 相关阅读:
    Java——多线程之方法详解
    Java——深入理解Java异常体系
    Java——Java代码的执行顺序
    Java——抽象类与接口的前世今生
    存储系列之 LUN 和 LVM
    存储系列之 RAID技术原理简介
    存储系列之 硬盘接口与SCSI总线协议
    存储系列之 介质(软盘、硬盘、固态)和磁盘寻址
    Redis设计原理简介
    MySQL InnoDB索引介绍以及在线添加索引实例分析
  • 原文地址:https://www.cnblogs.com/seejoy/p/5775387.html
Copyright © 2011-2022 走看看