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

com.opensymphony.xwork2.config.providers.XmlHelper Maven / Gradle / Ivy

There is a newer version: 6.4.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package com.opensymphony.xwork2.config.providers;

import org.apache.commons.lang3.StringUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import java.util.LinkedHashMap;
import java.util.Map;


/**
 * XML utilities.
 *
 * @author Mike
 */
public class XmlHelper {


    /**
     * 

* This method will find all the parameters under this paramsElement and return them as * Map<String, String>. For example, *

* *
     *   <result ... >
     *      <param name="param1">value1</param>
     *      <param name="param2">value2</param>
     *      <param name="param3">value3</param>
     *   </result>
     * 
* *

* will returns a Map<String, String> with the following key, value pairs: *

* *
    *
  • param1 - value1
  • *
  • param2 - value2
  • *
  • param3 - value3
  • *
* * @param paramsElement params element * @return a map of key,value pairs */ public static Map getParams(Element paramsElement) { LinkedHashMap params = new LinkedHashMap<>(); if (paramsElement == null) { return params; } NodeList childNodes = paramsElement.getChildNodes(); for (int i = 0; i < childNodes.getLength(); i++) { Node childNode = childNodes.item(i); if ((childNode.getNodeType() == Node.ELEMENT_NODE) && "param".equals(childNode.getNodeName())) { Element paramElement = (Element) childNode; String paramName = paramElement.getAttribute("name"); String val = getContent(paramElement); if (val.length() > 0) { params.put(paramName, val); } } } return params; } /** *

* This method will return the content of this particular element. * For example, *

* *
     *    <result>something_1</result>
     * 
* *

* When the {@link org.w3c.dom.Element} <result> is passed in as * argument (element to this method, it returns the content of it, * namely, something_1 in the example above. *

* * @param element the DOM element * @return content as string */ public static String getContent(Element element) { StringBuilder paramValue = new StringBuilder(); NodeList childNodes = element.getChildNodes(); for (int j = 0; j < childNodes.getLength(); j++) { Node currentNode = childNodes.item(j); if (currentNode != null && currentNode.getNodeType() == Node.TEXT_NODE) { String val = currentNode.getNodeValue(); if (val != null) { paramValue.append(val.trim()); } } } return paramValue.toString().trim(); } /** * @param doc document * @return the value of the "order" attribute from the root element */ public static Integer getLoadOrder(Document doc) { Element rootElement = doc.getDocumentElement(); String number = rootElement.getAttribute("order"); if (StringUtils.isNotBlank(number)) { try { return Integer.parseInt(number); } catch (NumberFormatException e) { return Integer.MAX_VALUE; } } else { //no order specified return Integer.MAX_VALUE; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy