zoukankan      html  css  js  c++  java
  • JDBC的SQL注入漏洞

    1.1 JDBC的SQL注入漏洞

    1.1.1 什么是SQL注入漏洞

    在早期互联网上SQL注入漏洞普遍存在。有一个网站,用户需要进行注册,用户注册以后根据用户名和密码完成登录。假设现在用户名已经被其他人知道了,但是其他人不知道你的密码,也可以登录到网站上进行相应的操作。

    1.1.2 演示SQL注入漏洞

    1.1.2.1 基本登录功能实现

    package com.xdr630.jdbc.demo4;
    
    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.Statement;
    
    import com.xdr630.jdbc.utils.JDBCUtils;
    
    public class UserDao {
    	/**
    	 * 完成用户登录的方法:解决SQL注入漏洞
    	 * @param username
    	 * @param password
    	 * @return
    	 */
    public boolean login(String username,String password){
    		
    		Connection conn = null;
    		Statement stmt = null;
    		ResultSet rs = null;
    		// 定义一个变量:
    		boolean flag = false;
    		try{
    			// 获得连接:
    			conn = JDBCUtils.getConnection();
    			// 完成登录功能:
    			// 创建执行SQL语句的对象:
    			stmt = conn.createStatement();
    			// 编写SQL语句:
    			String sql = "select * from user where username = '"+username+"' and password = '"+password+"'";
    			// 执行SQL:
    			rs = stmt.executeQuery(sql);
    			if(rs.next()){
    				// 说明根据用户名和密码可以查询到这条记录
    				flag = true;
    			}
    		}catch(Exception e){
    			e.printStackTrace();
    		}finally{
    			JDBCUtils.release(rs, stmt, conn);
    		}
    		return flag;
    	}
    
    }
    

    1.1.2.2 演示SQL注入漏洞

    输入用户名
    aaa’ or ‘1=1 密码随意
    
    aaa’ --      密码随意
    
    • 已知表数据:
      在这里插入图片描述
    package com.xdr630.jdbc.demo4;
    
    import org.junit.Test;
    	
    /**
     * SQL注入的漏洞
     * @author xdr
     *
     */
    public class JDBCDemo4 {
    	
    	@Test
    	/**
    	 * SQL注入漏洞演示
    	 */
    	public void demo1() {
    		UserDao userDao = new UserDao();
    //		boolean flag = userDao.login("aaa' or '1=1", "12345678");
    		boolean flag = userDao.login("aaa' -- ","asdfgh");
    		if(flag) {
    			System.out.println("登录成功!");
    		}
    		else {
    			System.out.println("登录失败!");
    		}
    	}
    }
    
    
    • 控制台输出:
      在这里插入图片描述

    本文来自博客园,作者:兮动人,转载请注明原文链接:https://www.cnblogs.com/xdr630/p/15254873.html

  • 相关阅读:
    dedecmsV5.7和discuz!X3.4整合之后免激活登陆
    dedecms织梦文章微信分享带缩略图与简介
    关于PHP的mkdir函数
    关于discuz的fap.php 漏洞问题
    discuzX3.4安装之后,没有任何样式怎么办?
    阿里云 RDS for MySQL支持什么引擎
    PHP随机生成要求位数个字符(大小写字母+数字)
    PHP json_decode为什么将json字符串转成数组是对象格式?
    PHP实用的功能函数
    css实现三角形图标
  • 原文地址:https://www.cnblogs.com/xdr630/p/15254873.html
Copyright © 2011-2022 走看看