2017-05-20 4 views
0

この問題の解決に役立つことがあります。私はBOサーバーに接続しようとしており、接続してパラメータを設定した後、pdf形式でエクスポートしようとしています。 ReportClientDocumentの以下Java CrystalReportsの問題:一時ファイルを作成できません:パラメータ値がありません.-エラーコード:-2147215357

IInfoObject infoObject = (IInfoObject) infoObjects.get(0); 

      IReportAppFactory reportAppFactory = (IReportAppFactory) enterpriseSession.getService("RASReportFactory");   
      //Open the report file   
      return reportAppFactory.openDocument(infoObject, OpenReportOptions._refreshRepositoryObjects , Locale.ENGLISH); 

を取得するために使用されるコードの下

パラメータを設定するために使用されるコードです:以下

 ParameterFieldController paramFieldController = clientDoc.getDataDefController().getParameterFieldController();    
     Fields parameterFields = clientDoc.getDataDefinition().getParameterFields(); 
     for (int i = 0; i < parameterFields.size(); i++) { 
      IParameterField paramToChange = (IParameterField) parameterFields.getField(i); 
      String field = paramToChange.getName();    

      if (field.substring(0, 1).equalsIgnoreCase("@")) 
       field = field.substring(1); 
      else if (field.substring(0, 2).equalsIgnoreCase("V_")) 
       field = field.substring(2); 
      String value = null; 
      System.out.println("Fields: :i= "+i+ " "+field); 
      if (reportParam.get(field) != null) 
       value = reportParam.get(field).toString();     
      else 
       value = ""; 


      IParameterFieldDiscreteValue newDiscreteValue = new ParameterFieldDiscreteValue(); 
      System.out.println("Setting Parameter value :i= "+i+ " "+value); 
      newDiscreteValue.setValue(value); 
      ParameterField tempParam = new ParameterField(); 
      paramToChange.copyTo(tempParam, false); 
      if (tempParam.getCurrentValues().size() > 0) 
       tempParam.getCurrentValues().remove(0); 
      tempParam.getCurrentValues().add(0, newDiscreteValue); 
      paramFieldController.modify(paramToChange, tempParam); 

は、私は、さまざまなメソッドを呼び出す午前ためであります順番に。

ReportClientDocument clientDoc = getDocumentFromInfoStore(enterpriseSession、crInfo.getReportsFolder()、reportName);

if (!setDatabaseLocation(crInfo,clientDoc, sUserId, isILIReport)) { 
     ReportLogger.debug("Error generating " + rptFileName + " report.<br/>" 
       + "Report Following Error Details<br/>" 
       + "Database Location could not be set."); 
     return null; 
    } else if (!setReportParameters(clientDoc,reportParam)) { 
     ReportLogger.debug("Error generating " + rptFileName + " report.<br/>" 
       + "Report Following Error Details<br>" 
       + "Database Parameters could not be set."); 
     return null; 
    } else if (!setFilter(reportParam, clientDoc)) { 
     ReportLogger.debug("Error generating " + rptFileName + " report.<br/>" 
       + "Report Following Error Details<br>" 
       + "Database Filters could not be set."); 
     return null; 
    }else if (!setFooterCriteriaInfo(reportParam, clientDoc)) { 
     ReportLogger.debug("Error generating " + rptFileName + " report.<br/>" 
       + "Report Following Error Details<br>" 
       + "Database Filters could not be set."); 
     return null; 
    }else if (!setSorting(reportParam, clientDoc)) { 
     ReportLogger.debug("Error generating " + rptFileName + " report.<br/>" 
       + "Report Following Error Details<br>" 
       + "Database Filters could not be set."); 
     return null; 
    } 

私は間違ったことをしていますが、あなたの助けは本当に感謝です! -前もって感謝します。

答えて

0

最後に私はこの問題を解決しました。 PrameterFieldオブジェクトのディープコピーで問題が解決すること、すなわち真のcopyToメソッドのブール値を変更することにより、

IParameterFieldDiscreteValue newDiscreteValue = new ParameterFieldDiscreteValue(); 
      System.out.println("Setting Parameter value :i= "+i+ " "+value); 
      newDiscreteValue.setValue(value); 
      ParameterField tempParam = new ParameterField(); 
      **paramToChange.copyTo(tempParam, true);** 

を次のようにし、ソリューションです。すなわち、paramToChange.copyTo(tempParam、true);

関連する問題