⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 utilproperties.java

📁 Sequoia ERP是一个真正的企业级开源ERP解决方案。它提供的模块包括:电子商务应用(e-commerce), POS系统(point of sales),知识管理,存货与仓库管理
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * $Id: UtilProperties.java 5462 2005-08-05 18:35:48Z jonesde $ * *  Copyright (c) 2001-2005 The Open For Business Project - www.ofbiz.org * *  Permission is hereby granted, free of charge, to any person obtaining a *  copy of this software and associated documentation files (the "Software"), *  to deal in the Software without restriction, including without limitation *  the rights to use, copy, modify, merge, publish, distribute, sublicense, *  and/or sell copies of the Software, and to permit persons to whom the *  Software is furnished to do so, subject to the following conditions: * *  The above copyright notice and this permission notice shall be included *  in all copies or substantial portions of the Software. * *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY *  CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT *  OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *  THE USE OR OTHER DEALINGS IN THE SOFTWARE. */package org.ofbiz.base.util;import java.net.URL;import java.text.MessageFormat;import java.util.List;import java.util.Locale;import java.util.Map;import java.util.MissingResourceException;import java.util.Properties;import java.util.ResourceBundle;import java.util.Set;import java.io.FileOutputStream;import java.io.FileNotFoundException;import java.io.IOException;import javolution.util.FastSet;import org.ofbiz.base.util.collections.FlexibleProperties;import org.ofbiz.base.util.collections.ResourceBundleMapWrapper;import org.ofbiz.base.util.string.FlexibleStringExpander;import org.ofbiz.base.util.cache.UtilCache;/** * Generic Property Accessor with Cache - Utilities for working with properties files * * @author     <a href="mailto:jonesde@ofbiz.org">David E. Jones</a> * @version    $Rev: 5462 $ * @since      1.0 */public class UtilProperties implements java.io.Serializable {    public static final String module = UtilProperties.class.getName();    /** An instance of the generic cache for storing the FlexibleProperties     *  corresponding to each properties file keyed by a String for the resource location.     * This will be used for both non-locale and locale keyed FexibleProperties instances.     */    protected static UtilCache resourceCache = new UtilCache("properties.UtilPropertiesResourceCache");    /** An instance of the generic cache for storing the FlexibleProperties     *  corresponding to each properties file keyed by a URL object     */    protected static UtilCache urlCache = new UtilCache("properties.UtilPropertiesUrlCache");    /** An instance of the generic cache for storing the ResourceBundle     *  corresponding to each properties file keyed by a String for the resource location and the locale     */    protected static UtilCache bundleLocaleCache = new UtilCache("properties.UtilPropertiesBundleLocaleCache");    /** Compares the specified property to the compareString, returns true if they are the same, false otherwise     * @param resource The name of the resource - if the properties file is 'webevent.properties', the resource name is 'webevent'     * @param name The name of the property in the properties file     * @param compareString The String to compare the property value to     * @return True if the strings are the same, false otherwise     */    public static boolean propertyValueEquals(String resource, String name, String compareString) {        String value = getPropertyValue(resource, name);        if (value == null) return false;        return value.trim().equals(compareString);    }    /** Compares Ignoring Case the specified property to the compareString, returns true if they are the same, false otherwise     * @param resource The name of the resource - if the properties file is 'webevent.properties', the resource name is 'webevent'     * @param name The name of the property in the properties file     * @param compareString The String to compare the property value to     * @return True if the strings are the same, false otherwise     */    public static boolean propertyValueEqualsIgnoreCase(String resource, String name, String compareString) {        String value = getPropertyValue(resource, name);        if (value == null) return false;        return value.trim().equalsIgnoreCase(compareString);    }    /** Returns the value of the specified property name from the specified resource/properties file.     * If the specified property name or properties file is not found, the defaultValue is returned.     * @param resource The name of the resource - if the properties file is 'webevent.properties', the resource name is 'webevent'     * @param name The name of the property in the properties file     * @param defaultValue The value to return if the property is not found     * @return The value of the property in the properties file, or if not found then the defaultValue     */    public static String getPropertyValue(String resource, String name, String defaultValue) {        String value = getPropertyValue(resource, name);        if (value == null || value.length() == 0)            return defaultValue;        else            return value;    }    public static double getPropertyNumber(String resource, String name) {        String str = getPropertyValue(resource, name);        double strValue = 0.00000;        try {            strValue = Double.parseDouble(str);        } catch (NumberFormatException nfe) {}        return strValue;    }    /** Returns the value of the specified property name from the specified resource/properties file     * @param resource The name of the resource - can be a file, class, or URL     * @param name The name of the property in the properties file     * @return The value of the property in the properties file     */    public static String getPropertyValue(String resource, String name) {        if (resource == null || resource.length() <= 0) return "";        if (name == null || name.length() <= 0) return "";        FlexibleProperties properties = (FlexibleProperties) resourceCache.get(resource);        if (properties == null) {            try {                URL url = UtilURL.fromResource(resource);                if (url == null) return "";                properties = FlexibleProperties.makeFlexibleProperties(url);                resourceCache.put(resource, properties);            } catch (MissingResourceException e) {                Debug.log(e.getMessage(), module);            }        }        if (properties == null) {            Debug.log("[UtilProperties.getPropertyValue] could not find resource: " + resource, module);            return "";        }        String value = null;        try {            value = properties.getProperty(name);        } catch (Exception e) {            Debug.log(e.getMessage(), module);        }        return value == null ? "" : value.trim();    }       /** Returns the specified resource/properties file     * @param resource The name of the resource - can be a file, class, or URL     * @return The properties file     */    public static Properties getProperties(String resource) {        if (resource == null || resource.length() <= 0)            return null;        Properties properties = (FlexibleProperties) resourceCache.get(resource);        if (properties == null) {            try {                URL url = UtilURL.fromResource(resource);                if (url == null)                    return null;                properties = FlexibleProperties.makeFlexibleProperties(url);                resourceCache.put(resource, properties);            } catch (MissingResourceException e) {                Debug.log(e.getMessage(), module);            }        }        if (properties == null) {            Debug.log("[UtilProperties.getProperties] could not find resource: " + resource, module);            return null;        }        return properties;    }    /** Returns the specified resource/properties file     * @param url The URL to the resource     * @return The properties file     */    public static Properties getProperties(URL url) {        if (url == null)            return null;        Properties properties = (FlexibleProperties) resourceCache.get(url);        if (properties == null) {            try {                properties = FlexibleProperties.makeFlexibleProperties(url);                resourceCache.put(url, properties);            } catch (MissingResourceException e) {                Debug.log(e.getMessage(), module);            }        }        if (properties == null) {            Debug.log("[UtilProperties.getProperties] could not find resource: " + url, module);            return null;        }        return properties;    }    // ========= URL Based Methods ==========    /** Compares the specified property to the compareString, returns true if they are the same, false otherwise     * @param url URL object specifying the location of the resource     * @param name The name of the property in the properties file     * @param compareString The String to compare the property value to     * @return True if the strings are the same, false otherwise     */    public static boolean propertyValueEquals(URL url, String name, String compareString) {        String value = getPropertyValue(url, name);        if (value == null) return false;        return value.trim().equals(compareString);    }    /** Compares Ignoring Case the specified property to the compareString, returns true if they are the same, false otherwise     * @param url URL object specifying the location of the resource     * @param name The name of the property in the properties file     * @param compareString The String to compare the property value to     * @return True if the strings are the same, false otherwise     */    public static boolean propertyValueEqualsIgnoreCase(URL url, String name, String compareString) {        String value = getPropertyValue(url, name);        if (value == null) return false;        return value.trim().equalsIgnoreCase(compareString);    }    /** Returns the value of the specified property name from the specified resource/properties file.     * If the specified property name or properties file is not found, the defaultValue is returned.     * @param url URL object specifying the location of the resource     * @param name The name of the property in the properties file     * @param defaultValue The value to return if the property is not found     * @return The value of the property in the properties file, or if not found then the defaultValue     */    public static String getPropertyValue(URL url, String name, String defaultValue) {        String value = getPropertyValue(url, name);        if (value == null || value.length() <= 0)            return defaultValue;        else            return value;    }    public static double getPropertyNumber(URL url, String name) {        String str = getPropertyValue(url, name);        double strValue = 0.00000;        try {            strValue = Double.parseDouble(str);        } catch (NumberFormatException nfe) {}        return strValue;    }    /** Returns the value of the specified property name from the specified resource/properties file     * @param url URL object specifying the location of the resource     * @param name The name of the property in the properties file     * @return The value of the property in the properties file     */    public static String getPropertyValue(URL url, String name) {        if (url == null) return "";        if (name == null || name.length() <= 0) return "";        FlexibleProperties properties = (FlexibleProperties) urlCache.get(url);        if (properties == null) {            try {                properties = FlexibleProperties.makeFlexibleProperties(url);                urlCache.put(url, properties);            } catch (MissingResourceException e) {                Debug.log(e.getMessage(), module);            }        }        if (properties == null) {            Debug.log("[UtilProperties.getPropertyValue] could not find resource: " + url, module);            return null;        }        String value = null;        try {            value = properties.getProperty(name);        } catch (Exception e) {            Debug.log(e.getMessage(), module);        }        return value == null ? "" : value.trim();    }    /** Returns the value of a split property name from the specified resource/properties file     * Rather than specifying the property name the value of a name.X property is specified which     * will correspond to a value.X property whose value will be returned. X is a number from 1 to     * whatever and all values are checked until a name.X for a certain X is not found.     * @param url URL object specifying the location of the resource     * @param name The name of the split property in the properties file     * @return The value of the split property from the properties file     */    public static String getSplitPropertyValue(URL url, String name) {        if (url == null) return "";

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -