Утилита Escape Character для данных URL и JSON — не стесняйтесь использовать в своем проекте Java
Опубликовано: 2021-11-19
Что такое escape-символ в Java?
В основном escape-символы — это символы, which replaces existing character
new & provided character
, который работает лучше всего, не вызывая ошибок во время выполнения.
Кроме того, это необходимо для межсистемной/процессной передачи, т.е. один и тот же символ работает для C++, Java и т.д. языка программирования.
В этом уроке мы рассмотрим две утилиты Escape Character.
- URLEscapeUtil
- JSONEscapeUtil
Также этот учебник поможет вам, если у вас есть следующие вопросы:
- Экранирующие символы Java в строке
- Какие символы нужно экранировать в HTML
- Что означает escape char в java
- Экранирующие символы Java в строке
- Как мне избежать строки для Java?
- Escape-последовательности в Java с примерами
Давайте начнем:
- Создать класс CrunchifyEscapeCharUtility.java
- Создайте метод crunchifyURLEscapeUtil(String s), который возвращает строку с escape-символом в указанном URL-адресе.
- Создайте метод crunchifyJSONEscapeUtil(String s), который возвращает строку с escape-символом в предоставленном JSON.
- В основном () -
- мы будем читать данные JSON из файла
- укажите имя файла
Crunchify_Escape_Util.txt
- Мы используем
java.net.URLEncoder
для добавления экранирующего символа URL.
В Java, когда мы кодируем строку, применяются следующие правила:

Вот содержимое файла Crunchify_Escape_Util.txt
. Пожалуйста, поместите его на свой ноутбук / рабочий стол и обновите путь в программе.
1 2 3 4 5 6 7 8 9 10 |
{ "founder" : "App Shah" , "blogURL" : "https://crunchify.com" , "twitter" : "https://twitter.com/Crunchify" , "social" : { "facebook" : "http://facebook.com/Crunchify" , "pinterest" : "https://www.pinterest.com/Crunchify/crunchify-articles”, " rss ": " https : //crunchify.com/feed/" } } |
Вариант 1: Вот полный пример Java.
- Создайте собственные методы Escape JSON и URL.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
package crunchify . com . tutorials ; import java . io . BufferedReader ; import java . io . FileReader ; import java . io . IOException ; import java . net . URLEncoder ; import java . nio . charset . StandardCharsets ; import java . text . StringCharacterIterator ; /** * @author Crunchify.com * Version: 1.0 * Program: Escape Character Utility for URL and JSON data - Feel free to use in your Java Project. */ public class CrunchifyEscapeCharUtility { public static void main ( String [ ] args ) { // URL Escape Utility String crunchifyURL = "https://crunchify.com/this is test" ; crunchifyLog ( "Sample URL: " + crunchifyURL ) ; crunchifyLog ( "Escaped URL: " + crunchifyURLEscapeUtil ( crunchifyURL ) ) ; // JSON Escape Utility // We will read file first and then we will do escape char on that StringBuilder jsonData = new StringBuilder ( ) ; BufferedReader crunchifyBufferReader = null ; try { String crunchifyLine ; crunchifyBufferReader = new BufferedReader ( new FileReader ( "/Users/app/Downloads/Crunchify_Escape_Util.txt" ) ) ; while ( ( crunchifyLine = crunchifyBufferReader . readLine ( ) ) ! = null ) { jsonData . append ( crunchifyLine ) . append ( "\n" ) ; } // IOException: Signals that an I/O exception of some sort has occurred. // This class is the general class of exceptions produced by failed or interrupted I/O operations. } catch ( IOException exception ) { exception . printStackTrace ( ) ; } finally { try { if ( crunchifyBufferReader ! = null ) crunchifyBufferReader . close ( ) ; } catch ( IOException ex ) { ex . printStackTrace ( ) ; } } // Let's print raw JSON file data crunchifyLog ( "\n Sample JSON: " + jsonData . toString ( ) . toString ( ) ) ; // Let's print data after escaping JSON strings crunchifyLog ( "Escaped JSON: " + crunchifyJSONEscapeUtil ( jsonData . toString ( ) . toString ( ) ) ) ; } // Used to ensure that HTTP query strings are in proper form, by escaping special characters such as spaces. // Translates a string into application/x-www-form-urlencoded format using a specific encoding scheme public static String crunchifyURLEscapeUtil ( String crunchifyURL ) { String crunchifyNewURL ; // UTF_8: Eight-bit UCS Transformation Format. crunchifyNewURL = URLEncoder . encode ( crunchifyURL , StandardCharsets . UTF_8 ) ; return crunchifyNewURL ; } // JSON Escape Utility public static String crunchifyJSONEscapeUtil ( String crunchifyJSON ) { // StringBuilder(): Constructs a string builder with no characters in it and an initial capacity of 16 characters. final StringBuilder crunchifyNewJSON = new StringBuilder ( ) ; // StringCharacterIterator class iterates over the entire String StringCharacterIterator crunchifyIterator = new StringCharacterIterator ( crunchifyJSON ) ; // current(): Implements CharacterIterator.current() for String. char crunchifyChar = crunchifyIterator . current ( ) ; // DONE = \\uffff (not a character) while ( crunchifyChar ! = StringCharacterIterator . DONE ) { if ( crunchifyChar == '\"' ) { crunchifyNewJSON . append ( "\\\" "); } else if (crunchifyChar == '\t') { crunchifyNewJSON.append(" \ \ t "); } else if (crunchifyChar == '\f') { crunchifyNewJSON.append(" \ \ f "); } else if (crunchifyChar == '\n') { crunchifyNewJSON.append(" \ \ n "); } else if (crunchifyChar == '\r') { crunchifyNewJSON.append(" \ \ r "); } else if (crunchifyChar == '\\') { crunchifyNewJSON.append(" \ \ \ \ "); } else if (crunchifyChar == '/') { crunchifyNewJSON.append(" \ \ / "); } else if (crunchifyChar == '\b') { crunchifyNewJSON.append(" \ \ b " ) ; } else { // Nothing matched - just as text as it is. // next(): Implements CharacterIterator.next() for String. crunchifyNewJSON . append ( crunchifyChar ) ; } crunchifyChar = crunchifyIterator . next ( ) ; } return crunchifyNewJSON . toString ( ) ; } // Simple log utility private static void crunchifyLog ( String crunchifyData ) { System . out . println ( crunchifyData ) ; } } |
Вывод консоли Eclipse:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
Sample URL : https : //crunchify.com/this is test Escaped URL : https % 3A % 2F % 2Fcrunchify.com % 2Fthis + is + test Sample JSON : { "founder" : "App Shah" , "blogURL" : "https://crunchify.com" , "twitter" : "https://twitter.com/Crunchify" , "social" : { "facebook" : "http://facebook.com/Crunchify" , "pinterest" : "https://www.pinterest.com/Crunchify/crunchify-articles”, " rss ": " https : //crunchify.com/feed/" } } Escaped JSON : { \ n \ " founder \ " : \ " App Shah \ " , \ n \ " blogURL \ " : \ " https : \ / \ / crunchify . com \ " , \ n \ " twitter \ " : \ " https : \ / \ / twitter . com \ / Crunchify \ " , \ n \ " social \ " : { \ n \ " facebook \ " : \ " http : \ / \ / facebook . com \ / Crunchify \ " , \ n \ " pinterest \ " : \ " https : \ / \ / www . pinterest . com \ / Crunchify \ / crunchify - articles ” , \ n \ " rss \ " : \ " https : \ / \ / crunchify . com \ / feed \ / \ " \ n } \ n } \ n Process finished with exit code 0 |
Вариант 2: использование зависимости Apache Commons commons-text
- Добавьте зависимость Maven pom.xml
1 2 3 4 5 |
< dependency > < groupId > org . apache . commons < / groupId > < artifactId > commons - text < / artifactId > < version > 1.9 < / version > < / dependency > |
Полный код:
- Создать класс: CrunchifyEscapeJSONTutorial.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
package crunchify . com . java . tutorials ; import org . apache . commons . text . StringEscapeUtils ; /** * @author Crunchify.com * Program: In Java How to Escape JSON? Simple Tutorial using Apache Commons Library. */ public class CrunchifyEscapeJSONTutorial { public static void main ( String [ ] args ) { // StringEscapeUtils: Escapes and unescapes Strings for Java, Java Script, HTML and XML. // #ThreadSafe# // This code has been adapted from Apache Commons Lang 3.5. String crunchifyHTML = "{\n" + " \"founder\": \"App Shah\",\n" + " \"blogURL\": \"https://crunchify.com\",\n" + " \"twitter\": \"https://twitter.com/Crunchify\",\n" + " \"social\": {\n" + " \"facebook\": \"http://facebook.com/Crunchify\",\n" + " \"pinterest\": \"https://www.pinterest.com/Crunchify/crunchify-articles”,\n" + " \"rss\": \"https://crunchify.com/feed/\"\n" + " }\n" + "}" ; // escapeJson: Escapes the characters in a String using Json String rules. // Escapes any values it finds into their Json String form. Deals correctly with quotes and control-chars (tab, backslash, cr, ff, etc.) // So a tab becomes the characters '\\' and 't'. // The only difference between Java strings and Json strings is that in Json, forward-slash (/) is escaped. String crunchifyResult = StringEscapeUtils . escapeJson ( crunchifyHTML ) ; crunchifyPrintUtils ( crunchifyResult ) ; } private static void crunchifyPrintUtils ( String crunchifyResult ) { System . out . println ( crunchifyResult ) ; } } |
Результат IntelliJ IDEA:
Мы перешли на IntelliJ IDEA за последние два года. Вот результат консоли.

1 2 3 |
{ \ n \ " founder \ " : \ " App Shah \ " , \ n \ " blogURL \ " : \ " https : \ / \ / crunchify . com \ " , \ n \ " twitter \ " : \ " https : \ / \ / twitter . com \ / Crunchify \ " , \ n \ " social \ " : { \ n \ " facebook \ " : \ " http : \ / \ / facebook . com \ / Crunchify \ " , \ n \ " pinterest \ " : \ " https : \ / \ / www . pinterest . com \ / Crunchify \ / crunchify - articles \ u201D , \ n \ " rss \ " : \ " https : \ / \ / crunchify . com \ / feed \ / \ " \ n } \ n } Process finished with exit code 0 |
Дайте мне знать, если у вас возникнут какие-либо проблемы с запуском этого Java-приложения.