在类似留言板的web应用中,需要将<textarea>中的大段文字显示在Jsp页面上,因此需要对文字中的特殊字符如换行、空格的作处理,方法如下:
1、直接保存,然后当从数据库中取出来时用过滤方法过滤一遍再送回页面即可,给一段代码,看了就明白了,可以自己扩充
public static String filter(String value) {
if (value == null)
return (null);
StringBuffer result = new StringBuffer();
for (int i = 0; i < value.length(); i++) {
char ch = value.charAt(i);
if (ch == '<')
result.append("&lt;");
else if (ch == '>')
result.append("&gt;");
else if (ch == '&')
result.append("&amp;");
else if (ch == '"')
result.append("&quot;");
else if (ch == '\r')
result.append("<BR>");
else if (ch == '\n') {
if (i > 0 && value.charAt(i - 1) == '\r') {
} else {
result.append("<BR>");
}
} else if (ch == '\t')
result.append("&nbsp;&nbsp;&nbsp;&nbsp");
else if (ch == ' ')
result.append("&nbsp;");
else
result.append(ch);
}
return (result.toString());
}
2、在action中用replaceAll()把空格回车替换出来,
replaceAll(“\r\n“,“<br>“);
replaceAll(“ “,“\b“);
在jsp页面中,如果用<bean:write>则加上filter="false",
<bean:write name="info" property="content" filter="false"/>
3、利用样式表,在显示页面中放置一个“透明”的<textarea>,即边框颜色和文本框颜色都与背景颜色一致的文本框,然后将要显示的内容放置到该文本框中,这样不需要做任何处理,而且绝对和用户输入的格式一模一样,个人认为是最好的方法。当然,千万要记住把这个文本框设置成只读的啊,嘿嘿
 
textarea里的内容自动换行输出
soking 发表于 - 2005-8-31 9:59:00
只要设置表格的css就行了。简单实用!!
td {
 word-break:break-all;
    }
 
 jsp传递中文参数、空格以及表单内容换行问题解决小结
作者:fbysss
Blog地址:blog.csdn.net/fbysss
MSN:jameslastchina@hotmail.com
声明:本文为fbysss原创,如需引用,请注明作者及引用地址
关键字:jsp,中文参数,换行,回车,空格
========================================================================
一、地址传递参数中文/空格问题
举例说明:
    String sContent = "中文 参数";
    如果不做任何处理就直接传递,中文也许没有问题(但不保证),但空格肯定会有问题,到接收页面无法识别。
解决办法1:java.net.URLEncoder.encode(sContent,"gb2312"); 然后再传递。比如url是"accept.jsp?content="+sContent;
读取时,使用
String sc = request.getParameter("content");
sc = new String(sc.getBytes("iso-8859-1"),"gb2312");
 
 
解决办法2:
 
 
传递前,先做以下替换
 
 
sContent=sContent.replaceAll("  ","%20");
 
 
接收到字符串之后,如果在td中显示,则需要使用
 
 
sContent=sContent.replaceAll("  ","&nbsp;");//注意这里不是替换%20,而是替换空格。如果有中文,要先转码
 
 
如果在textarea中显示,则不需要处理。
 
 
 这样就没问题了。
二、回车换行问题
问题描述:
    表单中的textArea中有换行的内容,提交之后保存到数据库,再读取出来的时候,没有换行,全部连在一起了。
解决:
1. 在写入数据库的时候,加入
      sContent=sContent.replaceAll(" ","&nbsp;");
    sContent=sContent.replaceAll("\r\n","<br/>");
      sContent=sContent.replaceAll("\n","<br/>");
2.在读取的时候,如果要在textArea中显示,需要加入
    sc = 数据库中的content字段值 ;
    sc=sc.replaceAll("<br/>","\r\n");
    sc=sc.replaceAll("<br>","\r\n");
    sc=sc.replaceAll("&nbsp;"," ");
如果是直接在td中显示,则不需要转换 。