在spring cloud 框架中添加过滤器,对json格式的请求数据进行过滤进行防sql注入(只对一层json有效)

本文介绍了一种在请求数据中使用JSON格式时防止SQL注入的方法。通过对JSON参数进行特殊字符和敏感字符串的替换,实现对SQL注入攻击的有效防御。文章详细展示了如何在Java环境中实现这一过滤机制。

请求数据json只能是一层,多层嵌套的json数据不支持,有大牛知道怎么解决的可以提出来,谢谢

 

/**

* 对请求json参数进行防sql注入过滤

*

* @create 2018-12-18

*/

@Component

@Slf4j

@RefreshScope

public class SqLinjectionFilter extends ZuulFilter {

@Override

public String filterType() {

return "pre";

}

 

@Override

public int filterOrder() {

return -3;

}

 

@Override

public boolean shouldFilter() {

return true;

}

 

@Override

public Object run() {

RequestContext ctx = RequestContext.getCurrentContext();

HttpServletRequest request = ctx.getRequest();

try {

InputStream in = ctx.getRequest().getInputStream();

String body = StreamUtils.copyToString(in, Charset.forName("UTF-8"));

Map<String, Object> stringObjectMap = cleanXSS(body);

JSONObject json = JSONObject.fromObject(stringObjectMap);

String newBody = json.toString();

final byte[] reqBodyBytes = newBody.getBytes();

ctx.setRequest(new HttpServletRequestWrapper(request){

@Override

public ServletInputStream getInputStream() throws IOException {

return new ServletInputStreamWrapper(reqBodyBytes);

}

@Override

public int getContentLength() {

return reqBodyBytes.length;

}

@Override

public long getContentLengthLong() {

return reqBodyBytes.length;

}

});

} catch (IOException e) {

e.printStackTrace();

}

return null;

}

private Map<String, Object> cleanXSS(String value) {

//You'll need to remove the spaces from the html entities below

value = value.replaceAll("<", "& lt;").replaceAll(">", "& gt;");

value = value.replaceAll("\\(", "& #40;").replaceAll("\\)", "& #41;");

value = value.replaceAll("'", "& #39;");

value = value.replaceAll("eval\\((.*)\\)", "");

value = value.replaceAll("[\\\"\\\'][\\s]*javascript:(.*)[\\\"\\\']", "\"\"");

value = value.replaceAll("script", "");

value = value.replaceAll("[*]","["+"*]");

value = value.replaceAll("[+]","["+"+]");

value = value.replaceAll("[?]","["+"?]");

 

String badStr = "'|and|exec|execute|insert|select|delete|update|count|drop|%|chr|mid|master|truncate|" +

"char|declare|sitename|net user|xp_cmdshell|;|or|+|,|like'|and|exec|execute|insert|create|drop|" +

"table|from|grant|use|group_concat|column_name|" +

"information_schema.columns|table_schema|union|where|select|delete|update|order|by|count|" +

"chr|mid|master|truncate|char|declare|or|;|--|,|like|//|/|%|#";

JSONObject json = JSONObject.fromObject(value);

String[] badStrs = badStr.split("\\|");

Map<String, Object> map=json;

Map<String, Object> mapjson=new HashMap<>();

for (Map.Entry<String, Object> entry : map.entrySet()) {

String value1 = (String) entry.getValue();

for (String bad :badStrs){

if (value1.equalsIgnoreCase(bad)){

value1="forbid";

mapjson.put(entry.getKey(),value1);

break;

}else {

mapjson.put(entry.getKey(),entry.getValue());

}

}

}

return mapjson;

}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值