欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Hibernate使用中防止SQL注入的几种方案

程序员文章站 2023-08-13 21:50:21
hibernate使用中防止sql注入的几种方案 hibernate是一个开放源代码的对象关系映射框架,它对jdbc进行了非常轻量级的对象封装,使得java程序员可以随心...

hibernate使用中防止sql注入的几种方案

hibernate是一个开放源代码的对象关系映射框架,它对jdbc进行了非常轻量级的对象封装,使得java程序员可以随心所欲的使用对象编程思维来操纵数据库。

    在获取便利操作的同时,sql的注入问题也值得我们的密切注意,下面就来谈谈几点如何避免sql注入:

    1.对参数名称进行绑定:

query query=session.createquery(hql);
query.setstring(“name”,name);

    2.对参数位置进行邦定:

query query=session.createquery(hql);
query.setstring(0,name1);
query.setstring(1,name2);
...

    3.setparameter()方法:

query query=session.createquery(hql); 
query.setparameter(“name”,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);
}

  输出结果:''

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!