JDBC_入门及注入问题
.JDBC基本概念:
java database Connectivity java数据库连接,java语言操作数据库
本质:
官方定义的一套操作所有关系型数据库的规则,即接口。
各个数据库厂商实现这套接口,提供数据库驱动jar包。
我们是以这套接口编程,真正执行的代码是驱动jar包中的实现类
.快速入门:
步骤:
.导入驱动jar包
.注册驱动
Class.
.获取数据库连接对象 Connection
.定义sql
.获取执行sql语句的对象 Statement
.执行sql,接收返回结果
.处理结果
.释放资源
.JDBC各个接口和类的详解:
.DriverManager:驱动管理对象
功能:
.注册驱动:
Class.forName("com.mysql.jdbc.Driver");
mysql5之后驱动jar包可以省略注册驱动的步骤
.获取数据库连接
static Connection getConnection(String url, String user, String password)
参数:
url:指定连接的路径
jdbc:mysql://ip地址(域名):端口号/数据库名称
user:用户名
password:密码
.connection: 数据库连接对象
.功能:
.获取执行sql的对象
Statement createStatement()
PreparedStatement prepareStatement(String sql)
.管理事务:
开启事务:void setAutoCommit(boolean autoCommit):调用该方法设置参数为false,即开启事务
提交事务:void commit()
回滚事务:void rollback()
.statement: 指定sql的对象
.boolean execute(String sql):可以执行任意sql 了解
.int executeUpdate(String sql):执行DML(insert update delete)语句、DDL(create alter drop)语句
.ResultSet executeQuery(String sql):执行DML(insert update delete)语句、DDL(create alter drop)语句
返回值:影响的行数
.ResultSet:结果集对象
.boolean next():游标向下移动一行
.getXxx():获取数据 Xxx:数据类型
.getXxx(参数):
int:列的编号从1开始
String:列名称
注意:
使用步骤:
.游标向下移动一行
.判断是否有数据 使用next的返回值判断
.获取数据
.PreparedStatement:执行sql的对象
.SQL注入问题:在拼接sql时有一些sql特殊关键字参与拼接回造成安全性问题
.输入用户名随意,输入密码:a' or 'a' = 'a
.解决sql注入问题:使用PreparedStatement对象来解决
.预编译的sql:参数使用?作为占位符
.步骤:
.写sql语句使用占位符
.Connection.prepareStatement(String sql)
.给?赋值:.setXxx(参数1,参数2)
参数1:?的位置
参数2:?的值
.执行sql不需要参数
*/
import java.sql.*;
public class JDBC_Test01 {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
.注册驱动
Class.forName("com.mysql.jdbc.Driver");
.获取数据库连接对象 Connection
Connection connection /day01","root","ROOT");
.定义sql
String sql = "show tables";
.获取执行sql语句的对象 Statement
Statement statement = connection.createStatement();
.执行sql,接收返回结果
int count = statement.executeUpdate(sql);
.处理结果
System.out.println(count);
.释放资源
connection.close();
JDBC_入门及注入问题的更多相关文章
- 初级安全入门——XSS注入的原理与利用
XSS的简单介绍 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets,CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者 ...
- 初级安全入门——SQL注入的原理与利用
工具简介 SQLMAP: 一个开放源码的渗透测试工具,它可以自动探测和利用SQL注入漏洞来接管数据库服务器.它配备了一个强大的探测引擎,为最终渗透测试人员提供很多强大的功能,可以拖库,可以访问底层的文 ...
- 基础Web漏洞-SQL注入入门(手工注入篇)
一.什么是SQL注入 SQL是操作数据库数据的结构化查询语言,网页的应用数据和后台数据库中的数据进行交互时会采用SQL.而SQL注入是将Web页面的原URL.表单域或数据包输入的参数,修改拼接成SQ ...
- Spring入门-----------------属性注入和对象注入
属性注入即通过setter方法注入bean的属性或依赖对象. 属性注入使用<property>元素,使用name属性指定bean的属性的名称,value属性或<value>子节 ...
- PHP代码审计入门(SQL注入漏洞挖掘基础)
SQL注入漏洞 SQL注入经常出现在登陆页面.和获取HTTP头(user-agent/client-ip等).订单处理等地方,因为这几个地方是业务相对复杂的,登陆页面的注入现在来说大多数是发生在HTT ...
- CTF SSTI(服务器模板注入)
目录 基础 一些姿势 1.config 2.self 3.[].() 3.url_for, g, request, namespace, lipsum, range, session, dict, g ...
- LDAP注入介绍
LDAP注入介绍 一. 前言 前些日子在看 OWASP TOP 10 时看到了对LDAP注入攻击的介绍,对此产生了兴趣,在网上经过一番搜索之后找到了构成本文主要来源的资料,整理出来分享给大家. 二. ...
- 紧跟时代步伐,让我们拥抱MVC 3
作为一个开发者,我们不希望技术很快的更新,这是因为我们还没有完全掌握原来技术的基础上,又要掌握新的技术,作为天天忙忙碌碌的程序员,我们不希望还要额外的时间来学习,尤其是当我们的年龄,逐渐的变大的时候, ...
- 4.JDBC编程
01.JDBC_Java程序和MySQL的关系: 1).Java程序跟其它MySQL客户端一样,就是一个"客户端",用于"封装SQL语句"并发送给MyS ...
随机推荐
- 通过adb命令查看SN、CID码等信息
用ADB命令来查看自己手机的相关硬件以及其他的参数信息,相信许多机友已经早已查看过,而新入门感兴趣的机友可以尝试一下. 运用这些ADB命令可以很直观的查看到你手机上的硬件与软件方面的详细信息. 下 ...
- 2019杭电多校第四场hdu6621 K-th Closest Distance(二分答案+主席树)
K-th Closest Distance 题目传送门 解题思路 二分答案+主席树 先建主席树,然后二分答案mid,在l和r的区间内查询[p-mid, p+mid]的范围内的数的个数,如果大于k则说明 ...
- 2019牛客多校第二场A-Eddy Walker
Eddy Walker 题目传送门 解题思路 因为走过所有的点就会停下来,又因为是从0出发的,所以当n>1时,在0停下来的概率为0,其他的为1/(n-1); 代码如下 #include < ...
- 拾遗:Docker 基本应用
https://wiki.gentoo.org/wiki/Docker 检查内核内核选项 exec /usr/share/docker/contrib/check-config.sh 使用 btrfs ...
- node express 会话管理中间件 --- cookie-parser
本文转载自:https://www.cnblogs.com/bq-med/p/8995100.html cookie是由服务器发送给客户端(浏览器)的小量信息. 我们知道,平时上网时都是使用无状态的H ...
- 实验报告&总结
Java实验报告 班级计科二班 学号 20188429 姓名 罗璇哲 完成时间 评分等级 实验三 String类的应用 一. 实验目的 (1) 掌握类String类的使用: (2) 学会使用JDK帮助 ...
- 年底了,该跳槽了,全套高级Java面试题及答案整理~
又到年底了,又是一轮跳槽季 城外的人想进去,城里的人想出来 为什么离职? 马云说过,要么工资低,要么受了委屈 我想大多数人离职是这个原因 出来混的,跳槽也都是为了更好的生活 干技术的,工资都是跳出来的 ...
- VUE 中 使用 iview Form组件 enter键防止页面刷新
<Form :label-width="100" inline label-position='left' @keydown.native.enter.prevent =&q ...
- projects
layout title project 开源项目 本文记录我收藏的开源项目
- ORACLE check view
select owner as schema_name, view_name from sys.all_views where VIEW_NAME like 'P%' order by ...