java mysql 防注入_防止sql注入方法 如何防止java中将MySQL的数据库验证密码加上 ' or '1'= '1 就可以出现万能密码 的PreparedStatement...

packagecom.swift;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.SQLException;public classLoginJDBC$PreparedStatement2 {public static voidmain(String[] args) {

User userSwift=new User("zhangsan","123456");if(login(userSwift)) {

System.out.println("账号密码正确,登陆成功");

}else{

System.out.println("登陆失败");

}

}private static booleanlogin(User userSwift) {

Connection conn=null;

PreparedStatement ps=null;

ResultSet rs=null;try{//1、装载驱动

Class.forName("com.mysql.jdbc.Driver");

}catch(ClassNotFoundException e) {

e.printStackTrace();

}try{//2、链接数据库,使用com.mysql.jdbc.Connection包会出错

conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/sw_database?user=root&password=root");//3、创建连接语句

ps=conn.prepareStatement("select * from sw_user where username=? and password=?");

ps.setString(1, userSwift.getUsername());

ps.setString(2, userSwift.getPassword());//4、执行SQL语句获得结果集

rs=ps.executeQuery();if(rs.next()) {return true;

}

}catch(SQLException e) {

e.printStackTrace();

}finally{//关闭结果集

try{if(rs!=null) {

rs.close();

}

}catch(SQLException e) {//TODO Auto-generated catch block

e.printStackTrace();

}//关闭连接语句

try{if(ps!=null) {

ps.close();

}

}catch(SQLException e) {//TODO Auto-generated catch block

e.printStackTrace();

}//关闭数据库连接

try{if(conn!=null) {

conn.close();

}

}catch(SQLException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

}return false;

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值