sql注入

  1. 基于mybatis的预编译

“$”无法防止sql注入,”#”可以防止,因为“#“使用了预编译机制,而”$”未使用。

当出现表名之类的,需要预编译的参数时,则需要使用“$“,此时应注意表名不得从页面(客户端)传入,最好在java代码中自行获取。

当出现“in“关键词的时候,配合”#”使用应记得参数此时为多个,而非一个。

2.直接基于PreparedStatement的预编译

 A: if (elements[k][1].equalsIgnoreCase(DataType.Float)) {

                       stmt.setFloat(k + 1, Float.parseFloat(elements[k][0]));

                   }

B:String m_Device7300ASAM_SQL = "select * from tab_multipolar_shelf where device_id=?";

   String[][] elements ={{device_id,"STRING"}};

    return (Map)JdbcUtils.query(m_DeviceInfo_SQL_Prepared,elements)

代替

String m_Device7300ASAM_SQL = "select * from tab_multipolar_shelf where device_id='";

    return DataSetBean.getRecord(this.m_Device7300ASAM_SQL + device_id + "'");

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值