Hibernate在操作數據庫的時候,有以下幾種方法來防止SQL注入,大家可以一起學習一下。
1.對參數名稱進行綁定:
2.對參數位置進行邦定:
3.setParameter()方法:
4.setProperties()方法:
5.HQL拼接方法,這種方式是最常用,而且容易忽視且容易被注入的,通常做法就是對參數的特殊字符進行過濾,推薦大家使用 Spring工具包的StringEscapeUtils.escapeSql()方法對參數進行過濾:
public static void main(String[] args) { String str = StringEscapeUtils.escapeSql("'"); System.out.println(str); }
輸出結果:''
總之防止SQL注入的方式的原理就是轉義特殊符號。最近項目中經常直接使用HQL拼接,所以需要使用StringEscapeUtils.escapeSql來防止SQL注入,很方便吧。