栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java-转义字符串以防止SQL注入

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java-转义字符串以防止SQL注入

PreparedStatement是可行的方法,因为它们使SQL注入成为不可能。这是一个简单的示例,将用户的输入作为参数:

public insertUser(String name, String email) {   Connection conn = null;   PreparedStatement stmt = null;   try {      conn = setupTheDatabaseConnectionSomehow();      stmt = conn.prepareStatement("INSERT INTO person (name, email) values (?, ?)");      stmt.setString(1, name);      stmt.setString(2, email);      stmt.executeUpdate();   }   finally {      try {         if (stmt != null) { stmt.close(); }      }      catch (Exception e) {         // log this error      }      try {         if (conn != null) { conn.close(); }      }      catch (Exception e) {         // log this error      }   }}

无论名称和电子邮件中包含什么字符,这些字符都将直接放置在数据库中。它们不会以任何方式影响INSERT语句。

对于不同的数据类型,有不同的设置方法-使用哪种方法取决于数据库字段是什么。例如,如果数据库中有一个INTEGER列,则应使用一个

setInt
方法。 PreparedStatement文档列出了可用于设置和获取数据的所有不同方法。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/414869.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号