正则表达式作为模式属性传递时不起作用

时间:2019-07-11 15:53:49

标签: java xml logback pattern-layout

我正在尝试的正则表达式是找到另一个单词旁边的单词并将其替换! 当我将其作为模式属性传递时,它似乎不起作用。

但是似乎在代码中不起作用。

我已经尝试过此正则表达式以使用默认的Java程序进行检查,并且看起来工作正常。 -> https://repl.it/repls/BlushingAccurateCarat

当我只是传入(通过属性的密码)时,它确实会*发出密码。

我的logback.xml文件

<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
    <layout class="com.vecna.nexus.facilities.loggerMasking.MaskingPatternLayout">
        <patternsProperty><![CDATA[(?<=password.{0,3})(\\w+)]]> 
        </patternsProperty>
        <pattern>%-5p %c{0} %d{dd MMM yyyy HH:mm:ss.SSS}: %m%n</pattern>
    </layout>
</encoder>

我的Java代码

public class MaskingPatternLayout extends PatternLayout {

    private String patternsProperty;

    private Optional<Pattern> pattern;

    public String getPatternsProperty() {
        return patternsProperty;
    }

    public void setPatternsProperty(String patternsProperty) {
        this.patternsProperty = patternsProperty;
        final Logger s_log = LoggerFactory.getLogger("CHECKING STUFF");
        s_log.info(this.patternsProperty);
        if (this.patternsProperty != null) {
            this.pattern = Optional.of(Pattern.compile(patternsProperty, Pattern.MULTILINE));
        } else {
            this.pattern = Optional.empty();
        }
    }

    @Override
    public String doLayout(ILoggingEvent event) {
        final StringBuilder message = new StringBuilder(super.doLayout(event));

        if (pattern.isPresent()) {
            Matcher matcher = pattern.get().matcher(message);
            while (matcher.find()) {

                int group = 1;
                while (group <= matcher.groupCount()) {
                    if (matcher.group(group) != null) {
                        for (int i = matcher.start(group); i < matcher.end(group); i++) {
                            message.setCharAt(i, '*');
                        }
                    }
                    group++;
                }
            }
        }

        return message.toString();
    }
}

我需要输出为->密码:******** 但是我只得到密码:12312312

1 个答案:

答案 0 :(得分:0)

问题似乎出在(?<= password。{0,3})(\\ w +)中多余的\。 正确的正则表达式

<patternsProperty><![CDATA[((?<=password.{0,3})(\w+))]]> </patternsProperty>