在将textarea里面的大段文字储存到数据库,然后提取出来以显示时,格式无效,因为此时是HTML格式,所以需要转换。
看到JK_10000在javascript区提供了此代码,就顺路牵来。
当然,碰到我这个代码格式化狂人,是肯定要面目全非的,啊哈哈哈哈哈哈......
HTMLTextEncoder方法将文本格式转换为HTML格式。
XMLEncoder方法将文本格式转换为XML格式。
/**
* 字符串编码器类,将字符串转换为指定格式.
*
* 参数字典:
* src - source 来源的简写
* dst - destnation 目的的简写
* fnd - find 查找的简写
* rep - replace 替换的简写
* idx - index 索引,下标的简写
* enc - encoding 编码的简写
*
* 例子:
* <%=ArticleFormat.HTMLTextEncoder(yourString)%>
*/
public class StringEncoder
{
/**
* 将字符串src中的子字符串fnd全部替换为新子字符串rep.
* 功能相当于java sdk 1.4的String.replaceAll方法.
* 不同之处在于查找时不是使用正则表达式而是普通字符串.
*/
public static String replaceAll(String src, String fnd, String rep) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
String dst = src;
int idx = dst.indexOf(fnd);
while (idx >= 0)
{
dst = dst.substring(0, idx) + rep + dst.substring(idx + fnd.length(), dst.length());
idx = dst.indexOf(fnd, idx + rep.length());
}
return dst;
}
/**
* 转换为HTML编码.
*/
public static String HTMLEncoder(String src) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
String dst = src;
dst = replaceAll(dst, "<", "<");
dst = replaceAll(dst, ">", "&rt;");
dst = replaceAll(dst, "\"", """);
dst = replaceAll(dst, "'", "");
return dst;
}
/**
* 转换为HTML文字编码.
*/
public static String HTMLTextEncoder(String src) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
String dst = src;
dst = replaceAll(dst, "<", "<");
dst = replaceAll(dst, ">", "&rt;");
dst = replaceAll(dst, "\"", """);
dst = replaceAll(dst, "'", "");
dst = replaceAll(dst, " ", " ");
dst = replaceAll(dst, "\r\n", "
");
dst = replaceAll(dst, "\r", "
");
dst = replaceAll(dst, "\n", "
");
return dst;
}
/**
* 转换为URL编码.
*/
public static String urlEncoder(String src, String enc) throws Exception
{
return java.net.URLEncoder.encode(src, enc) ;
}
/**
* 转换为XML编码.
*/
public static String XMLEncoder(String src) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
String dst = src;
dst = replaceAll(dst, "&", "&");
dst = replaceAll(dst, "<", "<");
dst = replaceAll(dst, ">", ">");
dst = replaceAll(dst, "\"", """);
dst = replaceAll(dst, "\'", "´");
return dst;
}
/**
* 转换为SQL编码.
*/
public static String sqlEncoder(String src) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
return replaceAll(src, "'", "''");
}
/**
* 转换为javascript编码.
*/
public static String jsEncoder(String src) throws Exception
{
if (src == null || src.equals(""))
{
return "";
}
String dst = src;
dst = replaceAll(dst, "'", "\\'");
dst = replaceAll(dst, "\"", "\\\"");
//dst = replaceAll(dst, "\r\n", "\\\n"); // 和\n转换有冲突
dst = replaceAll(dst, "\n", "\\\n");
dst = replaceAll(dst, "\r", "\\\n");
return dst;
}
}

