热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaSQL注入的原理和用法

本篇内容介绍了“JavaSQL注入的原理和用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如

本篇内容介绍了“Java SQL注入的原理和用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

目录
  • 一,SQL注入

    • –1,需求

    • –2,测试

    • –3,总结

  • 二,练习PreparedStatement

    • –1,需求

    • –2,测试

    • –3,制作工具类

  • 三,HTML

    • –1,概述

    • –2,入门案例

    • –3,使用工具

    • –4,测试

  • 四,测试常用标签

    一,SQL注入

    –1,需求

    –1,利用jdbc查询user的信息,如果信息正确就登录,否则提示错误

    –1,创建user表,指定字段id name password,并添加数据

    –2,通过jdbc查询user表的数据,根据用户名和密码查

    –2,测试

    package cn.tedu.test;
    import java.sql.*;
    import java.util.Scanner;
    //测试 用户的查询
    /*
    create table user(
    	id int primary key auto_increment,
    	name varchar(20),
    	password varchar(20)
    )
    insert into user values(null,'jack','123');
    insert into user values(null,'rose','123');
     */
    public class Test3 {
        public static void main(String[] args) throws Exception {
    //       method();  //模拟登录
    //       method2(); //暴露问题
           method3(); //解决SQL攻击问题
        }
        private static void method3() throws Exception {
            //1,注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2,获取连接
            String url ="jdbc:mysql:///cgb2105?characterEncoding=utf8" ;//简写形式
            Connection  conn = DriverManager.getConnection(url, "root", "root");
            //3,获取传输器
    //        Statement st = conn.createStatement();
    //        String sql = "select * from user where name='"+a+"' and password='"+b+"'";
            String a = new Scanner(System.in).nextLine();//用户名
            String b = new Scanner(System.in).nextLine();//密码
            //SQL骨架,?叫占位符
            String sql = "select * from user where name=? and password=?";
            //PreparedStatement把SQL骨架和参数分开发送给数据的
            //解决了SQL攻击问题:jack'# 只是把#当做普通文本而不是注释符号
            PreparedStatement ps = conn.prepareStatement(sql);
            //给SQL设置参数--指定要给哪个问号赋啥值
            ps.setString(1,a);
            ps.setString(2,b);
            //4,执行SQL,根据用户名和密码查库
            ResultSet rs = ps.executeQuery();
            //5,解析结果集
            if( rs.next() ){ //如果查到了数据next()返回true,就可以登录
                System.out.println("登录成功~~");
            }else{
                System.out.println("登录失败!");
            }
            //6,释放资源
            rs.close();//释放结果集
            ps.close();//释放传输器
            conn.close();//释放连接
        }
        private static void method2() throws Exception {
            //1,注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2,获取连接
            String url ="jdbc:mysql:///cgb2105?characterEncoding=utf8" ;//简写形式
            Connection  conn = DriverManager.getConnection(url, "root", "root");
            //3,获取传输器
            Statement st = conn.createStatement();
            //4,执行SQL,根据用户名和密码查库
            String a = new Scanner(System.in).nextLine();//用户名
            String b = new Scanner(System.in).nextLine();//密码
    //SQl攻击/SQL注入问题:本质是因为用户输入的特殊符号造成SQL语义发生了改变。jack'#
            String sql = "select * from user where name='"+a+"' and password='"+b+"'";
            ResultSet rs = st.executeQuery(sql);
            //5,解析结果集
            if( rs.next() ){ //如果查到了数据next()返回true,就可以登录
                System.out.println("登录成功~~");
            }else{
                System.out.println("登录失败!");
            }
            //6,释放资源
            rs.close();//释放结果集
            st.close();//释放传输器
            conn.close();//释放连接
        }
        //模拟登录:根据用户名和密码查询user表
        private static void method() throws Exception {
            //1,注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2,获取连接
    //String url ="jdbc:mysql://localhost:3306/cgb2105?characterEncoding=utf8" ;
    String url ="jdbc:mysql:///cgb2105?characterEncoding=utf8" ;//简写形式
            Connection  conn = DriverManager.getConnection(url, "root", "root");
            //3,获取传输器
            Statement st = conn.createStatement();
            //4,执行SQL,根据用户名和密码查库
            String sql = "select * from user where name='jack' and password='123'";
            ResultSet rs = st.executeQuery(sql);
            //5,解析结果集
            if( rs.next() ){ //如果查到了数据next()返回true,就可以登录
                System.out.println("登录成功~~");
            }else{
                System.out.println("登录失败!");
            }
            //6,释放资源
            rs.close();//释放结果集
            st.close();//释放传输器
            conn.close();//释放连接
        }
    }

    –3,总结

    SQL 攻击发生的现象是:用户输入了一些SQL中的特殊字符,#表示注释

    Statement工具:无法避免SQL注入问题,而且SQL复杂需要自己拼接参数,低效

    PreparedStatement工具:避免了SQL攻击的问题,SQL简单,高效

    –SQL简单,先把SQL骨架发给数据库,再把参数发给数据库。用?代替参数的位置叫占位符

    二,练习PreparedStatement

    –1,需求

    删除id=1的用户信息

    –2,测试

    package cn.tedu.test;
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.SQLException;
    public class Test4 {
        public static void main(String[] args) {
            Connection conn = null;
            PreparedStatement ps= null;
            try{
                //调用工具类,,,获取连接
                conn = JDBCUtils.getConnection();
                //3,获取传输器 ,利用高级的工具类执行SQL
                //先执行SQL骨架
                String sql = "delete from user where id=?";
                ps = conn.prepareStatement(sql);
                //给第一个问号,设置值是1
                ps.setInt(1,1);
                //4,执行SQL
                int rows = ps.executeUpdate();
                System.out.println("删除成功");
            }catch (Exception e){
                System.out.println("执行失败...");
            }finally{ //最终一定会被执行的
                //5,释放资源
               JDBCUtils.close(null,ps,conn);
            }
        }
    }

    –3,制作工具类

    package cn.tedu.test;
    import java.sql.*;
    //提取jdbc重复的代码,提高复用性
    public class JDBCUtils {
        /**
         * 释放资源
         * @param rs 结果集
         * @param ps 传输器
         * @param conn 数据库的连接
         */
        final static public void close(ResultSet rs, PreparedStatement ps, Connection conn){
            if(rs != null){//防止空指针异常
                try {
                    rs.close();
                } catch (SQLException throwables) {
                    System.out.println("执行失败...");//项目上线后的
                    //throwables.printStackTrace();//程序调试阶段
                }
            }
            if(ps != null){//防止空指针异常
                try {
                    ps.close();
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            }
            if(conn != null) {//防止空指针异常
                try {
                    conn.close();
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            }
        }
        /**
         * 获取和数据库的连接
         * */
        static public Connection getConnection() throws Exception {
            //1,注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2,获取连接
            String url="jdbc:mysql:///cgb2105?characterEncoding=utf8";
            Connection conn = DriverManager.getConnection(url,"root","root");
            return conn;
        }
    }

    三,HTML

    –1,概述

    是超文本标记语言,是指可以在网页中加入比文本更丰富的内容。标记有很多,要写开始标记和结果标记

    –2,入门案例

    html>
    	
    		
    	
    	
    		test......
    	
    

    –3,使用工具

    Java SQL注入的原理和用法

    Java SQL注入的原理和用法

    Java SQL注入的原理和用法

    Java SQL注入的原理和用法

     
      
    	 
    		 
    		 
    	
    	 
    		
    		你好      html~
    		你好html~ 
       你       好html~   你好html~ 你好html~ 你好html~

    –4,测试

    Java SQL注入的原理和用法

    四,测试常用标签

    
    	
    		
    		
    	
    	
    		
    			

     1级标签 

     2级标签 

     3级标签 

     4级标签 
     5级标签 
     6级标签 
    1.  全国新冠疫苗接种剂次超13亿 
    2.  刘伯明神七出舱曾遇险情 
    3.  中国成功发射风云三号05星 
    4.  江苏女生中考757分8门满分 
    点我 北京市富婆通讯录

    18518518515

    123

    123

    123

    123

    123

    123

    123

    123

    123

    123

    点我,回到顶部               男   杨幂         

    “Java SQL注入的原理和用法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程笔记网站,小编将为大家输出更多高质量的实用文章!


    推荐阅读
    • Java太阳系小游戏分析和源码详解
      本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
    • Java容器中的compareto方法排序原理解析
      本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
    • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
    • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
    • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
    • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
    • JavaSE笔试题-接口、抽象类、多态等问题解答
      本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
    • Spring特性实现接口多类的动态调用详解
      本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
    • importjava.util.ArrayList;publicclassPageIndex{privateintpageSize;每页要显示的行privateintpageNum ... [详细]
    • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
    • MyBatis多表查询与动态SQL使用
      本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
    • r2dbc配置多数据源
      R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
    • Python SQLAlchemy库的使用方法详解
      本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
    • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
      本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
    • 本文介绍了Java中Hashtable的clear()方法,该方法用于清除和移除指定Hashtable中的所有键。通过示例程序演示了clear()方法的使用。 ... [详细]
    author-avatar
    唯爱辉1314
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有