程序员Android开发

匹配字符串,正则表达式用了就高大上了?

2020-11-22  本文已影响0人  岛上码农

前言:作者举了一个例子来表名在实际开发中,做字符串检测时,会使用正则表达式;但是有些时候压根没必要,而导致这样的原因其实是开发者的基础不够扎实。看似很牛地使用了正则表达式解决了问题,而实际上存在更简单的方法。因此,程序员的扎实的程序语言基础其实十分重要,而当前恰恰是很多新人盲目学学框架,却忘记打基础,结果导致实际开发过程中的代码一塌糊涂。

Nohemi有个程序需要使用基于角色的安全访问认证,基于他们组织的需要,他们的角色名称规则有点不寻常。有些角色名称是需要大小写匹配的,而有些角色名称有更灵活格式。然后她的同事编写了如下代码根据角色名称解析对应的系统角色的。

    public static String decodeRole(String role) {
        String decodedRole = "";
        if (role != null && !role.trim().equals("")) {
            if (role.trim().equalsIgnoreCase(ROLE_1_STRING))
                decodedRole = CODE_ROLE_1;
            else if (role.trim().equalsIgnoreCase(ROLE_2_STRING))
                decodedRole = CODE_ROLE_2;
            else if (role.trim().equalsIgnoreCase(ROLE_3_STRING))
                decodedRole = CODE_ROLE_3;
            else if (personalContains(role.trim(), ROLE_4_STRING))
                decodedRole = CODE_ROLE_4;
        }
        return decodedRole;
    }

这是角色名称转换为系统角色的关键方法。角色1、2和3必须准确匹配。而角色4,需要通过特殊规则匹配 — 一个需要通过正则表达式校验的复杂规则。

    private static final String REGEXP_SUFFIX = ").*$";
    private static final String REGEXP_PREFIX = "^.*(";
    public static boolean personalContains(String fatherString,
                                           String toSearchString) {
        Pattern p = Pattern.compile(REGEXP_PREFIX + toSearchString.toLowerCase()
                + REGEXP_SUFFIX);
        Matcher m = p.matcher(fatherString.toLowerCase());
        boolean matchFound = m.matches();
        if (matchFound)
            return true;
        else
            return false;
    }

这段代码的规则是这样的,如果你搜索一个字符串,例如ROLE_4,则构建完成的正则表达式为^.*(ROLE_4).*$。也就是这个字符串的开头必须是0个或多个字符,然后是ROLE_4字符串,最后是以0个或多个字符结尾。

实际上这是一个是否包含子字符串的的检测,而这不应该是首选的做法。一方面通过前后拼接、包含变量构建正则表达式代码看起来十分费解,另一方面Java的String类本身就提供了一个String.contains方法来做这件事情。这个花费力气写的personalContains方法根本没必要。

更扯淡的是,本来这个方法返回的结果只需要是return m.matches()即可,结果他们还增加了一个matchFound变量,简直就是画蛇添足!

        if (matchFound)
            return true;
        else
            return false;

wx公号:岛上码农

上一篇 下一篇

猜你喜欢

热点阅读