zoukankan      html  css  js  c++  java
  • 解决springboot druid 数据库批量更新错误问题

    原文:https://www.2cto.com/kf/201712/706399.html

    springboot druid 数据库多SQL错误multi-statement not allow

    Caused by: java.sql.SQLException: sql injection violation, multi-statement not allowcom.alibaba.druid.wall.WallFilter.check(WallFilter.java:714) atcom.alibaba.druid.wall.WallFilter.connection_prepareStatement(WallFilter.java:240) atcom.alibaba.druid.filter.FilterChainImpl.connection_prepareStatement(FilterChainImpl.java:448) atcom.alibaba.druid.filter.FilterAdapter.connection_prepareStatement(FilterAdapter.java:928) atcom.alibaba.druid.filter.FilterEventAdapter.connection_prepareStatement(FilterEventAdapter.java:122) atcom.alibaba.druid.filter.FilterChainImpl.connection_prepareStatement(FilterChainImpl.java:448) atcom.alibaba.druid.proxy.jdbc.ConnectionProxyImpl.prepareStatement(ConnectionProxyImpl.java:342) atcom.alibaba.druid.pool.DruidPooledConnection.prepareStatement(DruidPooledConnection.java:318)

    解决方案:

    1、配置数据库连接,添加allowMultiQueries=true

    jdbc.url=jdbc:mysql://192.168.11.107:3306/alarm_db?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8

    2、如果需要开启wall监控,同时允许multiStatementAllow,就不要在application.yml中配置filter,自己定义

    //使用连接池dataSource

    @Bean

    @ConfigurationProperties(prefix = "spring.datasource")

    public DataSource dataSource() {

    DruidDataSource druidDataSource = new DruidDataSource();

    List filterList=new ArrayList<>();

    filterList.add(wallFilter());

    druidDataSource.setProxyFilters(filterList);

    return druidDataSource;

    }

    @Bean

    public WallFilter wallFilter(){

    WallFilter wallFilter=new WallFilter();

    wallFilter.setConfig(wallConfig());

    return wallFilter;

    }

    @Bean

    public WallConfig wallConfig(){

    WallConfig config =new WallConfig();

    config.setMultiStatementAllow(true);//允许一次执行多条语句

    config.setNoneBaseStatementAllow(true);//允许非基本语句的其他语句

    return config;

    }

  • 相关阅读:
    【原】 POJ 1012 Joseph 约瑟夫 解题报告
    【原】 POJ 1001 Exponentiation 大整数乘法 解题报告
    POJ——1517
    毕业了,校园里走走看看——华中科技大学
    毕业答辩后
    CV编程常用的获取鼠标圈定区域的方法
    送走了GB
    POJ——2546
    奥巴马在YY21#524
    POJ——3517
  • 原文地址:https://www.cnblogs.com/shihaiming/p/10344762.html
Copyright © 2011-2022 走看看