All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.nesscomputing.syslog4j.impl.message.modifier.escape.HTMLEntityEscapeSyslogMessageModifier Maven / Gradle / Ivy

Go to download

Syslog4j provides client and server implementations of the BSD Syslog protocol (RFC 3164) and the structured syslog" protocol (RFC5424).

There is a newer version: 0.9.47-NESS-8
Show newest version
/**
 *
 * (C) Copyright 2008-2011 syslog4j.org
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the GNU Lesser General Public License
 * (LGPL) version 2.1 which accompanies this distribution, and is available at
 * http://www.gnu.org/licenses/lgpl-2.1.html
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 */
package com.nesscomputing.syslog4j.impl.message.modifier.escape;

import org.apache.commons.lang3.StringUtils;

import com.nesscomputing.syslog4j.SyslogFacility;
import com.nesscomputing.syslog4j.SyslogIF;
import com.nesscomputing.syslog4j.SyslogLevel;
import com.nesscomputing.syslog4j.SyslogMessageModifierIF;

/**
* HTMLEntityEscapeSyslogMessageModifier is an implementation of SyslogMessageModifierIF
* that safely escapes HTML entity characters.
*
* 

This modifier is useful for applications that display log content in browsers without * properly escaping HTML characters.

* *

Syslog4j is licensed under the Lesser GNU Public License v2.1. A copy * of the LGPL license is available in the META-INF folder in all * distributions of Syslog4j and in the base directory of the "doc" ZIP.

* * @author <[email protected]> * @version $Id: HTMLEntityEscapeSyslogMessageModifier.java,v 1.4 2010/10/28 05:10:57 cvs Exp $ */ public class HTMLEntityEscapeSyslogMessageModifier implements SyslogMessageModifierIF { public static final SyslogMessageModifierIF createDefault() { return new HTMLEntityEscapeSyslogMessageModifier(); } @Override public String modify(SyslogIF syslog, SyslogFacility facility, SyslogLevel level, String message) { if (StringUtils.isBlank(message)) { return message; } else { String escapedMessage = escapeHtml(message); return escapedMessage; } } public boolean verify(String message) { // NO-OP return true; } /** * escapeHtml(String) is based partly on the article posted here: http://www.owasp.org/index.php/How_to_perform_HTML_entity_encoding_in_Java * with the addition of common characters and modifications for Java 1.4 support. * * @param message * @return Returns a message where any HTML entity characters are escaped. */ public static String escapeHtml(String message) { StringBuffer b = new StringBuffer(message.length()); for (int i = 0; i < message.length(); i++) { char ch = message.charAt(i); if (ch == '<') { b.append("<"); } else if (ch == '>') { b.append(">"); } else if (ch == '"') { b.append("""); } else if (ch == '\'') { b.append("'"); } else if (ch == '&') { b.append("&"); } else if (ch >= ' ' && ch <= '~') { b.append(ch); } else if (Character.isWhitespace(ch)) { b.append("&#").append((int) ch).append(";"); } else if (Character.isISOControl(ch)) { continue; // Ignore character } else if (Character.isDefined(ch)) { b.append("&#").append((int) ch).append(";"); } } return b.toString(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy