123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- package com.baomidou.mybatisplus.toolkit;
- /**
- * <p>
- * StringEscape ,数据库字符串转义
- * </p>
- *
- * @author Caratacus
- * @Date 2016-10-16
- */
- public class StringEscape {
- /**
- * <p>
- * 字符串是否需要转义
- * </p>
- *
- * @param str
- * @param len
- * @return
- */
- private static boolean isEscapeNeededForString(String str, int len) {
- boolean needsHexEscape = false;
- for (int i = 0; i < len; ++i) {
- char c = str.charAt(i);
- switch (c) {
- /* Must be escaped for 'mysql' */
- case 0:
- needsHexEscape = true;
- break;
- /* Must be escaped for logs */
- case '\n':
- needsHexEscape = true;
- break;
- case '\r':
- needsHexEscape = true;
- break;
- case '\\':
- needsHexEscape = true;
- break;
- case '\'':
- needsHexEscape = true;
- break;
- /* Better safe than sorry */
- case '"':
- needsHexEscape = true;
- break;
- /* This gives problems on Win32 */
- case '\032':
- needsHexEscape = true;
- break;
- default:
- break;
- }
- if (needsHexEscape) {
- // no need to scan more
- break;
- }
- }
- return needsHexEscape;
- }
- /**
- * 转义字符串
- *
- * @param escapeStr
- * @return
- */
- public static String escapeString(String escapeStr) {
- if (escapeStr.matches("\'(.+)\'")) {
- escapeStr = escapeStr.substring(1, escapeStr.length() - 1);
- }
- String parameterAsString = escapeStr;
- int stringLength = escapeStr.length();
- if (isEscapeNeededForString(escapeStr, stringLength)) {
- StringBuilder buf = new StringBuilder((int) (escapeStr.length() * 1.1));
- //
- // Note: buf.append(char) is _faster_ than appending in blocks,
- // because the block append requires a System.arraycopy().... go
- // figure...
- //
- for (int i = 0; i < stringLength; ++i) {
- char c = escapeStr.charAt(i);
- switch (c) {
- /* Must be escaped for 'mysql' */
- case 0:
- buf.append('\\');
- buf.append('0');
- break;
- /* Must be escaped for logs */
- case '\n':
- buf.append('\\');
- buf.append('n');
- break;
- case '\r':
- buf.append('\\');
- buf.append('r');
- break;
- case '\\':
- buf.append('\\');
- buf.append('\\');
- break;
- case '\'':
- buf.append('\\');
- buf.append('\'');
- break;
- /* Better safe than sorry */
- case '"':
- buf.append('\\');
- buf.append('"');
- break;
- /* This gives problems on Win32 */
- case '\032':
- buf.append('\\');
- buf.append('Z');
- break;
- default:
- buf.append(c);
- }
- }
- parameterAsString = buf.toString();
- }
- return "\'" + parameterAsString + "\'";
- }
- }
|