1 package org.exoplatform.wcm.webui.reader;
2
3 import org.apache.commons.lang.StringEscapeUtils;
4 import org.apache.commons.lang.StringUtils;
5 import org.exoplatform.services.jcr.util.Text;
6
7 public class ContentReader {
8
9
10
11
12
13
14
15
16
17
18
19 public static String getXSSCompatibilityContent(String content) {
20 if (content != null)
21 content = StringEscapeUtils.escapeHtml(Text.unescapeIllegalJcrChars(content));
22 return content;
23 }
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45 public static String getEscapeHtmlContent(String content) {
46 if (content != null) {
47 content = StringEscapeUtils.unescapeHtml(content);
48 content = StringEscapeUtils.escapeHtml(content);
49 }
50 return content;
51 }
52
53
54
55
56
57
58
59
60
61
62 public static String getUnescapeIllegalJcrContent(String content) {
63 if (content != null)
64 content = Text.unescapeIllegalJcrChars(content);
65 return content;
66 }
67
68
69
70
71
72
73 public static String simpleEscapeHtml(String value) {
74 if (StringUtils.isEmpty(value)) return StringUtils.EMPTY;
75 int length = value.length();
76 StringBuilder result = new StringBuilder((int) (length * 1.5));
77 for (int i = 0; i < length; i++) {
78 char ch = value.charAt(i);
79 switch (ch) {
80 case '<':
81 result.append("<");
82 break;
83 case '>':
84 result.append(">");
85 break;
86 default:
87 result.append(ch);
88 break;
89 }
90 }
91 return result.toString();
92 }
93 }