• org.springframework.security.web.util.TextEscapeUtils


    经常看到一些开发团队在项目开发中,想重用一些代码,最低层次的代码重用其实就是写工具类,不过我这里想说的是,在web项目中常用的一些工具类不妨看一下springframework中的util包中的类,非常实用,最近在看springSecurity源码时就看到这样的一个类TextEscapeUtils,作用是用来进行URL编码的,并且做一些用户表单数据的非法输入字符的判断,具体代码如下:

    public abstract class TextEscapeUtils {
    
        public final static String escapeEntities(String s) {
            if (s == null || s.length() == 0) {
                return s;
            }
    
            StringBuilder sb = new StringBuilder();
    
            for (int i=0; i < s.length(); i++) {
                char c = s.charAt(i);
    
                if (c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z' || c >= '0' && c <= '9') {
                    sb.append(c);
                } else if(c == '<') {
                    sb.append("<");
                } else if (c == '>') {
                    sb.append(">");
                } else if (c == '&') {
                    sb.append("&");
                } else if (Character.isWhitespace(c)) {
                    sb.append("&#").append((int)c).append(";");
                } else if (Character.isISOControl(c)) {
                    // ignore control chars
                } else if (Character.isHighSurrogate(c)) {
                    if (i + 1 >= s.length()) {
                        // Unexpected end
                        throw new IllegalArgumentException("Missing low surrogate character at end of string");
                    }
                    char low = s.charAt(i + 1);
    
                    if (!Character.isLowSurrogate(low)) {
                        throw new IllegalArgumentException("Expected low surrogate character but found value = " + (int)low);
                    }
    
                    int codePoint = Character.toCodePoint(c, low);
                    if (Character.isDefined(codePoint)) {
                        sb.append("&#").append(codePoint).append(";");
                    }
                    i++; // skip the next character as we have already dealt with it
                } else if (Character.isLowSurrogate(c)) {
                    throw new IllegalArgumentException("Unexpected low surrogate character, value = " + (int)c);
                } else if (Character.isDefined(c)) {
                    sb.append("&#").append((int) c).append(";");
                }
                // Ignore anything else
            }
    
            return sb.toString();
        }
    }
    
  • 相关阅读:
    学派:儒学
    学派:儒家
    佛教-文章:释迦牟尼佛最有灵性的4句话
    阿里云-OSS-Help-安全白皮书:白皮书
    佛教-揭语:诸法因缘生,我说是因缘;因缘尽故灭,我作如是说;诸法从缘起,如来说是因;彼法因缘尽,是大沙门说。
    深度学习系列之ANN
    IDEA无法启动:Failed to create JVM:error code -4
    Windows8-x64 VMWare安装Linux CentOS6-x64
    [数位dp] bzoj 3209 花神的数论题
    UVALive 6084 Happy Camper(数学题)
  • 原文地址:https://www.cnblogs.com/hzhuxin/p/2315764.html
Copyright © 2020-2023  润新知