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

org.owasp.validator.html.util.HTMLEntityEncoder Maven / Gradle / Ivy

Go to download

A library for performing fast, configurable cleansing of HTML coming from untrusted sources.

The newest version!
/*
 * Copyright (c) 2007-2022, Arshan Dabirsiaghi, Jason Li
 *
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
 *
 * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
 * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
 * Neither the name of OWASP nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package org.owasp.validator.html.util;

public class HTMLEntityEncoder {

  /**
   * A helper method for HTML entity-encoding a String value.
   *
   * @param value A String containing HTML control characters.
   * @return An HTML-encoded String.
   */
  public static String htmlEntityEncode(String value) {

    StringBuffer buff = new StringBuffer();

    if (value == null) {
      return null;
    }

    for (int i = 0; i < value.length(); i++) {

      char ch = value.charAt(i);

      if (ch == '&') {
        buff.append("&");
      } else if (ch == '<') {
        buff.append("<");
      } else if (ch == '>') {
        buff.append(">");
      } else if (Character.isWhitespace(ch)) {
        buff.append(ch);
      } else if (Character.isLetterOrDigit(ch)) {
        buff.append(ch);
      } else if ((int) ch >= 32 && (int) ch <= 126) {
        buff.append("&#" + (int) ch + ";");
      }
    }

    return buff.toString();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy