【JOOQ】解决模糊查询的sql注入问题

解决jooq中模糊查询的sql注入问题

jooq模糊查询

单字符通配符:_

多字符通配符:%

name like '%xiaoming%'

在java中的使用:

// Java中
Tables.TABLE_NAME.FIELD_NAME.like("%"+name+"%");

传入的name中如果包含%或者_  就会产生sql注入问题,这个时候我们希望对传入的包含通配符的字符进行转义后再匹配,但JOOQ中不会自动转义。我们可以采取显式定义转义字符 

用一个字符在通配符之间标识前边为普通字符,

 示例(使用!字符标识):

name like '%xiao!%ming%' escape '!'

在Java中

// 处理传入的参数,将参数中的%、_、和!分别替换为!%、!_、!!
  public static String replaceLike(String str){
        if(StringUtils.isNotBlank(str)){
            if(str.contains("!") || str.contains("%") || str.contains("_")){
                String replaceStr = str.replace("!", "!!");
                String replaceStr2 = replaceStr.replace("%", "!%");
                String replaceStr3 = replaceStr2.replace("_", "!_");
                return replaceStr3;
            }
        }
        return str;
    }


// 将参数传入方法进行处理
String str = replaceLike(name);

处理完再进行模糊查询
Tables TABLE_NAME.FIELD_NAME.like("%"+str+"%",'!');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值