SQL 审计 Mybatis-Flex

        Mybatis-Flex 是一个优雅的 Mybatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper^ 亮点 帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。

        Mybatis-Flex v1.0.5 主要是添加了功能强大的 SQL 审计 功能。SQL 审计是一项非常重要的工作,是企业数据安全体系的重要组成部分,通过 SQL 审计功能为数据库请求进行全程记录,为事后追溯溯源提供了一手的信息,同时可以通过可以对恶意访问及时警告管理员,为防护策略优化提供数据支撑。

同时、提供 SQL 访问日志长期存储,满足等保合规要求

        Mybatis-Flex 会提供一个 SQL 审计后台管理系统 Mybatis-Flex-Admin,通过后台系统,我们可以监控每个 sql 的执行时间,哪个用户执行的,通过哪个网页访问造成的 SQL 执行;这样,我们可以对一些恶意的 sql 全面了解,同时可以帮助我们发现慢 sql 并进行优化。后续还会提供许多比如 慢 SQL 短信警告、SQL 熔断等功能

public class HelloWorld {
    public static void main(String... args) {

        //创建数据源
        HikariDataSource dataSource = new HikariDataSource();
        dataSource.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/mybatis-flex");
        dataSource.setUsername("username");
        dataSource.setPassword("password");

        //配置数据源
        MybatisFlexBootstrap.getInstance()
                .setDatasource(dataSource)
                .addMapper(AccountMapper.class)
                .start();


        //示例1:查询 id=1 条数据
        Account account = MybatisFlexBootstrap.getInstance()
                .execute(AccountMapper.class, mapper ->
                        mapper.selectOneById(1)
                );
        
        //示例2:或者使用 Db + Row 查询
        String sql = "select * from tb_account where age > ?";
        List<Row> rows = Db.selectListBySql(sql, 18);
    }
}

Mybatis-Flex:SQL 审计 | Mybatis-Flex

更多文档:

猜你喜欢

转载自blog.csdn.net/ejinxian/article/details/129868224