{
buf.append(line2, j, i - j).append(newString2);
i += oLength;
j = i;
}
buf.append(line2, j, line2.length - j);
return buf.toString();
}
return line;
}
/*
-
将源字符串中的某些字符替换为指定的字符
-
@param str 源字符串
-
@param oldChar 要被替换的字符
-
@param newChar 替换的字符
-
@return 替换后的字符串
*/
public static String replaceChar(String str, char oldChar, char newChar)
{
str = convertStringNull(str);
if (str.length() > 0)
{
str = str.replace(oldChar, newChar);
}
return str;
}
/**
-
将传入的字符串转换为中文字符串,并将空字符串转换为""
-
@param strOrigin 原始字符串
-
@return 中文字符串
*/
public static String toChineseStr(String strOrigin)
{
if (strOrigin == null || strOrigin.equals(null))
{
strOrigin = “”;
}
else
{
strOrigin = strOrigin.trim();
}
try
{
strOrigin = new String(strOrigin.getBytes(“ISO8859_1”), “GBK”);
}
catch (Exception e)
{
}
return strOrigin;
}
/**
-
将中文字符串转换为ISO8859_1编码格式,并将空字符串转换为""
-
@param strOrigin 原始字符串(中文字符串)
-
@return 转换后的字符串
*/
public static String toStandardStr(String strOrigin)
{
if (strOrigin == null || strOrigin.equals(null))
{
strOrigin = “”;
}
else
{
strOrigin = strOrigin.trim();
}
try
{
strOrigin = new String(strOrigin.getBytes(“GBK”), “ISO8859_1”);
}
catch (Exception e)
{
}
return strOrigin;
}
/**
-
将字符串转换为utf-8编码格式
-
@param s 要转换的字符串
-
@return 转换后的字符串
*/
public static String toUtf8String(String s)
{
StringBuffer sb = new StringBuffer();
for (int i = 0; i < s.length(); i++)
{
char c = s.charAt(i);
if (c >= 0 && c <= 255)
{
sb.append©;
}
else
{
byte[] b;
try
{
b = new Character©.toString().getBytes(“utf-8”);
}
catch (Exception ex)
{
System.out.println(ex);
b = new byte[0];
}
for (int j = 0; j < b.length; j++)
{
int k = b[j];
if (k < 0)
k += 256;
sb.append(“%” + Integer.toHexString(k).toUpperCase());
}
}
}
return sb.toString();
}
/**
-
将字符串从原来的编码格式转换为指定的编码格式
-
@param strOrigin 原始字符串
-
@param originEncode 原始编码格式
-
@param desEncode 目标编码格式
-
@return 转换后的字符串
*/
public static String converStrEncode(String strOrigin, String originEncode,
String desEncode)
{
if (strOrigin == null || strOrigin.equals(null))
{
strOrigin = “”;
}
else
{
strOrigin = strOrigin.trim();
}
try
{
strOrigin = new String(strOrigin.getBytes(originEncode), desEncode);
}
catch (Exception e)
{
System.out.println(“字符串编码格式转换出错!”);
//e.printStackTrace();
}
return strOrigin;
}
/**
*将空格串" "或空指针转换为html的空格编码
-
@param strOrigin原始字符串
-
@return 返回转换后的字符串
*/
public static final String filterNullStringToHTMLSpace(String strOrigin)
{
if (strOrigin == null)
{
return " ";
}
else if (strOrigin.length() == 0)
{
return " ";
}
else
{
return strOrigin.trim();
}
}
/**
*将字符串转换成可以在HTML中正常显示的字符串,如在input框中显示< > ’ 等特殊字符,在这里<转变成了<
-
@param strOrigin 原始字符串
-
@return 返回转换后的字符串
*/
public static String toHTMLString(String strOrigin)
{
StringBuffer out = new StringBuffer();
for (int i = 0; strOrigin != null && i < strOrigin.length(); i++)
{
char c = strOrigin.charAt(i);
if (c == ‘’')
out.append(“'”);
else if (c == ‘"’)
out.append(“”");
else if (c == ‘<’)
out.append(“<”);
else if (c == ‘>’)
out.append(“>”);
else if (c == ‘&’)
out.append(“&”);
else if (c == ’ ')
out.append(" ");
else if (c == ‘\n’)
out.append(“
”);
else
out.append©;
}
return out.toString();
}
/**
*将字符串的HTML编码的字串转成正常的字符串
-
@param strOrigin 原始字符串
-
@return 返回转换后的字符串
*/
public static String UnEncodeHtml(String strOrigin)
{
int index = 0, pos = 0;
if (strOrigin == null || strOrigin.length() == 0)
return strOrigin;
StringBuffer buffer = new StringBuffer();
do
{
index = strOrigin.indexOf(‘&’);
if (index != -1)
{
pos = strOrigin.indexOf(‘;’);
if (strOrigin.charAt(index + 1) == ‘#’ && pos > 0)
{
String tmp = strOrigin.substring(index + 2, pos);
char ch = (char) Integer.parseInt(tmp);
buffer.append(ch);
}
else if (pos > 0)
{
String tmp = strOrigin.substring(index, pos + 1);
if (tmp.equals(“”"))
{
buffer.append(‘"’);
}
else if (tmp.equals(“&”))
{
buffer.append(‘&’);
}
else if (tmp.equals(“<”))
{
buffer.append(‘<’);
}
else if (tmp.equals(“>”))
{
buffer.append(‘>’);
}
else if (tmp.equals(" "))
{
buffer.append(’ ');
}
}