`
igogogo9
  • 浏览: 247392 次
  • 性别: Icon_minigender_1
  • 来自: 海口市
社区版块
存档分类
最新评论

jsp使用URL编码传递中文参数乱码问题

阅读更多


Jsp页面使用URL编码传递中文参数的情况下,在参数的解析过程中会出现乱码。由于java在设计的时候考虑到了国际化的问题,在java源程序编译成字节码的时候默认使用的是UTF-8编码。而在web运用上,由于不同的浏览器向服务器发送的信息采用的编码方式不同,在由像tomcat之类的服务器解码的时候会由于编码方式的不同而产生乱码,这是一个会困扰jsp初学者很久的问题。以前在使用struts的时候不需要处理这些问题,前些天在做一个简单的jsp页面的时候碰到这个问题。经过半天的摸索,基本解决了该问题。
例子中a.jsp页面通过URL编码的方式传递中文参数,在b.jsp中对该参数进行解析。
a.jsp源代码
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>

<body>
<%
       String str_test = "华工";
%>
<form method=post action="b.jsp?test=<%=java.net.URLEncoder.encode(str_test) %>">
         <input type="submit" value="Submit" name="提交"> 
</form>

</body>
</html>


b.jsp源代码
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>

<body>

<%
       String str = new String(request.getParameter("test").getBytes("ISO8859_1"));
%>
<BR>
<%=str %>
</body>
</html>


说明:在使用了java.net.URLEncoder.encode 编码后,页面获取参数request.getParameter后需要使用ISO8859_1编码转换。此外,在jsp的字符集声明中把charset=UTF-8也没有问题。
jsp 传递中文参数乱码问题的解决方法在用中文作为参数传给处理页面进行处理时发现是乱码。以往听说过是由于编码问题造成的,但就是无法解决。今天总算找到相关的解决方法。很简单:在每个 jsp页面加上下面3行 <%@ page pageEncoding="GBK"%> <%@ page contentType="text/html;charset=GBK"%> <%request.setCharacterEncoding("GBK");%> 把GBK改成gb2312也可以,区别就是GBK不仅支持简体中文还支持繁体而gb2312只支持简体中文

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中显示,则不需要转换 。

实际上这是我下面的那个帖子,最近找出了问题出在哪了,就把问题重新写的具体点.
但是不知道怎么解决,不知道有没有哪位高手站出来解决一下呢?
下面是我的代码(是个分页显示问题)
D1和D2是从上一页面得到的选择条件参数,在SQL查询时要用到

<%
String D1=request.getParameter("D1");
if(D1==null)
{D1="";
}
byte B1[]=D1.getBytes("ISO-8859-1");
D1=new String(B1);

String D2=request.getParameter("D2");
if(D2==null)
{D2="";
}
byte B2[]=D2.getBytes("ISO-8859-1");
D2=new String(B2);
out.print(D1);
out.print(D2);//我为了看D1,D2有没有传递过来,让他显示一下!
%>

这是超级连接,page是分页显示时需要的当前页代码
<a href="gagea.jsp?page=<%=intPage+1%>&D1=<%=D1%>&D2=<%=D2%>">下一页</a>

当我点连接时,网页地址栏显示正确(3个参数都传递过去了),但是页面中却都是?我想是中文参数传递问题,但不知道具体怎么解决
虽然代码不详细,但相信高手们一看就知道问题出在哪了,请帮个忙吧,谢谢,这两天因为这一个问题把我头都弄大了,郁闷!
分享到:
评论
2 楼 qishi001 2008-08-12  
简单分页
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.io.*,java.util.*,java.sql.*,java.lang.*" errorPage="" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>jsp测试页面</title>
<style type="text/css">
td{
font-size:12px;
background-color:#C6E9FD;
}
</style>
<script type="text/javascript">
function nextPage() {
var formObj = document.getElementById('form1');
var thisPage = document.getElementById('thisPage').value;
document.getElementById('thisPage').value = parseInt(thisPage,10) + 1;
formObj.submit();
}

function firstPage() {
document.getElementById('thisPage').value = 1;
document.getElementById('form1').submit();
}

function upPage() {
var formObj = document.getElementById('form1');
var thisPage = document.getElementById('thisPage').value;
document.getElementById('thisPage').value = parseInt(thisPage,10) - 1;
formObj.submit();
}

function lastPage(v) {
document.getElementById('thisPage').value = v;
document.getElementById('form1').submit();
}

</script>
</head>

<body>
<%
try {
Connection conn;
Class.forName("com.mysql.jdbc.Driver").newInstance();

conn = java.sql.DriverManager.getConnection("jdbc:mysql://localhost:3306/bookdb","root","");

Statement stmt = conn.createStatement();

ResultSet rs = null;

String sql = "select count(id) from books";
rs = stmt.executeQuery(sql);
rs.next();
   
int firstPage = 1, nextPage, thisPage, iStart = 0, iLast = 0;
int tatolNum = rs.getInt(1);
int PageSize = 5;
int pageCount = 0;

if (tatolNum <= PageSize) {
pageCount = 1;
} else {
if (tatolNum % PageSize == 0) {
pageCount = (int)(tatolNum / PageSize);
} else {
pageCount = (int)(tatolNum / PageSize) + 1;
}
}

if(request.getParameter("thisPage") != null) {
thisPage = Integer.parseInt(request.getParameter("thisPage"),10);
} else { thisPage = 1; }

if (thisPage == 1) {
iStart = thisPage - 1;
iLast = thisPage * PageSize;
} else {
iStart = (thisPage - 1) * PageSize;
iLast = PageSize;
}

sql = "select id,name,title,price,yr,description,saleAmount from books limit " + iStart + "," + iLast;
rs = stmt.executeQuery(sql);
%>
<div style="margin:0px auto;width:1024px;">
<table width="100%" cellspacing="1" cellpadding="1" style="border:1px #8080FF solid; border-bottom:0px;">
            <tr>
                <td width="10%" align="center"  height="25">编号</td>
                <td width="14%" align="center" >作者</td>
                <td width="11%" align="center" >书名</td>
                <td width="11%" align="center" >价格</td>
                <td width="12%" align="center" >出版日期</td>
                <td width="32%" align="center" >说明</td>
                <td width="10%" align="center" >销量</td>
              </tr>
<%
while (rs.next()) {
%>
              <tr>
                <td width="10%" align="center" height="20"><%= rs.getString("id") %></td>
                <td width="14%" align="center" ><%= rs.getString("name") %></td>
                <td width="11%" align="center" ><%= rs.getString("title") %></td>
                <td width="11%" align="center" ><%= rs.getFloat("price") %></td>
                <td width="12%" align="center" ><%= rs.getInt("yr") %></td>
                <td width="32%" align="center" ><%= rs.getString("description") %></td>
                <td width="10%" align="center" ><%= rs.getInt("saleAmount") %></td>
              </tr>
<%
}
%>
        </table>
        <form id="form1" style="margin:0 0 0 0;" method="post" action="index.jsp">
        <table width="100%" cellspacing="0" cellpadding="0" style="border:1px #8080FF solid; border-top:0px;">
         <tr>
                    <td colspan="7" style="height:0px;"><input type="hidden" id="thisPage" name="thisPage" value="<%=thisPage%>" /></td>
              </tr>
            <tr>
                <td width="80%" align="left" height="20" style=" padding-left:10px;" >&nbsp;共&nbsp;<%= pageCount %>&nbsp;页 &nbsp;&nbsp;第&nbsp;<%= thisPage%>&nbsp;页</td>
                <td width="5%" align="center"><% if (thisPage == 1) { %>首页 <% } else { %><div style="cursor:pointer; color:#0000FF;" onclick="firstPage();">首页</div><% } %></td>
                    <td width="5%" align="center"><% if(thisPage == 1) { %>上一页<% } else { %><div style="cursor:pointer; color:#0000FF;" onclick="upPage();">上一页</div><% } %></td>
                    <td width="5%" align="center"><% if(pageCount <= 1 || thisPage == pageCount) { %>下一页<% } else { %><div style="cursor:pointer;color:#0000FF;" onclick="nextPage();">下一页</div><% } %></td>
                    <td width="5%" align="center"><% if(thisPage == pageCount) { %>尾页<% } else { %><div style="cursor:pointer;color:#0000FF;" onclick="lastPage(<%=pageCount%>);">尾页</div><% } %></td>
                    <!--<td width="10%" align="center">转到&nbsp;<input type="text" id="trunPage" name="trunPage" style="width:30px;"/>&nbsp;页</td> -->
              </tr>
        </table>
      </form>
     </div>
<%
rs.close();
stmt.close();
conn.close();
}catch (Exception e) {
out.println(e);
}
%>
</body>
</html>
1 楼 qishi001 2008-08-12  
<%@ page contentType="text/html; charset=UTF-8" language="java" errorPage="" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>EL</title>
</head>

<body>
<% request.setCharacterEncoding("UTF-8"); %>
<table width="80%" align="center" border="0">
	<tr><td>Hello ${param['name']}</td></tr>
</table>
<form style="margin-top:0px;" method="post">
	<table width="80%" align="center" border="0">
    	<tr><td><input type="text" name="name" id="name" /></td></tr>
        <tr><td><input type="submit" /></td></tr>
    </table>
</form>
</body>
</html>


1.contentType="text/html; charset=UTF-8"
2.content="text/html; charset=UTF-8"
3.request.setCharacterEncoding("UTF-8");

注意统一一下就好了。

相关推荐

Global site tag (gtag.js) - Google Analytics