com.frameworkset.util.BaseSimpleStringUtil Maven / Gradle / Ivy
Show all versions of bboss-core-entity Show documentation
/*****************************************************************************
* *
* This file is part of the tna framework distribution. *
* Documentation and updates may be get from biaoping.yin the author of *
* this framework *
* *
* Sun Public License Notice: *
* *
* The contents of this file are subject to the Sun Public License Version *
* 1.0 (the "License"); you may not use this file except in compliance with *
* the License. A copy of the License is available at http://www.sun.com *
* *
* The Original Code is tag. The Initial Developer of the Original *
* Code is biaoping yin. Portions created by biaoping yin are Copyright *
* (C) 2000. All Rights Reserved. *
* *
* GNU Public License Notice: *
* *
* Alternatively, the contents of this file may be used under the terms of *
* the GNU Lesser General Public License (the "LGPL"), in which case the *
* provisions of LGPL are applicable instead of those above. If you wish to *
* allow use of your version of this file only under the terms of the LGPL *
* and not to allow others to use your version of this file under the SPL, *
* indicate your decision by deleting the provisions above and replace *
* them with the notice and other provisions required by the LGPL. If you *
* do not delete the provisions above, a recipient may use your version of *
* this file under either the SPL or the LGPL. *
* *
* biaoping.yin ([email protected]) *
* Author of Learning Java *
* *
*****************************************************************************/
package com.frameworkset.util;
import org.frameworkset.util.CollectionUtils;
import org.frameworkset.util.DataFormatUtil;
import org.frameworkset.util.ObjectUtils;
import org.frameworkset.util.encoder.Charsets;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.*;
import java.lang.reflect.Array;
import java.net.InetAddress;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.nio.charset.Charset;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
/**
* To change for your class or interface DAO中VOObject String类型与PO数据类型转换工具类.
*
* @author biaoping.yin
* @version 1.0
*/
public class BaseSimpleStringUtil {
// private static final SimpleDateFormat format = new SimpleDateFormat(
// "yyyy-MM-dd HH:mm:ss");
protected static final Logger logger = LoggerFactory.getLogger(BaseSimpleStringUtil.class);
// 逗号常量
public static final String COMMA = ",";
// 空串常量
public static final String BLANK = "";
public static String getPath(String contextPath, String path) {
if(contextPath == null || contextPath.equals("") )
return path;
if(path == null || path.equals("")){
return contextPath;
}
StringBuilder builder = new StringBuilder();
builder.append(contextPath);
boolean contextPathEndsWith = contextPath.endsWith("/");
boolean pathEndsWith = path.startsWith("/");
if(contextPathEndsWith || pathEndsWith){
if(contextPathEndsWith && pathEndsWith){
builder.append(path.substring(1));
}
else {
builder.append(path);
}
}
else{
builder.append("/").append(path);
}
return builder.toString();
}
/**
* A constant passed to the {@link # split()}methods indicating that
* all occurrences of a pattern should be used to split a string.
*/
public static final int SPLIT_ALL = 0;
/**
* 以下的变量:dontNeedEncoding,dfltEncName,caseDiff 是从jdk 1.4 java.net.URLEncoder
* 下移植过来
*/
private static BitSet dontNeedEncoding;
private static String dfltEncName = null;
private static String getDfltEncName(){
if(dfltEncName == null) {
synchronized (BaseSimpleStringUtil.class) {
if(dfltEncName == null) {
dfltEncName = System.getProperty("file.encoding");
}
}
}
return dfltEncName;
}
static final int caseDiff = ('a' - 'A');
private static BitSet initDontNeedEncoding(){
/*
* The list of characters that are not encoded has been determined as
* follows:
*
* RFC 2396 states: ----- Data characters that are allowed in a URI but
* do not have a reserved purpose are called unreserved. These include
* upper and lower case letters, decimal digits, and a limited set of
* punctuation marks and symbols.
*
* unreserved = alphanum | mark
*
* mark = "-" | "_" | "." | "!" | "~" | "*" | "'" | "(" | ")"
*
* Unreserved characters can be escaped without changing the semantics
* of the URI, but this should not be done unless the URI is being used
* in a context that does not allow the unescaped character to appear.
* -----
*
* It appears that both Netscape and Internet Explorer escape all
* special characters from this list with the exception of "-", "_",
* ".", "*". While it is not clear why they are escaping the other
* characters, perhaps it is safest to assume that there might be
* contexts in which the others are unsafe if not escaped. Therefore, we
* will use the same list. It is also noteworthy that this is consistent
* with O'Reilly's "HTML: The Definitive Guide" (page 164).
*
* As a last note, Intenet Explorer does not encode the "@" character
* which is clearly not unreserved according to the RFC. We are being
* consistent with the RFC in this matter, as is Netscape.
*/
if(dontNeedEncoding == null) {
synchronized (BaseSimpleStringUtil.class) {
if(dontNeedEncoding == null) {
dontNeedEncoding = new BitSet(256);
int i;
for (i = 'a'; i <= 'z'; i++) {
dontNeedEncoding.set(i);
}
for (i = 'A'; i <= 'Z'; i++) {
dontNeedEncoding.set(i);
}
for (i = '0'; i <= '9'; i++) {
dontNeedEncoding.set(i);
}
dontNeedEncoding.set(' '); /*
* encoding a space to a + is done in the
* encode() method
*/
dontNeedEncoding.set('-');
dontNeedEncoding.set('_');
dontNeedEncoding.set('.');
dontNeedEncoding.set('*');
}
}
}
return dontNeedEncoding;
}
private static String ipHost;
private static String ip;
private static String hostName;
private static void init(){
if(ip == null) {
try {
InetAddress addr = InetAddress.getLocalHost();
String ip_ = addr.getHostAddress();//获得本机IP
String address = addr.getHostName();//获得本机名称
ipHost = ipHost + "-" + address;
hostName = address;
ip = ip_;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public static String getIp()
{
if(ip != null)
return ip;
synchronized (BaseSimpleStringUtil.class) {
init();
}
return ip;
}
/**
* 获取服务器IP和名称
* @return
*/
public static String getHostIP()
{
if(ipHost != null)
return ipHost;
synchronized (BaseSimpleStringUtil.class) {
init();
}
return ipHost;
}
public static String getHostName(){
if(hostName != null)
return hostName;
synchronized (BaseSimpleStringUtil.class) {
init();
}
return hostName;
}
/**
* Parse the given {@code timeZoneString} value into a {@link TimeZone}.
* @param timeZoneString the time zone {@code String}, following {@link TimeZone#getTimeZone(String)}
* but throwing {@link IllegalArgumentException} in case of an invalid time zone specification
* @return a corresponding {@link TimeZone} instance
* @throws IllegalArgumentException in case of an invalid time zone specification
*/
public static TimeZone parseTimeZoneString(String timeZoneString) {
TimeZone timeZone = TimeZone.getTimeZone(timeZoneString);
if ("GMT".equals(timeZone.getID()) && !timeZoneString.startsWith("GMT")) {
// We don't want that GMT fallback...
throw new IllegalArgumentException("Invalid time zone specification '" + timeZoneString + "'");
}
return timeZone;
}
public static String getRealPath(String contextPath, String path) {
return getRealPath(contextPath, path,false);
}
public static void getRealPath(StringBuilder builder,String contextPath, String path) {
getRealPath(builder,contextPath, path,false);
}
public static boolean isHttpUrl(String path)
{
if(path == null)
return false;
return path.startsWith("http://")
|| path.startsWith("https://")
|| path.startsWith("ftp://")
|| path.startsWith("tps://") ;
}
/**
* 获取36位 uuid
* @return
*/
public static String getUUID()
{
return UUID.randomUUID().toString();
}
/**
* 获取32位 uuid
* @return
*/
public static String getUUID32()
{
String uuid = UUID.randomUUID().toString();
return uuid.replace("-","");
}
public static String getRealPath(String contextPath, String path,boolean usebase) {
if(isHttpUrl(path))
return path;
if (contextPath == null || contextPath.equals("") || contextPath.equals("/")) {
// System.out.println("SimpleStringUtil.getRealPath() contextPath:"
// + contextPath);
if(usebase)//如果需要检测上下文路径为空串,那么如果path第一个字符不是/,那么需要补充字符/到第一个位置
{
if(isEmpty(path))
return "/";
else
{
return path.startsWith("/")?path:new StringBuilder().append("/").append(path).toString();
}
}
else
{
return path == null?"":path;
}
}
if (path == null || path.equals("")) {
return contextPath;
}
contextPath = contextPath.replace('\\', '/');
path = path.replace('\\', '/');
if (path.startsWith("/") ) {
if (!contextPath.endsWith("/"))
return new StringBuilder().append(contextPath).append( path).toString();
else {
return new StringBuilder().append(contextPath.substring(0,contextPath.length() - 1)).append( path).toString();
}
} else {
if (!contextPath.endsWith("/"))
return new StringBuilder().append(contextPath).append("/" ).append(path).toString();
else {
return new StringBuilder().append(contextPath).append( path).toString();
}
}
}
public static void getRealPath(StringBuilder builder,String contextPath, String path,boolean usebase) {
if(isHttpUrl(path)) {
builder.append(path);
return;
}
if (contextPath == null || contextPath.equals("") || contextPath.equals("/")) {
// System.out.println("SimpleStringUtil.getRealPath() contextPath:"
// + contextPath);
if(usebase)//如果需要检测上下文路径为空串,那么如果path第一个字符不是/,那么需要补充字符/到第一个位置
{
if(isEmpty(path)) {
builder.append("/");
return;
}
else
{
if(path.startsWith("/"))
builder.append(path);
else
builder.append("/").append(path);
return;
}
}
else
{
if(path != null)
builder.append(path);
return;
}
}
if (path == null || path.equals("")) {
builder.append( contextPath);
return;
}
contextPath = contextPath.replace('\\', '/');
path = path.replace('\\', '/');
if (path.startsWith("/") ) {
if (!contextPath.endsWith("/")) {
builder.append(contextPath).append(path);
return;
}
else {
builder.append(contextPath.substring(0,contextPath.length() - 1)).append( path);
return;
}
} else {
if (!contextPath.endsWith("/")) {
builder.append(contextPath).append("/").append(path);
}
else {
builder.append(contextPath).append( path);
return;
}
}
}
public static boolean containKey(String[] values, String key) {
if (values == null || key == null) {
return false;
}
boolean contain = false;
for (int i = 0; i < values.length; i++) {
// System.out.println("values[" + i + "]:" + values[i]);
// System.out.println("key:" + key);
if (values[i].equals(key)) {
contain = true;
break;
}
}
return contain;
}
public static String getNormalPath(String parent,String file)
{
// if(parent.equals("") )
// return file;
// if(file.equals("")){
// return parent;
// }
// if(parent.endsWith("/") && !file.startsWith("/"))
// return parent + file;
// else if(!parent.endsWith("/") && file.startsWith("/"))
// return parent + file;
// else if(!parent.endsWith("/") && !file.startsWith("/"))
// return parent + "/"+file;
// else //if(parent.endsWith("/") && file.startsWith("/"))
// return parent + file.substring(1);
return getPath(parent, file);
}
public static String getFormatDate(Date date, String formate) {
SimpleDateFormat dateFormat = DataFormatUtil.getSimpleDateFormat(formate);
if (date == null) {
return null;
}
return dateFormat.format(date);
}
public static Date stringToDate(String date) {
if (date == null || date.trim().equals("")) {
return null;
}
SimpleDateFormat format = DataFormatUtil.getSimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// date = date.replace('-', '/');
// SimpleDateFormat format = new SimpleDateFormat();
try {
return format.parse(date);
} catch (ParseException e) {
return new Date(date);
}
}
public static Date stringToDate(String date, String format_) {
if (date == null || date.trim().equals("")) {
return null;
}
// date = date.replace('-', '/');
SimpleDateFormat format = DataFormatUtil.getSimpleDateFormat(format_);
try {
return format.parse(date);
} catch (ParseException e) {
return new Date(date);
}
}
/**
* 获取文件名称
*
* @param path
* 文件路经
* @return String
*/
public static String getFileName(String path) {
int index = path.lastIndexOf('/');
String fileName = "";
if (index == -1) {
index = path.lastIndexOf('\\');
}
fileName = path.substring(index + 1);
return fileName;
}
public static String getFileName(String prefix, String extension)
throws UnsupportedEncodingException {
// prefix = MessageUtility.getValidFileName(prefix);
// UTF8 URL encoding only works in IE, not Mozilla
String fileName = URLEncoder.encode(prefix);
// Bug of IE (http://support.microsoft.com/?kbid=816868)
// Cannot be more than 150(I don't know the exact number)
int limit = 150 - extension.length();
if (fileName.length() > limit) {
// because the UTF-8 encoding scheme uses 9 bytes to represent a
// single CJK character
fileName = URLEncoder.encode(prefix.substring(0, Math.min(prefix
.length(), limit / 9)));
}
return fileName + extension;
}
/**
* 将日期数组转换成字符串数组
*
* @param dates
* Date[] 日期数组
* @return String[] 字符串数组
*/
public static String[] dateArrayTOStringArray(Date[] dates) {
if (dates == null) {
return null;
}
SimpleDateFormat format = DataFormatUtil.getSimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String[] dates_s = new String[dates.length];
for (int i = 0; i < dates.length; i++) {
dates_s[i] = format.format(dates[i]);
}
return dates_s;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static Date[] stringArrayTODateArray(String[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
Date[] dates = new Date[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
if(dateformat != null)
{
try {
dates[i] = dateformat.parse((dates_s[i]));
} catch (ParseException e) {
long dl = Long.parseLong(dates_s[i]);
dates[i] = new Date(dl);
}
}
else
{
try
{
dates[i] = new Date(dates_s[i]);
}
catch (Exception e)
{
long dl = Long.parseLong(dates_s[i]);
dates[i] = new Date(dl);
}
}
}
return dates;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static Date[] longArrayTODateArray(long[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
Date[] dates = new Date[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
{
dates[i] = new Date(dates_s[i]);
}
}
return dates;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static java.sql.Date[] stringArrayTOSQLDateArray(String[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
java.sql.Date[] dates = new java.sql.Date[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
if(dateformat != null)
{
try {
dates[i] = new java.sql.Date(dateformat.parse((dates_s[i]))
.getTime());
} catch (ParseException e) {
// dates[i] = new java.sql.Date(new java.util.Date(dates_s[i])
// .getTime());
long dl = Long.parseLong(dates_s[i]);
dates[i] = new java.sql.Date(dl);
}
}
else
{
try
{
dates[i] = new java.sql.Date(new Date(dates_s[i])
.getTime());
}
catch (Exception e)
{
long dl = Long.parseLong(dates_s[i]);
dates[i] = new java.sql.Date(dl);
}
}
}
return dates;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static java.sql.Date[] longArrayTOSQLDateArray(long[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
java.sql.Date[] dates = new java.sql.Date[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
{
dates[i] = new java.sql.Date(dates_s[i]);
}
}
return dates;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static java.sql.Timestamp[] stringArrayTOTimestampArray(String[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
java.sql.Timestamp[] dates = new java.sql.Timestamp[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
if(dateformat != null)
{
try {
dates[i] = new java.sql.Timestamp(dateformat.parse((dates_s[i]))
.getTime());
} catch (ParseException e) {
long dl = Long.parseLong(dates_s[i]);
dates[i] = new java.sql.Timestamp(dl);
// dates[i] = new java.sql.Timestamp(new java.util.Date(dates_s[i])
// .getTime());
}
}
else
{
try
{
dates[i] = new java.sql.Timestamp(new Date(dates_s[i])
.getTime());
}
catch (Exception e)
{
long dl = Long.parseLong(dates_s[i]);
dates[i] = new java.sql.Timestamp(dl);
}
}
}
return dates;
}
/**
* 将字符串数组转换成日期数组
*
* Date[] 字符串数组
* @return String[] 日期数组
*/
public static java.sql.Timestamp[] longArrayTOTimestampArray(long[] dates_s,DateFormat dateformat) {
if (dates_s == null) {
return null;
}
java.sql.Timestamp[] dates = new java.sql.Timestamp[dates_s.length];
for (int i = 0; i < dates_s.length; i++) {
{
dates[i] = new java.sql.Timestamp(dates_s[i]);
}
}
return dates;
}
/**
* Replaces all occurrences of a String within another String.
*
* A {@code null} reference passed to this method is a no-op.
*
*
* StringUtils.replace(null, *, *) = null
* StringUtils.replace("", *, *) = ""
* StringUtils.replace("any", null, *) = "any"
* StringUtils.replace("any", *, null) = "any"
* StringUtils.replace("any", "", *) = "any"
* StringUtils.replace("aba", "a", null) = "aba"
* StringUtils.replace("aba", "a", "") = "b"
* StringUtils.replace("aba", "a", "z") = "zbz"
*
*
* @see #replace(String text, String searchString, String replacement, int max)
* @param text text to search and replace in, may be null
* @param searchString the String to search for, may be null
* @param replacement the String to replace it with, may be null
* @return the text with any replacements processed,
* {@code null} if null String input
*/
public static String replace(String text, String searchString, String replacement) {
return replace(text, searchString, replacement, -1);
}
/**
* Represents a failed index search.
* @since 2.1
*/
public static final int INDEX_NOT_FOUND = -1;
/**
* Replaces a String with another String inside a larger String,
* for the first {@code max} values of the search String.
*
* A {@code null} reference passed to this method is a no-op.
*
*
* StringUtils.replace(null, *, *, *) = null
* StringUtils.replace("", *, *, *) = ""
* StringUtils.replace("any", null, *, *) = "any"
* StringUtils.replace("any", *, null, *) = "any"
* StringUtils.replace("any", "", *, *) = "any"
* StringUtils.replace("any", *, *, 0) = "any"
* StringUtils.replace("abaa", "a", null, -1) = "abaa"
* StringUtils.replace("abaa", "a", "", -1) = "b"
* StringUtils.replace("abaa", "a", "z", 0) = "abaa"
* StringUtils.replace("abaa", "a", "z", 1) = "zbaa"
* StringUtils.replace("abaa", "a", "z", 2) = "zbza"
* StringUtils.replace("abaa", "a", "z", -1) = "zbzz"
*
*
* @param text text to search and replace in, may be null
* @param searchString the String to search for, may be null
* @param replacement the String to replace it with, may be null
* @param max maximum number of values to replace, or {@code -1} if no maximum
* @return the text with any replacements processed,
* {@code null} if null String input
*/
public static String replace(String text, String searchString, String replacement, int max) {
if (isEmpty(text) || isEmpty(searchString) || replacement == null || max == 0) {
return text;
}
int start = 0;
int end = text.indexOf(searchString, start);
if (end == INDEX_NOT_FOUND) {
return text;
}
int replLength = searchString.length();
int increase = replacement.length() - replLength;
increase = increase < 0 ? 0 : increase;
increase *= max < 0 ? 16 : max > 64 ? 64 : max;
StringBuilder buf = new StringBuilder(text.length() + increase);
while (end != INDEX_NOT_FOUND) {
buf.append(text.substring(start, end)).append(replacement);
start = end + replLength;
if (--max == 0) {
break;
}
end = text.indexOf(searchString, start);
}
buf.append(text.substring(start));
return buf.toString();
}
/**
* The empty String {@code ""}.
* @since 2.0
*/
public static final String EMPTY = "";
/**
*
* @param str
* @param searchChars
* @param replaceChars
* @return
*/
public static String replaceChars(String str, String searchChars, String replaceChars) {
if (isEmpty(str) || isEmpty(searchChars)) {
return str;
}
if (replaceChars == null) {
replaceChars = EMPTY;
}
boolean modified = false;
int replaceCharsLength = replaceChars.length();
int strLength = str.length();
StringBuilder buf = new StringBuilder(strLength);
for (int i = 0; i < strLength; i++) {
char ch = str.charAt(i);
int index = searchChars.indexOf(ch);
if (index >= 0) {
modified = true;
if (index < replaceCharsLength) {
buf.append(replaceChars.charAt(index));
}
} else {
buf.append(ch);
}
}
if (modified) {
return buf.toString();
}
return str;
}
public static String replaceNull(String resource) {
return resource == null ? "" : resource;
}
/**
* Translates a string into application/x-www-form-urlencoded
* format using a specific encoding scheme. This method uses the supplied
* encoding scheme to obtain the bytes for unsafe characters.
*
* Note: The
* World Wide Web Consortium Recommendation states that
* UTF-8 should be used. Not doing so may introduce
* incompatibilites.
*
* @param s
* String
to be translated.
* @param enc
* The name of a supported character encoding
* .
* @return the translated String
.
* @exception UnsupportedEncodingException
* If the named encoding is not supported
* @see URLDecoder#decode(String, String)
* @since 1.4
*/
public static String encode(String s, String enc) {
if (enc == null || enc.trim().equals("")) {
enc = getDfltEncName();
}
boolean needToChange = false;
boolean wroteUnencodedChar = false;
int maxBytesPerChar = 10; // rather arbitrary limit, but safe for now
StringBuilder out = new StringBuilder(s.length());
ByteArrayOutputStream buf = new ByteArrayOutputStream(maxBytesPerChar);
OutputStreamWriter writer = null;
try {
writer = new OutputStreamWriter(buf, enc);
} catch (UnsupportedEncodingException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
for (int i = 0; i < s.length(); i++) {
int c = (int) s.charAt(i);
// System.out.println("Examining character: " + c);
if (initDontNeedEncoding().get(c)) {
if (c == ' ') {
c = '+';
needToChange = true;
}
// System.out.println("Storing: " + c);
out.append((char) c);
wroteUnencodedChar = true;
} else {
// convert to external encoding before hex conversion
try {
if (wroteUnencodedChar) { // Fix for 4407610
writer = new OutputStreamWriter(buf, enc);
wroteUnencodedChar = false;
}
writer.write(c);
/*
* If this character represents the start of a Unicode
* surrogate pair, then pass in two characters. It's not
* clear what should be done if a bytes reserved in the
* surrogate pairs range occurs outside of a legal surrogate
* pair. For now, just treat it as if it were any other
* character.
*/
if (c >= 0xD800 && c <= 0xDBFF) {
/*
* System.out.println(Integer.toHexString(c) + " is high
* surrogate");
*/
if ((i + 1) < s.length()) {
int d = (int) s.charAt(i + 1);
/*
* System.out.println("\tExamining " +
* Integer.toHexString(d));
*/
if (d >= 0xDC00 && d <= 0xDFFF) {
/*
* System.out.println("\t" +
* Integer.toHexString(d) + " is low
* surrogate");
*/
writer.write(d);
i++;
}
}
}
writer.flush();
} catch (IOException e) {
buf.reset();
continue;
}
byte[] ba = buf.toByteArray();
for (int j = 0; j < ba.length; j++) {
out.append('%');
char ch = Character.forDigit((ba[j] >> 4) & 0xF, 16);
// converting to use uppercase letter as part of
// the hex value if ch is a letter.
if (Character.isLetter(ch)) {
ch -= caseDiff;
}
out.append(ch);
ch = Character.forDigit(ba[j] & 0xF, 16);
if (Character.isLetter(ch)) {
ch -= caseDiff;
}
out.append(ch);
}
buf.reset();
needToChange = true;
}
}
return (needToChange ? out.toString() : s);
}
/**
* Translates a string into application/x-www-form-urlencoded
* format using a specific encoding scheme. This method uses the supplied
* encoding scheme to obtain the bytes for unsafe characters.
*
* Note: The
* World Wide Web Consortium Recommendation states that
* UTF-8 should be used. Not doing so may introduce
* incompatibilites.
*
* @param s
* String
to be translated.
* The name of a supported character encoding
* .
* @return the translated String
.
* @exception UnsupportedEncodingException
* If the named encoding is not supported
* @see URLDecoder#decode(String, String)
* @since 1.4
*/
public static String encode(String s) {
return encode(s, getDfltEncName());
}
public static String toUTF(String inpara) {
char temchr;
int ascchr;
int i;
String rtstr = new String("");
if (inpara == null) {
inpara = "";
}
for (i = 0; i < inpara.length(); i++) {
temchr = inpara.charAt(i);
ascchr = temchr + 0;
// System.out.println(ascchr);
// System.out.println(Integer.toBinaryString(ascchr));
rtstr = rtstr + "" + Integer.toHexString(ascchr) + ";";
}
return rtstr;
}
public static String toGB2312(String inpara) {
// System.out.println("原来的字符串为:" + inpara);
if (inpara == null) {
inpara = "";
}
try {
char[] temp = inpara.toCharArray();
byte[] b = new byte[temp.length];
// System.out.println("分成char[]后字符串的为:" + temp);
// System.out.println("传递字符串的长度为:" + temp.length);
int tempint;
for (int i = 0; i < temp.length; i++) {
b[i] = (byte) temp[i];
tempint = (int) b[i];
// System.out.println("第" + i + "个字符的编码为:" + tempint +
// "\t二进制码为:" +
// Integer.toBinaryString(tempint));
}
String deststring = new String(b, "gb2312");
// System.out.println(deststring);
return deststring;
} catch (UnsupportedEncodingException e) {
return "不支持的字符编码";
}
}
public List splitString(String src, int size) {
if (src == null)
return null;
List segs = new ArrayList();
StringBuilder seg = new StringBuilder();
while (src.length() > size) {
}
if (src.length() <= size) {
segs.add(src);
return segs;
}
// int length = msg.length();
// int splitNum = (int) (length / step) + 1;
// boolean flag = true;
// if (splitNum > 10) {
// splitNum = 10;
// flag = false;
// }
// int len = 0;
// for (int i = 0; i < splitNum; i++) {
// if (i == 0) {
// String spMsg = msg.substring(0, step) +
// getFirstEnd(splitNum);
// v.addElement(spMsg);
// spMsg = null;
// len = step;
// continue;
// }
// if (i == splitNum - 1) {
// String spMsg = null;
// if (flag == false)
// spMsg = getSecondFirst(i, splitNum) +
// msg.substring(len, len + step);
// v.addElement(spMsg);
// spMsg = null;
// continue;
// }
// String spMsg = null;
// spMsg = getSecondFirst(i, splitNum) +
// msg.substring(len, len + step) +
// getSecondEnd(i, splitNum);
// v.addElement(spMsg);
// spMsg = null;
// }
return null;
}
public String splitString(String src, int offset, int size) {
if (src == null || src.equals("")) {
return "";
}
if (offset < src.length()) {
return src.substring(offset, size);
} else {
int newoffset = src.length() % size;
}
return (String) splitString(src, size).get(offset);
}
public static String replaceNull(String value, String nullReplace) {
return value == null ? nullReplace : value;
}
public static boolean getBoolean(String value, boolean nullReplace) {
boolean ret = false;
if (value == null)
ret = nullReplace;
else if (value.trim().equalsIgnoreCase("true"))
ret = true;
else
ret = false;
return ret;
}
public static int getInt(String value, int defaultValue) {
try {
return Integer.parseInt(value);
} catch (Exception e) {
return defaultValue;
}
}
/**
* 判断链接是否是javascript函数
*
* @param nodeLink
* @return
*/
public static boolean isJavascript(String nodeLink) {
return nodeLink != null
&& nodeLink.toLowerCase().startsWith("javascript:");
}
/**
* 构建消息日志
*
* @param messages
* @return
*/
public static String buildStringMessage(List messages) {
if (messages == null || messages.size() == 0)
return null;
StringBuilder str = new StringBuilder();
for (int i = 0; i < messages.size(); i++) {
if (i == 0)
str.append(messages.get(i));
else
str.append("\\n").append(messages.get(i));
}
return str.toString();
}
public static boolean hasText(String str) {
return hasText((CharSequence) str);
}
/**
* Check whether the given CharSequence has actual text.
* More specifically, returns true
if the string not null
,
* its length is greater than 0, and it contains at least one non-whitespace character.
*
* StringUtils.hasText(null) = false
* StringUtils.hasText("") = false
* StringUtils.hasText(" ") = false
* StringUtils.hasText("12345") = true
* StringUtils.hasText(" 12345 ") = true
*
* @param str the CharSequence to check (may be null
)
* @return true
if the CharSequence is not null
,
* its length is greater than 0, and it does not contain whitespace only
* @see Character#isWhitespace
*/
public static boolean hasText(CharSequence str) {
if (!hasLength(str)) {
return false;
}
int strLen = str.length();
for (int i = 0; i < strLen; i++) {
if (!Character.isWhitespace(str.charAt(i))) {
return true;
}
}
return false;
}
/**
* Check that the given CharSequence is neither null
nor of length 0.
* Note: Will return true
for a CharSequence that purely consists of whitespace.
*
* StringUtils.hasLength(null) = false
* StringUtils.hasLength("") = false
* StringUtils.hasLength(" ") = true
* StringUtils.hasLength("Hello") = true
*
* @param str the CharSequence to check (may be null
)
* @return true
if the CharSequence is not null and has length
* @see #hasText(String)
*/
public static boolean hasLength(CharSequence str) {
return (str != null && str.length() > 0);
}
/**
* Test if the given String starts with the specified prefix,
* ignoring upper/lower case.
* @param str the String to check
* @param prefix the prefix to look for
* @see String#startsWith
*/
public static boolean startsWithIgnoreCase(String str, String prefix) {
if (str == null || prefix == null) {
return false;
}
if (str.startsWith(prefix)) {
return true;
}
if (str.length() < prefix.length()) {
return false;
}
String lcStr = str.substring(0, prefix.length()).toLowerCase();
String lcPrefix = prefix.toLowerCase();
return lcStr.equals(lcPrefix);
}
/**
* Compare two paths after normalization of them.
* @param path1 first path for comparison
* @param path2 second path for comparison
* @return whether the two paths are equivalent after normalization
*/
public static boolean pathEquals(String path1, String path2) {
return cleanPath(path1).equals(cleanPath(path2));
}
/**
* Normalize the path by suppressing sequences like "path/.." and
* inner simple dots.
* The result is convenient for path comparison. For other uses,
* notice that Windows separators ("\") are replaced by simple slashes.
* @param path the original path
* @return the normalized path
*/
public static String cleanPath(String path) {
String pathToUse = replace(path, WINDOWS_FOLDER_SEPARATOR, FOLDER_SEPARATOR);
// Strip prefix from path to analyze, to not treat it as part of the
// first path element. This is necessary to correctly parse paths like
// "file:core/../core/io/Resource.class", where the ".." should just
// strip the first "core" directory while keeping the "file:" prefix.
int prefixIndex = pathToUse.indexOf(":");
String prefix = "";
if (prefixIndex != -1) {
prefix = pathToUse.substring(0, prefixIndex + 1);
pathToUse = pathToUse.substring(prefixIndex + 1);
}
String[] pathArray = delimitedListToStringArray(pathToUse, FOLDER_SEPARATOR);
List pathElements = new LinkedList();
int tops = 0;
for (int i = pathArray.length - 1; i >= 0; i--) {
if (CURRENT_PATH.equals(pathArray[i])) {
// Points to current directory - drop it.
}
else if (TOP_PATH.equals(pathArray[i])) {
// Registering top path found.
tops++;
}
else {
if (tops > 0) {
// Merging path element with corresponding to top path.
tops--;
}
else {
// Normal path element found.
pathElements.add(0, pathArray[i]);
}
}
}
// Remaining top paths need to be retained.
for (int i = 0; i < tops; i++) {
pathElements.add(0, TOP_PATH);
}
return prefix + collectionToDelimitedString(pathElements, FOLDER_SEPARATOR);
}
/**
* Take a String which is a delimited list and convert it to a String array.
*
A single delimiter can consists of more than one character: It will still
* be considered as single delimiter string, rather than as bunch of potential
* delimiter characters - in contrast to tokenizeToStringArray
.
* @param str the input String
* @param delimiter the delimiter between elements (this is a single delimiter,
* rather than a bunch individual delimiter characters)
* @return an array of the tokens in the list
* @see #tokenizeToStringArray
*/
public static String[] delimitedListToStringArray(String str, String delimiter) {
return delimitedListToStringArray(str, delimiter, null);
}
/**
* Take a String which is a delimited list and convert it to a String array.
*
A single delimiter can consists of more than one character: It will still
* be considered as single delimiter string, rather than as bunch of potential
* delimiter characters - in contrast to tokenizeToStringArray
.
* @param str the input String
* @param delimiter the delimiter between elements (this is a single delimiter,
* rather than a bunch individual delimiter characters)
* @param charsToDelete a set of characters to delete. Useful for deleting unwanted
* line breaks: e.g. "\r\n\f" will delete all new lines and line feeds in a String.
* @return an array of the tokens in the list
* @see #tokenizeToStringArray
*/
public static String[] delimitedListToStringArray(String str, String delimiter, String charsToDelete) {
if (str == null) {
return new String[0];
}
if (delimiter == null) {
return new String[] {str};
}
List result = new ArrayList();
if ("".equals(delimiter)) {
for (int i = 0; i < str.length(); i++) {
result.add(deleteAny(str.substring(i, i + 1), charsToDelete));
}
}
else {
int pos = 0;
int delPos = 0;
while ((delPos = str.indexOf(delimiter, pos)) != -1) {
result.add(deleteAny(str.substring(pos, delPos), charsToDelete));
pos = delPos + delimiter.length();
}
if (str.length() > 0 && pos <= str.length()) {
// Add rest of String, but not in case of empty input.
result.add(deleteAny(str.substring(pos), charsToDelete));
}
}
return toStringArray(result);
}
/**
* Copy the given Collection into a String array.
* The Collection must contain String elements only.
* @param collection the Collection to copy
* @return the String array (null
if the passed-in
* Collection was null
)
*/
public static String[] toStringArray(Collection collection) {
if (collection == null) {
return null;
}
return (String[]) collection.toArray(new String[collection.size()]);
}
/**
* Copy the given Collection into a String array.
* The Collection must contain String elements only.
* @param collection the Collection to copy
* @return the String array (null
if the passed-in
* Collection was null
)
*/
public static Integer[] toIntArray(Collection collection) {
if (collection == null) {
return null;
}
return (Integer[]) collection.toArray(new Integer[collection.size()]);
}
/**
* Copy the given Enumeration into a String array.
* The Enumeration must contain String elements only.
* @param enumeration the Enumeration to copy
* @return the String array (null
if the passed-in
* Enumeration was null
)
*/
public static String[] toStringArray(Enumeration enumeration) {
if (enumeration == null) {
return null;
}
List list = Collections.list(enumeration);
return (String[]) list.toArray(new String[list.size()]);
}
/**
* Trim the elements of the given String array,
* calling String.trim()
on each of them.
* @param array the original String array
* @return the resulting array (of the same size) with trimmed elements
*/
public static String[] trimArrayElements(String[] array) {
if (ObjectUtils.isEmpty(array)) {
return new String[0];
}
String[] result = new String[array.length];
for (int i = 0; i < array.length; i++) {
String element = array[i];
result[i] = (element != null ? element.trim() : null);
}
return result;
}
/**
* Remove duplicate Strings from the given array.
* Also sorts the array, as it uses a TreeSet.
* @param array the String array
* @return an array without duplicates, in natural sort order
*/
public static String[] removeDuplicateStrings(String[] array) {
if (ObjectUtils.isEmpty(array)) {
return array;
}
Set set = new TreeSet();
for (int i = 0; i < array.length; i++) {
set.add(array[i]);
}
return toStringArray(set);
}
/**
* Delete any character in a given String.
* @param inString the original String
* @param charsToDelete a set of characters to delete.
* E.g. "az\n" will delete 'a's, 'z's and new lines.
* @return the resulting String
*/
public static String deleteAny(String inString, String charsToDelete) {
if (!hasLength(inString) || !hasLength(charsToDelete)) {
return inString;
}
StringBuilder out = new StringBuilder();
for (int i = 0; i < inString.length(); i++) {
char c = inString.charAt(i);
if (charsToDelete.indexOf(c) == -1) {
out.append(c);
}
}
return out.toString();
}
/**
* Convenience method to return a Collection as a delimited (e.g. CSV)
* String. E.g. useful for toString()
implementations.
* @param coll the Collection to display
* @param delim the delimiter to use (probably a ",")
* @param prefix the String to start each element with
* @param suffix the String to end each element with
* @return the delimited String
*/
public static String collectionToDelimitedString(Collection coll, String delim, String prefix, String suffix) {
if (CollectionUtils.isEmpty(coll)) {
return "";
}
StringBuilder sb = new StringBuilder();
Iterator it = coll.iterator();
while (it.hasNext()) {
sb.append(prefix).append(it.next()).append(suffix);
if (it.hasNext()) {
sb.append(delim);
}
}
return sb.toString();
}
/**
* Convenience method to return a Collection as a delimited (e.g. CSV)
* String. E.g. useful for toString()
implementations.
* @param coll the Collection to display
* @param delim the delimiter to use (probably a ",")
* @return the delimited String
*/
public static String collectionToDelimitedString(Collection coll, String delim) {
return collectionToDelimitedString(coll, delim, "", "");
}
/**
* Convenience method to return a Collection as a CSV String.
* E.g. useful for toString()
implementations.
* @param coll the Collection to display
* @return the delimited String
*/
public static String collectionToCommaDelimitedString(Collection coll) {
return collectionToDelimitedString(coll, ",");
}
/**
* Tokenize the given String into a String array via a StringTokenizer.
* Trims tokens and omits empty tokens.
* The given delimiters string is supposed to consist of any number of
* delimiter characters. Each of those characters can be used to separate
* tokens. A delimiter is always a single character; for multi-character
* delimiters, consider using delimitedListToStringArray
* @param str the String to tokenize
* @param delimiters the delimiter characters, assembled as String
* (each of those characters is individually considered as delimiter).
* @return an array of the tokens
* @see StringTokenizer
* @see String#trim()
* @see #delimitedListToStringArray
*/
public static String[] tokenizeToStringArray(String str, String delimiters) {
return tokenizeToStringArray(str, delimiters, true, true);
}
/**
* Tokenize the given String into a String array via a StringTokenizer.
*
The given delimiters string is supposed to consist of any number of
* delimiter characters. Each of those characters can be used to separate
* tokens. A delimiter is always a single character; for multi-character
* delimiters, consider using delimitedListToStringArray
* @param str the String to tokenize
* @param delimiters the delimiter characters, assembled as String
* (each of those characters is individually considered as delimiter)
* @param trimTokens trim the tokens via String's trim
* @param ignoreEmptyTokens omit empty tokens from the result array
* (only applies to tokens that are empty after trimming; StringTokenizer
* will not consider subsequent delimiters as token in the first place).
* @return an array of the tokens (null
if the input String
* was null
)
* @see StringTokenizer
* @see String#trim()
* @see #delimitedListToStringArray
*/
public static String[] tokenizeToStringArray(
String str, String delimiters, boolean trimTokens, boolean ignoreEmptyTokens) {
if (str == null) {
return null;
}
StringTokenizer st = new StringTokenizer(str, delimiters);
List tokens = new ArrayList();
while (st.hasMoreTokens()) {
String token = st.nextToken();
if (trimTokens) {
token = token.trim();
}
if (!ignoreEmptyTokens || token.length() > 0) {
tokens.add(token);
}
}
return toStringArray(tokens);
}
private static final String FOLDER_SEPARATOR = "/";
private static final String WINDOWS_FOLDER_SEPARATOR = "\\";
private static final String TOP_PATH = "..";
private static final String CURRENT_PATH = ".";
private static final char EXTENSION_SEPARATOR = '.';
/**
* Apply the given relative path to the given path,
* assuming standard Java folder separation (i.e. "/" separators);
* @param path the path to start from (usually a full file path)
* @param relativePath the relative path to apply
* (relative to the full file path above)
* @return the full file path that results from applying the relative path
*/
public static String applyRelativePath(String path, String relativePath) {
int separatorIndex = path.lastIndexOf(FOLDER_SEPARATOR);
if (separatorIndex != -1) {
String newPath = path.substring(0, separatorIndex);
if (!relativePath.startsWith(FOLDER_SEPARATOR)) {
newPath += FOLDER_SEPARATOR;
}
return newPath + relativePath;
}
else {
return relativePath;
}
}
/**
* Extract the filename from the given path,
* e.g. "mypath/myfile.txt" -> "myfile.txt".
* @param path the file path (may be null
)
* @return the extracted filename, or null
if none
*/
public static String getFilename(String path) {
if (path == null) {
return null;
}
int separatorIndex = path.lastIndexOf(FOLDER_SEPARATOR);
return (separatorIndex != -1 ? path.substring(separatorIndex + 1) : path);
}
/**
* Convenience method to return a String array as a CSV String.
* E.g. useful for toString()
implementations.
* @param arr the array to display
* @return the delimited String
*/
public static String arrayToCommaDelimitedString(Object[] arr) {
return arrayToDelimitedString(arr, ",");
}
/**
* Convenience method to return a String array as a delimited (e.g. CSV)
* String. E.g. useful for toString()
implementations.
* @param arr the array to display
* @param delim the delimiter to use (probably a ",")
* @return the delimited String
*/
public static String arrayToDelimitedString(Object[] arr, String delim) {
if (ObjectUtils.isEmpty(arr)) {
return "";
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < arr.length; i++) {
if (i > 0) {
sb.append(delim);
}
sb.append(arr[i]);
}
return sb.toString();
}
/**
* Trim trailing whitespace from the given String.
* @param str the String to check
* @return the trimmed String
* @see Character#isWhitespace
*/
public static String trimTrailingWhitespace(String str) {
if (!hasLength(str)) {
return str;
}
StringBuilder buf = new StringBuilder(str);
while (buf.length() > 0 && Character.isWhitespace(buf.charAt(buf.length() - 1))) {
buf.deleteCharAt(buf.length() - 1);
}
return buf.toString();
}
/**
* Trim all occurences of the supplied leading character from the given String.
* @param str the String to check
* @param leadingCharacter the leading character to be trimmed
* @return the trimmed String
*/
public static String trimLeadingCharacter(String str, char leadingCharacter) {
if (!hasLength(str)) {
return str;
}
StringBuilder buf = new StringBuilder(str);
while (buf.length() > 0 && buf.charAt(0) == leadingCharacter) {
buf.deleteCharAt(0);
}
return buf.toString();
}
/**
* Trim all occurences of the supplied trailing character from the given String.
* @param str the String to check
* @param trailingCharacter the trailing character to be trimmed
* @return the trimmed String
*/
public static String trimTrailingCharacter(String str, char trailingCharacter) {
if (!hasLength(str)) {
return str;
}
StringBuilder buf = new StringBuilder(str);
while (buf.length() > 0 && buf.charAt(buf.length() - 1) == trailingCharacter) {
buf.deleteCharAt(buf.length() - 1);
}
return buf.toString();
}
/**
* Trim leading whitespace from the given String.
* @param str the String to check
* @return the trimmed String
* @see Character#isWhitespace
*/
public static String trimLeadingWhitespace(String str) {
if (!hasLength(str)) {
return str;
}
StringBuilder buf = new StringBuilder(str);
while (buf.length() > 0 && Character.isWhitespace(buf.charAt(0))) {
buf.deleteCharAt(0);
}
return buf.toString();
}
/**
* Count the occurrences of the substring in string s.
* @param str string to search in. Return 0 if this is null.
* @param sub string to search for. Return 0 if this is null.
*/
public static int countOccurrencesOf(String str, String sub) {
if (str == null || sub == null || str.length() == 0 || sub.length() == 0) {
return 0;
}
int count = 0, pos = 0, idx = 0;
while ((idx = str.indexOf(sub, pos)) != -1) {
++count;
pos = idx + sub.length();
}
return count;
}
/**
* Strip the filename extension from the given path,
* e.g. "mypath/myfile.txt" -> "mypath/myfile".
* @param path the file path (may be null
)
* @return the path with stripped filename extension,
* or null
if none
*/
public static String stripFilenameExtension(String path) {
if (path == null) {
return null;
}
int sepIndex = path.lastIndexOf(EXTENSION_SEPARATOR);
return (sepIndex != -1 ? path.substring(0, sepIndex) : path);
}
/**
* Convert a CSV list into an array of Strings.
* @param str the input String
* @return an array of Strings, or the empty array in case of empty input
*/
public static String[] commaDelimitedListToStringArray(String str) {
return delimitedListToStringArray(str, ",");
}
/**
* Append the given String to the given String array, returning a new array
* consisting of the input array contents plus the given String.
* @param array the array to append to (can be null
)
* @param str the String to append
* @return the new array (never null
)
*/
public static String[] addStringToArray(String[] array, String str) {
if (ObjectUtils.isEmpty(array)) {
return new String[] {str};
}
String[] newArr = new String[array.length + 1];
System.arraycopy(array, 0, newArr, 0, array.length);
newArr[array.length] = str;
return newArr;
}
/**
* Trim all whitespace from the given String:
* leading, trailing, and inbetween characters.
* @param str the String to check
* @return the trimmed String
* @see Character#isWhitespace
*/
public static String trimAllWhitespace(String str) {
if (!hasLength(str)) {
return str;
}
StringBuilder buf = new StringBuilder(str);
int index = 0;
while (buf.length() > index) {
if (Character.isWhitespace(buf.charAt(index))) {
buf.deleteCharAt(index);
}
else {
index++;
}
}
return buf.toString();
}
/**
* Parse the given localeString
into a {@link Locale}.
*
This is the inverse operation of {@link Locale#toString Locale's toString}.
* @param localeString the locale string, following Locale's
* toString()
format ("en", "en_UK", etc);
* also accepts spaces as separators, as an alternative to underscores
* @return a corresponding Locale
instance
*/
public static Locale parseLocaleString(String localeString) {
String[] parts = tokenizeToStringArray(localeString, "_ ", false, false);
String language = (parts.length > 0 ? parts[0] : "");
String country = (parts.length > 1 ? parts[1] : "");
String variant = "";
if (parts.length >= 2) {
// There is definitely a variant, and it is everything after the country
// code sans the separator between the country code and the variant.
int endIndexOfCountryCode = localeString.indexOf(country) + country.length();
// Strip off any leading '_' and whitespace, what's left is the variant.
variant = trimLeadingWhitespace(localeString.substring(endIndexOfCountryCode));
if (variant.startsWith("_")) {
variant = trimLeadingCharacter(variant, '_');
}
}
return (language.length() > 0 ? new Locale(language, country, variant) : null);
}
/**
* Determine the RFC 3066 compliant language tag,
* as used for the HTTP "Accept-Language" header.
* @param locale the Locale to transform to a language tag
* @return the RFC 3066 compliant language tag as String
*/
public static String toLanguageTag(Locale locale) {
return locale.getLanguage() + (hasText(locale.getCountry()) ? "-" + locale.getCountry() : "");
}
/**
* Extract the filename extension from the given path,
* e.g. "mypath/myfile.txt" -> "txt".
* @param path the file path (may be null
)
* @return the extracted filename extension, or null
if none
*/
public static String getFilenameExtension(String path) {
if (path == null) {
return null;
}
int sepIndex = path.lastIndexOf(EXTENSION_SEPARATOR);
return (sepIndex != -1 ? path.substring(sepIndex + 1) : null);
}
public static final String AOP_PROPERTIES_PATH = "/aop.properties";
public static InputStream getInputStream(String resourcefile,Class clazz) throws IOException {
InputStream is = null;
is = clazz.getResourceAsStream(resourcefile);
if (is == null) {
throw new FileNotFoundException(resourcefile
+ " cannot be opened because it does not exist");
}
return is;
}
public static Properties getProperties(String resourcefile,Class clazz) throws IOException {
InputStream is = getInputStream(resourcefile,clazz);
try {
Properties props = new Properties();
props.load(is);
return props;
} finally {
is.close();
}
}
public static boolean isEmpty(String value)
{
return value == null || "".equals(value);
}
public static boolean isNotEmpty(String value)
{
return value != null && !"".equals(value);
}
public static boolean isEmpty(Collection cl)
{
return cl == null || cl.size() == 0;
}
public static boolean isNotEmpty(Collection cl)
{
return !isEmpty( cl);
}
public static boolean isEmpty(Object obj)
{
if(obj == null)
return true;
if(obj instanceof String)
{
return isEmpty((String)obj);
}
if(obj instanceof Collection)
{
return isEmpty((Collection)obj);
}
else if(!obj.getClass().isArray())
{
return false;
}
else
{
return Array.getLength(obj) == 0;
}
}
public static boolean isNotEmpty(Object obj)
{
return !isEmpty( obj);
}
public static String formatException(Throwable exception)
{
StringWriter out = new StringWriter();
exception.printStackTrace(new PrintWriter(out));
String errorMessage = out.toString();
errorMessage = errorMessage.replaceAll("\\n",
"\\\\n");
errorMessage = errorMessage.replaceAll("\\r",
"\\\\r");
return errorMessage;
}
public static String formatBRException(Throwable exception)
{
StringWriter out = new StringWriter();
exception.printStackTrace(new PrintWriter(out));
String errorMessage = out.toString();
errorMessage = errorMessage.replaceAll("\\n",
"
");
errorMessage = errorMessage.replaceAll("\\r",
"
");
return errorMessage;
}
public static String exceptionToString(Throwable exception)
{
StringWriter out = new StringWriter();
try {
exception.printStackTrace(new PrintWriter(out));
String errorMessage = out.toString();
return errorMessage;
}
finally {
try {
out.close();
} catch (IOException e) {
}
}
// errorMessage = errorMessage.replaceAll("\\n",
// "\\\\n");
// errorMessage = errorMessage.replaceAll("\\r",
// "\\\\r");
}
// /**
// * 对value采用charset进行URLEncode编码,编码的次数根据encoudtimes指定
// * @param value
// * @param charset
// * @param encoudtimes
// * @return
// */
// public static String urlencode(String value,String charset,int encodecount)
// {
// if(value == null)
// return value;
// else if(encodecount <= 1)
// try {
// value = URLEncoder.encode(value,"UTF-8");
// } catch (UnsupportedEncodingException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
// else if(encodecount == 2)
// try {
// value = URLEncoder.encode(URLEncoder.encode(value,"UTF-8"),"UTF-8");
// } catch (UnsupportedEncodingException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
// else if(encodecount == 3)
// try {
// value = URLEncoder.encode(URLEncoder.encode(URLEncoder.encode(value,"UTF-8"),"UTF-8"),"UTF-8");
// } catch (UnsupportedEncodingException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
// else
// try {
// for(int i = 0; i < encodecount; i ++)
// {
// value = URLEncoder.encode(value,"UTF-8");
// }
// return value;
// } catch (Exception e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
// return value;
//
// }
/**
* 对value采用charset进行URLEncode编码,编码的次数根据encoudtimes指定
* @param value
* @param charset
* @param encodecount
* @return
*/
public static String urlencode(String value,String charset,int encodecount)
{
if(value == null)
return value;
else if(encodecount <= 1)
try {
value = URLEncoder.encode(value,charset);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
else if(encodecount == 2)
try {
value = URLEncoder.encode(URLEncoder.encode(value,charset),charset);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
else if(encodecount == 3)
try {
value = URLEncoder.encode(URLEncoder.encode(URLEncoder.encode(value,charset),charset),charset);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
else
try {
for(int i = 0; i < encodecount; i ++)
{
value = URLEncoder.encode(value,charset);
}
return value;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return value;
}
/**
* 对value采用charset进行URLEncode编码,编码的次数为1
* @param value
* @param charset
* @return
*/
public static String urlencode(String value,String charset)
{
return urlencode(value,charset,1);
}
private static Map localesIndexByString;
public static Locale getLocale(String locale)
{
return getAllLocales().get(locale);
}
/**
*
* @return
*/
public static Map getAllLocales()
{
if(localesIndexByString != null)
{
return localesIndexByString;
}
synchronized(BaseSimpleStringUtil.class)
{
if(localesIndexByString != null)
{
return localesIndexByString;
}
Map lm = new HashMap();
{
// if(locale.equals(Locale.SIMPLIFIED_CHINESE))
{
lm.put(String.valueOf(Locale.SIMPLIFIED_CHINESE), Locale.SIMPLIFIED_CHINESE);
}
// else if(locale.equals(Locale.ENGLISH))
{
lm.put(String.valueOf(Locale.ENGLISH), Locale.ENGLISH);
}
// else if(locale.equals(Locale.US))
{
lm.put(String.valueOf(Locale.US), Locale.US);
}
// else if(locale.equals(Locale.JAPANESE))
{
lm.put(String.valueOf(Locale.JAPANESE), Locale.JAPANESE);
}
// else if(locale.equals(Locale.FRENCH))
{
lm.put(String.valueOf(Locale.FRENCH), Locale.FRENCH);
}
// else if(locale.equals(Locale.CANADA_FRENCH))
{
lm.put(String.valueOf(Locale.CANADA_FRENCH), Locale.CANADA_FRENCH);
}
// else if(locale.equals(Locale.CANADA))
{
lm.put(String.valueOf(Locale.CANADA), Locale.CANADA);
}
// else if(locale.equals(Locale.UK))
{
lm.put(String.valueOf(Locale.UK), Locale.UK);
}
// else if(locale.equals(Locale.TAIWAN))
{
lm.put(String.valueOf(Locale.TAIWAN), Locale.TAIWAN);
}
// else if(locale.equals(Locale.PRC))
{
lm.put(String.valueOf(Locale.PRC), Locale.PRC);
}
// else if(locale.equals(Locale.KOREA))
{
lm.put(String.valueOf(Locale.KOREA), Locale.KOREA);
}
// else if(locale.equals(Locale.JAPAN))
{
lm.put(String.valueOf(Locale.JAPAN), Locale.JAPAN);
}
// else if(locale.equals(Locale.ITALY))
{
lm.put(String.valueOf(Locale.ITALY), Locale.ITALY);
}
// else if(locale.equals(Locale.GERMANY))
{
lm.put(String.valueOf(Locale.GERMANY), Locale.GERMANY);
}
// else if(locale.equals(Locale.FRANCE))
{
lm.put(String.valueOf(Locale.FRANCE), Locale.FRANCE);
}
// else if(locale.equals(Locale.TRADITIONAL_CHINESE))
{
lm.put(String.valueOf(Locale.TRADITIONAL_CHINESE), Locale.TRADITIONAL_CHINESE);
}
// else if(locale.equals(Locale.CHINESE))
{
lm.put(String.valueOf(Locale.CHINESE), Locale.CHINESE);
}
// else if(locale.equals(Locale.KOREAN))
{
lm.put(String.valueOf(Locale.KOREAN), Locale.KOREAN);
}
// else if(locale.equals(Locale.ITALIAN))
{
lm.put(String.valueOf(Locale.ITALIAN), Locale.ITALIAN);
}
// else if(locale.equals(Locale.GERMAN))
{
lm.put(String.valueOf(Locale.GERMAN), Locale.GERMAN);
}
lm.put("ROOT", Locale.ROOT);
// else
// {
// log.debug("不正确的语言代码:"+ locale);
// }
}
localesIndexByString = lm;
}
return localesIndexByString;
}
/**
*
* @param locales
* @return
*/
public static Map converLocales(String locales)
{
if(locales == null || locales.trim().equals(""))
return null;
String[] locales_ = locales.split("\\,");
Map lm = new HashMap();
for(String locale:locales_)
{
if(locale.equals(Locale.SIMPLIFIED_CHINESE.toString()))
{
lm.put(locale, Locale.SIMPLIFIED_CHINESE);
}
else if(locale.equals(Locale.ENGLISH.toString()))
{
lm.put(locale, Locale.ENGLISH);
}
else if(locale.equals(Locale.US.toString()))
{
lm.put(locale, Locale.US);
}
else if(locale.equals(Locale.JAPANESE.toString()))
{
lm.put(locale, Locale.JAPANESE);
}
else if(locale.equals(Locale.FRENCH.toString()))
{
lm.put(locale, Locale.FRENCH);
}
else if(locale.equals(Locale.CANADA_FRENCH.toString()))
{
lm.put(locale, Locale.CANADA_FRENCH);
}
else if(locale.equals(Locale.CANADA.toString()))
{
lm.put(locale, Locale.CANADA);
}
else if(locale.equals(Locale.UK.toString()))
{
lm.put(locale, Locale.UK);
}
else if(locale.equals(Locale.TAIWAN.toString()))
{
lm.put(locale, Locale.TAIWAN);
}
else if(locale.equals(Locale.PRC.toString()))
{
lm.put(locale, Locale.PRC);
}
else if(locale.equals(Locale.KOREA.toString()))
{
lm.put(locale, Locale.KOREA);
}
else if(locale.equals(Locale.JAPAN.toString()))
{
lm.put(locale, Locale.JAPAN);
}
else if(locale.equals(Locale.ITALY.toString()))
{
lm.put(locale, Locale.ITALY);
}
else if(locale.equals(Locale.GERMANY.toString()))
{
lm.put(locale, Locale.GERMANY);
}
else if(locale.equals(Locale.FRANCE.toString()))
{
lm.put(locale, Locale.FRANCE);
}
else if(locale.equals(Locale.TRADITIONAL_CHINESE.toString()))
{
lm.put(locale, Locale.TRADITIONAL_CHINESE);
}
else if(locale.equals(Locale.CHINESE.toString()))
{
lm.put(locale, Locale.CHINESE);
}
else if(locale.equals(Locale.KOREAN.toString()))
{
lm.put(locale, Locale.KOREAN);
}
else if(locale.equals(Locale.ITALIAN.toString()))
{
lm.put(locale, Locale.ITALIAN);
}
else if(locale.equals(Locale.GERMAN.toString()))
{
lm.put(locale, Locale.GERMAN);
}
else
{
logger.debug("不正确的语言代码:"+ locale + ",build new Locale for " + locale + "." );
lm.put(locale, new Locale(locale));
}
}
return lm;
}
public static String tostring(Object data)
{
StringBuilder ret = new StringBuilder();
tostring(ret ,data);
return ret.toString();
}
public static void tostring(StringBuilder ret ,Object data)
{
if(data == null )
{
return ;
}
else if(!data.getClass().isArray())
{
ret.append(data.toString());
}
else
{
int size = Array.getLength(data);
ret.append("{");
for(int i = 0; i < size; i ++)
{
if(i == 0)
{
}
else
{
ret.append(",");
}
tostring(ret ,Array.get(data, i));
}
ret.append("}");
}
}
public static String formatTimeToString(long mss) {
long days = mss / (1000 * 60 * 60 * 24);
long hours = (mss % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60);
long minutes = (mss % (1000 * 60 * 60)) / (1000 * 60);
long seconds = (mss % (1000 * 60)) / 1000;
StringBuilder sb = new StringBuilder();
if (days != 0) {
sb.append(days + "天");
}
if (hours != 0) {
sb.append(hours + "小时");
}
if (minutes != 0) {
sb.append(minutes + "分钟");
}
if (seconds != 0) {
sb.append(seconds + "秒");
}
return sb.toString();
}
public static Enumeration arryToenum(final Object[] values)
{
return new Enumeration()
{
int length = values!= null ?values.length:0;
int count = 0;
@Override
public boolean hasMoreElements() {
return count < length;
}
@Override
public Object nextElement() {
Object element = values[count];
count ++ ;
return element;
}
};
}
public static String native2ascii( String s )
{
StringBuilder res = new StringBuilder();
for ( int i = 0; i < s.length(); i++ ){
char ch = s.charAt( i );
int val = (int) ch;
if ( ch == '\r' ) continue;
if ( val >= 0 && val < 128 && ch != '\n' && ch != '\\' ) res.append( ch );
else{
res.append( "\\u" );
String hex = Integer.toHexString( val );
for( int j = 0; j < 4 - hex.length(); j++ ) res.append( "0" );
res.append( hex );
}
}
return res.toString();
}
public static String ascii2native( String s )
{
StringBuilder res = new StringBuilder(s.length());
for ( int i = 0; i < s.length(); i++ ){
char ch = s.charAt( i );
if (ch == '\\' && i+1>=s.length()){
res.append(ch);
break;
}
if ( ch != '\\') res.append( ch );
else {
switch (s.charAt(i+1)) {
case 'u':
res.append( (char) Integer.parseInt( s.substring( i+2, i+6 ), 16 ) );
i += 5;
break;
case 'n': res.append('\n'); i++; break;
case 't': res.append('\t'); i++; break;
case 'r': res.append('\r'); i++; break;
default: break;
}
}
}
return res.toString();
}
/**
* determine the OS name
*
* @return The name of the OS
*/
public static final String getOS() {
return System.getProperty("os.name");
}
/**
* @return True if the OS is a Windows derivate.
*/
public static final boolean isWindows() {
return getOS().startsWith("Windows");
}
/**
* @return True if the OS is a Linux derivate.
*/
public static final boolean isLinux() {
return getOS().startsWith("Linux");
}
/**
* @return True if the OS is an OSX derivate.
*/
public static final boolean isOSX() {
return getOS().toUpperCase().contains("OS X");
}
/**
* Constructs a new String
by decoding the specified array of bytes using the UTF-8 charset.
*
* @param bytes
* The bytes to be decoded into characters
* @return A new String
decoded from the specified array of bytes using the UTF-8 charset,
* or null
if the input byte array was null
.
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_8} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
*/
public static String newStringUtf8(final byte[] bytes) {
return newString(bytes, Charsets.UTF_8);
}
/**
* Constructs a new String
by decoding the specified array of bytes using the given charset.
*
* @param bytes
* The bytes to be decoded into characters
* @param charset
* The {@link Charset} to encode the String
* @return A new String
decoded from the specified array of bytes using the given charset,
* or null
if the input byte array was null
.
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_8} is not initialized, which should never happen since it is
* required by the Java platform specification.
*/
private static String newString(final byte[] bytes, final Charset charset) {
return bytes == null ? null : new String(bytes, charset);
}
/**
* Encodes the given string into a sequence of bytes using the US-ASCII charset, storing the result into a new byte
* array.
*
* @param string
* the String to encode, may be null
* @return encoded bytes, or null
if the input string was null
* @throws NullPointerException
* Thrown if {@link Charsets#US_ASCII} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
* @see Standard charsets
*/
public static byte[] getBytesUsAscii(final String string) {
return getBytes(string, Charsets.US_ASCII);
}
/**
* Encodes the given string into a sequence of bytes using the UTF-16 charset, storing the result into a new byte
* array.
*
* @param string
* the String to encode, may be null
* @return encoded bytes, or null
if the input string was null
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_16} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
* @see Standard charsets
*/
public static byte[] getBytesUtf16(final String string) {
return getBytes(string, Charsets.UTF_16);
}
/**
* Encodes the given string into a sequence of bytes using the UTF-16BE charset, storing the result into a new byte
* array.
*
* @param string
* the String to encode, may be null
* @return encoded bytes, or null
if the input string was null
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_16BE} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
* @see Standard charsets
*/
public static byte[] getBytesUtf16Be(final String string) {
return getBytes(string, Charsets.UTF_16BE);
}
/**
* Encodes the given string into a sequence of bytes using the UTF-16LE charset, storing the result into a new byte
* array.
*
* @param string
* the String to encode, may be null
* @return encoded bytes, or null
if the input string was null
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_16LE} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
* @see Standard charsets
*/
public static byte[] getBytesUtf16Le(final String string) {
return getBytes(string, Charsets.UTF_16LE);
}
/**
* Encodes the given string into a sequence of bytes using the UTF-8 charset, storing the result into a new byte
* array.
*
* @param string
* the String to encode, may be null
* @return encoded bytes, or null
if the input string was null
* @throws NullPointerException
* Thrown if {@link Charsets#UTF_8} is not initialized, which should never happen since it is
* required by the Java platform specification.
* @since As of 1.7, throws {@link NullPointerException} instead of UnsupportedEncodingException
* @see Standard charsets
*/
public static byte[] getBytesUtf8(final String string) {
return getBytes(string, Charsets.UTF_8);
}
/**
* Calls {@link String#getBytes(Charset)}
*
* @param string
* The string to encode (if null, return null).
* @param charset
* The {@link Charset} to encode the String
* @return the encoded bytes
*/
private static byte[] getBytes(final String string, final Charset charset) {
if (string == null) {
return null;
}
return string.getBytes(charset);
}
}