package com.basic.security.utils; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; public class SqlSplit { static char[] startEndQuotes = new char[]{'\'', '"', '`'}; static Set tableNameList = new HashSet<>(); static { tableNameList.addAll(Arrays.asList(new String[]{ "base_setting", "business", "business_apply_device", "business_person", "cluster", "cluster_node", "cluster_setting", "confirm", "device", "guest", "hint_door_access", "hint_recognize_message", "hint_sign_up", "id_card", "identity", "Log", "OfficeDevice", "org", "outdoor", "person", "person_identity", "temporary_person", "time", "user", "dbtablepersons", "dbTables", "visit" })); } public static boolean containsTable(String sql) { String tableName = getTableName(sql).trim(); if (tableNameList.contains(tableName)) { return true; } return false; } public static String getTableName(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("insert")) { return getTableNameFromInsertSql(sql); } if (sql.startsWith("delete")) { return getTableNameFromDeleteSql(sql); } if (sql.startsWith("update")) { return getTableNameFromUpdateSql(sql); } return sql; } public static boolean isInsert(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("insert")) { return true; } return false; } public static boolean isDelete(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("delete")) { return true; } return false; } public static Map getRowDataMap(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("insert")) { return insertToMap(sql); } if (sql.startsWith("delete")) { return deleteToMap(sql); } if (sql.startsWith("update")) { return updateToMap(sql); } return new HashMap<>(); } public static String getRowSqlOperateType(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("insert")) { return "insert"; } if (sql.startsWith("delete")) { return "delete"; } if (sql.startsWith("update")) { return "update"; } return ""; } public static boolean isUpdate(String sql) { sql = sql.toLowerCase(); sql = sql.trim(); if (sql.startsWith("update")) { return true; } return false; } public static String getTableNameFromDeleteSql(String sql) { String tableName = ""; sql = sql.replace("\n", " "); sql = sql.replace("\r\n", " "); sql = sql.replace(" ", " ") .replace(" ", " ").replace(" ", " ").replace(" ", " ").replace(" ", " ") ; sql = sql.substring(0, sql.toLowerCase().indexOf(" where ")).trim().split(" ")[2]; tableName = sql.substring(sql.indexOf(" ")).trim(); return tableName; } public static String getTableNameFromUpdateSql(String sql) { String tableName = ""; sql = sql.replace("\n", " "); sql = sql.replace("\r\n", " "); sql = sql.replace(" ", " ") .replace(" ", " ").replace(" ", " ").replace(" ", " ").replace(" ", " ") ; sql = sql.substring(0, sql.toLowerCase().indexOf(" set ")).trim().split(" ")[1]; int index = sql.indexOf(" "); if (index != -1) { tableName = sql.substring(index); } tableName = tableName.trim(); return tableName; } public static String getTableNameFromInsertSql(String sql) { sql = sql.toLowerCase(); sql = sql.replace("insert or replace into", "insert into"); String tableName = ""; sql = sql.replace("\n", " "); sql = sql.replace("\r\n", " "); sql = sql.replace(" ", " "); sql = sql.substring(sql.toLowerCase().indexOf("into ") + "into ".length()).trim(); tableName = sql.substring(0, sql.indexOf("(")).trim(); return tableName; } public static Map deleteToMap(String sql) { Map columnMap = new HashMap<>(); sql = sql.replace("\r\n", " ").replace("\n", " "); sql = sql.replace(" = ", " ") .replace("= ", " ") .replace("= ", " ") .replace("= ", " ") .replace(" =", " ") .replace(" =", " ") .replace(" =", " ") ; String[] sqlParts = sql.split(" "); for (String sqlPart : sqlParts) { if (sqlPart.contains("=")) { sqlPart = sqlPart.trim(); columnMap.put(sqlPart.split("=")[0], sqlPart.split("=")[1]); } } System1.out.println(columnMap); return columnMap; } public static Map updateToMap(String sql) { Map columnMap = new HashMap<>(); sql = sql.replace("\r\n", " ").replace("\n", " "); sql = sql.replace(" = ", " ") .replace("= ", " ") .replace("= ", " ") .replace("= ", " ") .replace(" =", " ") .replace(" =", " ") .replace(" =", " ") ; String[] sqlParts = sql.split(" "); for (String sqlPart : sqlParts) { if (sqlPart.contains("=")) { sqlPart = sqlPart.trim(); columnMap.put(sqlPart.split("=")[0], sqlPart.split("=")[1]); } } // System1.out.println(columnMap); return columnMap; } public static Map insertToMap(String sql) { Map columnMap = new HashMap<>(); String columnNameSql = sql; columnNameSql = sql.substring(sql.indexOf("(")); columnNameSql = columnNameSql.substring(0, columnNameSql.indexOf(")")); columnNameSql = columnNameSql.replace("(", ""); columnNameSql = columnNameSql.replace(")", ""); String[] columnNames = columnNameSql.split(","); for (int i = 0; i < columnNames.length; i++) { columnNames[i] = columnNames[i].trim(); } String valueSql = sql.substring(sql.toLowerCase().indexOf("values")).trim(); if (valueSql.toLowerCase().startsWith("values")) { valueSql = valueSql.substring("values".length()); valueSql = valueSql.trim(); } if (valueSql.charAt(0) == '(') { valueSql = valueSql.substring(1); } if (valueSql.charAt(valueSql.length() - 1) == ';') { valueSql = valueSql.substring(0, valueSql.length() - 1); } if (valueSql.charAt(valueSql.length() - 1) == ')') { valueSql = valueSql.substring(0, valueSql.length() - 1); } List valueList = parseValues(valueSql, columnNames.length); // System1.out.println(columnNames.length + ", " + valueList.size()); if (valueList.size() == columnNames.length) { for (int i = 0; i < columnNames.length; i++) { // System1.out.println(columnNames[i] + "=" + valueList.get(i)); Character startEndQuote = startEndQuote(columnNames[i].charAt(0)); if (startEndQuote != null) { columnNames[i] = columnNames[i].substring(1); columnNames[i] = columnNames[i].substring(0, columnNames[i].length() - 1); } columnMap.put(columnNames[i], valueList.get(i)); } } return columnMap; } public static Character startEndQuote(char startChar) { for (char startEndQuote : startEndQuotes) { if (startEndQuote == startChar) { return startChar; } } return null; } private static List parseValues(String valueSql, int columnNamesLength) { List valueList = new ArrayList<>(); while (true) { if (valueSql.trim().length() == 0) { break; } char quoteBegin = valueSql.charAt(0); Character startEndQuote = startEndQuote(quoteBegin); if (startEndQuote == null) { if (valueList.size() == columnNamesLength - 1) { String value = valueSql.trim(); valueList.add(value); } else { int commaIndex = valueSql.indexOf(","); String value = valueSql.substring(0, commaIndex); valueSql = valueSql.substring(commaIndex + 1).trim(); valueList.add(value); } } else { valueSql = valueSql.substring(1); valueSql = valueSql.replace(startEndQuote + " " + ",", startEndQuote + ","); valueSql = valueSql.replace(startEndQuote + " " + ",", startEndQuote + ","); valueSql = valueSql.replace(startEndQuote + " " + ",", startEndQuote + ","); valueSql = valueSql.trim(); int endIndex = valueSql.indexOf(startEndQuote + ","); if (valueList.size() == columnNamesLength - 1) { endIndex = valueSql.indexOf(startEndQuote); } if (endIndex == -1) { break; } String value = valueSql.substring(0, endIndex); valueSql = valueSql.substring(endIndex + 1).trim(); if (valueSql.length() > 0 && valueSql.charAt(0) == ',') { valueSql = valueSql.substring(1).trim(); } valueList.add(value); } } return valueList; } public static void main(String[] args) { tableNameList.contains("person"); // String sql = "INSERT INTO person(\"camera_image_feature_path\", \"checked_time_rule_id\", \"sign_up_rule\", \"id\", \"name\", \"camera_image_path\", \"camera_image_feature\", \"camera_image_fastdfs_path\", \"id_card_number\", \"id_card_image_path\", \"id_card_image_feature\", \"type\", \"phone\", \"sign_up_time\", \"sign_up_method\", \"sign_up_status\", \"verify_status\", \"auto_init\", \"update_time\", \"del_flag\", \"all_device\", \"company_id\", \"table\", \"device_id\") VALUES ('', '', '注册通行', 'PSPAD010120190716172753922', '', '/sdcard/security_attachment/person_camera_image_path_PSPAD010120190716172753922', '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', '', '', '', '', '', '', '1563269273923', '人工注册', '已注册', '不需要验证身份证', '', '', '0', '0', '', 'person', '');\n"; // System1.out.println("SqlSplit.main " + getTableNameFromInsertSql(sql)); // insertToMap(query); // System1.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date(Long.parseLong("1573901869122")))); // if (1 == 1) { // return; // } // Pattern pattern = Pattern.compile("\\((.*?)\\)", Pattern.DOTALL); // Matcher matcher = pattern.matcher(query); // List tokens = new ArrayList(); // while (matcher.find()) { // tokens.add(matcher.group().replace("(", "").replace(")", "").split(",")); // } // Map map = new HashMap(); // if (tokens.size() == 2 && tokens.get(0).length == tokens.get(1).length) { // for (int x = 0; x < tokens.get(0).length; x++) { // map.put(tokens.get(0)[x], tokens.get(1)[x].replace("'", "")); // } // } // for (Map.Entry entry : map.entrySet()) { // System1.out.println("KEY:" + entry.getKey()); // System1.out.println("VALUE:" + entry.getValue()); // } } }