jdbc怎么防止sql注入?

JDBC-防止sql注入漏洞

使用预编译可有效防止sql的注入漏洞。

原因:在statement中不能够有效的防止sql的注入漏洞,在于用户传入参数的时候可能会传入一些特殊字符,比如单引号' ' ,或者是-- 这种会影响到我们的sql语句.

所以使用预编译中的占位符,也就是?,可以有效的处理这一问题.

public class Prepared {
@Test
public void papa(){
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try{
//注册驱动
// Class.forName(com.MysqL.jdbc.Driver);
//建立连接
// conn = DriverManager.getConnection(jdbc:MysqL://localhost:3306/user,root,dumy);
conn =JDBCUtils.getConnection();
//编写sql代码
//String sql = select * from administer where id = ?;
String sql = select * from administer where username = ? and password =?;
//预编译
pstmt = conn.prepareStatement(sql);
//给? 赋值
pstmt.setString(1, ddd);
pstmt.setString(2, 123);
rs= pstmt.executeQuery();
while(rs.next()){
System.out.println(登录成功);
}
}catch(Exception e){
e.printstacktrace();
}finally{
JDBCUtils.release(pstmt, conn, rs);
}
}
}

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...