繁体中文
设为首页
加入收藏
当前位置:JSP技术首页 >> 资料/其它 >> 将文本格式的文章转换为html/xml格式文本的功能封装到Javabean

将文本格式的文章转换为html/xml格式文本的功能封装到Javabean

2005-04-15 08:00:00  作者:  来源:互联网  浏览次数:0  文字大小:【】【】【
简介:在将textarea里面的大段文字储存到数据库,然后提取出来以显示时,格式无效,因为此时是HTML格式,所以需要转换。 看到JK_10000在javascript区提供了此代码,就顺路牵来。 当然,碰到我这个代码格式化狂人,...

在将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;

}

}

责任编辑:admin
相关文章