统一数据源设置
默认导入的示例中心采用的是JDBC的数据源,每个页面查看我们都需要根据当前数据库的设置调整数据库的链接:
如果你觉得麻烦,希望统一设定数据源,则可以下载另外一个示例中心数据包
利用这个数据包我们可以在项目中添加一个名称为SampleCenterDatasource的Java类,大致代码为:
package test;
import java.sql.SQLException;
import java.util.Properties;
import javax.sql.DataSource;
import org.apache.commons.dbcp2.BasicDataSource;
import org.apache.commons.dbcp2.BasicDataSourceFactory;
import com.basksoft.report.core.definition.datasource.DatasourceDefinition;
import com.basksoft.report.core.model.datasource.BuildinDatasourceProvider;
import com.basksoft.report.core.model.datasource.DatasourceWrapper;
public class SampleCenterDatasource implements BuildinDatasourceProvider {
private static Properties properties = new Properties();
@Override
public DataSource buildDatasource(DatasourceDefinition def) {
// 加载DBCP配置文件
DataSource dataSource = null;
properties.put("username", "root");
properties.put("password", "helpdesk");
properties.put("driverClassName", "com.mysql.jdbc.Driver");
properties
.put("url",
"jdbc:mysql://localhost:3306/baskreportsample?useUnicode=true&characterEncoding=UTF-8&useSSL=false");
try {
dataSource = BasicDataSourceFactory.createDataSource(properties);
} catch (Exception e) {
e.printStackTrace();
}
return dataSource;
}
@Override
public void destroyDatasource(DatasourceWrapper ds) {
if (ds == null)
return;
DataSource datasource = ds.getDatasource();
if (datasource instanceof BasicDataSource) {
BasicDataSource basicDatasource = (BasicDataSource) datasource;
try {
basicDatasource.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
通过这个类我们为baskreport定义一个业务数据统一的数据源。根据自己项目情况调整相关参数设置。
之后我们利用ServiceLoader的扩展机制在META-INF的services目录中添加一个文件名为:com.basksoft.report.core.model.datasource.BuildinDatasourceProvider的文件
内容为:
test.SampleCenterDatasource
之后再在资源树中新建sample-center目录,再导入名称为sample-center-datasource-provider的示例文件。这些示例中的文件就不再需要调整数据源配置。
相关技术原理参考: