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

  • 相关阅读:
    八个方便C#开发的省时的国外工具
    从babel-polyfill的一个坑而起
    Universal Link
    微信机器人
    微信手记
    Elasticsearch手记
    小游戏引擎手记
    【数学基础】3D数学基础-左右手坐标系
    【linux基础】linux误改sudoers权限之后的恢复及配置sudoers
    【c/c++基础】struct/typedef struct的用法详解总结
  • 原文地址:https://www.cnblogs.com/jyh317/p/4325965.html
Copyright © 2020-2023  润新知