L'utilisation de JRBeanCollectionDataSource n'est pas la bonne façon d'utiliser le connecteur MongoDB. Jetez un œil à ce test fourni avec la source du connecteur Jaspersoft MongoDB :
MongoDbDatasource/src/test/java/com/jaspersoft/mongodb/ReportTest.java
Le connecteur binaire et la source se trouvent sur la page du projet .
Pour garder cette réponse autonome, voici un extrait de code montrant comment remplir un rapport MongoDB. C'est un extrait modifié du fichier que j'ai mentionné ci-dessus.
String mongoURI = "mongodb://bdsandbox6:27017/test";
MongoDbConnection connection = null;
Map<String, Object> parameters = new HashMap<String, Object>();
try {
connection = new MongoDbConnection(mongoURI, null, null);
parameters.put(MongoDbDataSource.CONNECTION, connection);
File jasperFile;
jasperFile = new File("MongoDbReport.jasper");
JasperCompileManager.compileReportToFile("MongoDbReport.jrxml", "MongoDbReport.jasper");
JasperFillManager.fillReportToFile("MongoDbReport.jasper", parameters);
JasperExportManager.exportReportToPdfFile("MongoDbReport.jrprint");
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (connection != null) {
connection.close();
}
}