java JDBC (二) 防止注入/参数化
package cn.sasa.demo2; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner; public class JDBCDemo2 { public static void main(String[] args) throws ClassNotFoundException, SQLException {
/**
* 防止注入攻击 /参数化查询
* Statement 接口 有个子接口 PreparedStatement --sql预编译
*
*/
String name = "";
String pwd = "";
Scanner sc = new Scanner(System.in);
System.out.println("用户名");
name = sc.nextLine();
System.out.println("密码");
pwd = sc.nextLine(); Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://192.168.0.207:3306/mydb", "root", "XXXXXXXX1"); //String sql = " SELECT * FROM `user` WHERE name='"+ name +"' and pwd='"+ pwd +"' ";
//Statement state = conn.createStatement();
//ResultSet rsSet = state.executeQuery(sql); String sql = " SELECT * FROM `user` WHERE name=? and pwd=? ";
PreparedStatement pstate = conn.prepareStatement(sql);
pstate.setObject(1, name);
pstate.setObject(2, pwd);
ResultSet rsSet = pstate.executeQuery(); while(rsSet.next()) {
System.out.println(rsSet.getString("name"));
} rsSet.close();
//state.close();
pstate.cancel();
conn.close(); } }
java JDBC (二) 防止注入/参数化的更多相关文章
- Java JDBC下执行SQL的不同方式、参数化预编译防御
		
相关学习资料 http://zh.wikipedia.org/wiki/Java数据库连接 http://lavasoft.blog.51cto.com/62575/20588 http://blog ...
 - Java JDBC的基础知识(二)
		
在我的上一篇Java JDBC的基础知识(一)中,最后演示的代码在关闭资源的时候,仅仅用了try/catch语句,这里是有很大的隐患的.在程序创建连接之后,如果不进行关闭,会消耗更多的资源.创建连接之 ...
 - Java JDBC学习实战(二): 管理结果集
		
在我的上一篇博客<Java JDBC学习实战(一): JDBC的基本操作>中,简要介绍了jdbc开发的基本流程,并详细介绍了Statement和PreparedStatement的使用:利 ...
 - Java EE : 二、图解 Cookie(小甜饼)
		
目录 Java EE : 一.图解Http协议 Java EE : 二.图解 Cookie(小甜饼) Java EE : 三.图解Session(会话) 概述 一.概述 二.详细介绍Cookie 传输 ...
 - Java JDBC批处理插入数据操作
		
在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...
 - Java JDBC批处理插入数据操作(转)
		
在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...
 - Java进阶(二十五)Java连接mysql数据库(底层实现)
		
Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...
 - java JDBC编程流程步骤
		
JDBC:Java Data Base Connection JDBC是用于运行sql语句并从数据库中获取新新的java API. JDBC是用来(让我们的程序)通过网络来操作数据库的,作用非常重要: ...
 - Sql 注入详解:宽字节注入+二次注入
		
sql注入漏洞 原理:由于开发者在编写操作数据库代码时,直接将外部可控参数拼接到sql 语句中,没有经过任何过滤就直接放入到数据库引擎中执行了. 攻击方式: (1) 权限较大时,直接写入webshel ...
 
随机推荐
- audio video 控制播放和停止
			
<audio id="audio" src="waring.wav" preload="auto" controls loop> ...
 - maven一键部署tomcat war包
			
1.环境如下 eclipse.apache-maven-3.0.5.apache-tomcat-7.0.39 2.配置如下 apache-tomcat-7.0.39配置C:\Program Files ...
 - Git常见报错及解决方案
			
报错一: You have not concluded your merge (MERGE_HEAD exists). Please, commit your changes before you c ...
 - eBGP&iBGP 总结
			
3.4 BGP 原文地址:http://mp.weixin.qq.com/s?src=3×tamp=1500043305&ver=1&signature=XwiIVV ...
 - Ubuntu14.04下安装MATLAB后,通过命令行打开其图形界面
			
安装的是Matlab R2017a,使用的是默认安装目录,安装在目录/usr/local/MATLAB/R2017a/bin中.那么安装完成之后系统不会给Matlab添加系统路径,只有把终端切换到安装 ...
 - [UI] 03 - Bootstrap: component
			
前言 一.框架体系 Bootstrap 是基于 HTML5.CSS3.JAVASCRIPT. 教程被分为: Bootstrap 基本结构. Bootstrap CSS. Bootstrap 布局组件 ...
 - 5 -- Hibernate的基本用法 --5 2 持久化对象的状态
			
1. 瞬态 : 对象有new操作符创建,且尚未与Hibernate Session关联的对象被认为处于瞬态.瞬态对象不会被持久化到数据库中,也不会被赋予持久化标识.如果程序中失去了瞬态对象的引用,瞬态 ...
 - c++中SetEvent和ResetEvent的使用
			
关于事件 事件(Event)是WIN32提供的最灵活的线程间同步方式,事件可以处于激发状态(signaled or true)或未激发状态(unsignal or false).根据状态变迁方式的不同 ...
 - nginx 动静分离(相同URL)
			
#报表 location ~* /(report)/ { if ($request_uri !~* .*(jd|taobao|operator).* ){ proxy_pass http://tweb ...
 - 第9天 py就业班基础02.01-02
			
明天该看就业班的02 03字串符 2018-4-21 10:47:34 数据类型 py自动给数据分类型 2018-4-21 10:55:05 input使用 定义一个变量 然后input输给变 ...