Hibernate一些防止SQL注入的方式


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM