统一数据源设置

默认导入的示例中心采用的是JDBC的数据源,每个页面查看我们都需要根据当前数据库的设置调整数据库的链接:

image-20220412133915269

如果你觉得麻烦,希望统一设定数据源,则可以下载另外一个示例中心数据包

利用这个数据包我们可以在项目中添加一个名称为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的文件

image-20220621142346739

内容为:

test.SampleCenterDatasource

之后再在资源树中新建sample-center目录,再导入名称为sample-center-datasource-provider的示例文件。这些示例中的文件就不再需要调整数据源配置。

相关技术原理参考:

results matching ""

    No results matching ""