码迷,mamicode.com
首页 > 数据库 > 详细

Hibernate一些防止SQL注入的方式

时间:2015-03-10 15:21:19      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:

  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注入,很方便吧。

Hibernate一些防止SQL注入的方式

标签:

原文地址:http://www.cnblogs.com/jyh317/p/4325965.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!