Hibernate在操作数据库的时候,有以下几种方法来防止SQL注入,大家可以一起学习一下。
1.对参数名称进行绑定:
Query query=session.createQuery(hql); query.setString(“username”,name);
2.对参数位置进行邦定:
Query query=session.createQuery(hql); query.setString(0,username1); query.setString(1,username2);
3.setParameter()方法:
Query query=session.createQuery(hql); query.setParameter(“username”,name,Hibernate.STRING);
4.setProperties()方法:
Entity entity=new Entity(); entity.setXx(“xx”); entity.setYy(100); Query query=session.createQuery(“from Entity c where c.xx=:xx and c.yy=:yy ”); query.setProperties(entity);
5.HQL拼接方法,这种方式是最常用,而且容易忽视且容易被注入的,通常做法就是对参数的特殊字符进行过滤,推荐大家使用 Spring工具包的StringEscapeUtils.escapeSql()方法对参数进行过滤:
public static void main(String[] args) { String str = StringEscapeUtils.escapeSql("‘"); System.out.println(str); }
输出结果:‘‘
总之防止SQL注入的方式的原理就是转义特殊符号。最近项目中经常直接使用HQL拼接,所以需要使用StringEscapeUtils.escapeSql来防止SQL注入,很方便吧。
时间: 2024-11-10 15:10:23