jsp中用javabean读取值出现乱码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jsp中用javabean读取值出现乱码相关的知识,希望对你有一定的参考价值。

javabean中代码:
package jv;
public class javabean private String nme;
public javabean()

nme=null;

public String getNme()
return nme;


public void setNme(String nme)
this.nme = nme;


private String xh;
public String getXh()
return xh;


public void setXh(String xh)
this.xh = xh;




第一个页面代码:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<jsp:useBean id="na" scope="session" class="jv.javabean"/>
<jsp:setProperty name="na" property="*" />
<%
if(request.getParameter("nme")!= null )

response.sendRedirect("j2.jsp");

%>

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body>
<form method="post" action=j1.jsp>
姓名:<input type="text" name="nme"><br>
学好;<input type="text" name="xh"><br>
<input type="submit" value="提交">

</form>
</body>
</html>

接收页面代码:

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<jsp:useBean id="na" scope="session" class="jv.javabean"/>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
request.setCharacterEncoding("utf-8");
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>dd</title>
</head>
<body>
<%= request.getParameter("nme")%>

uucdeeee<%= request.getParameter("xh")%>姓名是:<input type="text" value="<%=na.getNme() %>">
学好是:<jsp:getProperty name="na" property="xh" />
</body>
</html>

输入汉字就是乱码,,输入数字和字母就没有问题!!求高手解答啊

web乱码与浏览器,web服务器,都有关系。

一劳永逸的解决方案是:

在表单提交页面,用javascript对提交的数据进行两次UTF-8编码。

然后再接受程序的时候,进行一次UTF-8解码。追问

两次UTF-8和一次UTF-8解码的javascript的代码能写出来吗

追答

js
encodeURI(encodeURI(value));
jsp
value = URLDecoder.decode(value, "utf-8");

参考技术A 在form表单中添加accept-charset="gbk"试试
在<META http-equiv="content-Type" content="text/html;charset=gbk"
参考技术B tomcat配置文件中设置编码,具体百度 参考技术C new String(req.getBytes("ISO8859_1"),"UTF-8"); 参考技术D getParameter后做一次编码转换,例如:new String(req.getBytes("ISO8859_1"))。其中req是接收到的参数追问

这样做了啊还是是乱码啊,,

追答

("ISO8859_1")这个是编码方式,试一下其他的编码,例如"GBK"等...

两个HTML页面之间传值时中文出现乱码,怎样解决???

页面a
function totest()


var parm1=document.getElementById("tx1").value;
var parm2=document.getElementById("tx2").value;
var parm3=document.getElementById("tx3").value;
var parm4=document.getElementById("tx4").value;
var myurl="zhongji2.html"+"?"+"parm1="+parm1+"&parm2="+parm2+"&parm3="+parm3+"&parm4="+parm4;
window.location.assign(myurl);

页面b
function getvalue()


///test2.html?parm1=myimg1&parm2=myimg2
//获得第一个属性
var url=location.href;
var tmp1=url.split("?")[1];
var tmp2=tmp1.split("&")[0];
var tmp3=tmp2.split("=")[1];
var parm1=tmp3;
//获得第二个属性

var tmp6=url.split("?")[1];
var tmp4=tmp6.split("&")[1];
var tmp5=tmp4.split("=")[1];
var parm2=tmp5;

var tmp9=url.split("?")[1];
var tmp7=tmp9.split("&")[2];
var tmp8=tmp7.split("=")[1];
var parm3=tmp8;

var tmp12=url.split("?")[1];
var tmp10=tmp12.split("&")[3];
var tmp11=tmp10.split("=")[1];
var parm4=tmp11;

var inhtml= document.getElementById("inhtml");
inhtml.innerHTML=parm1;
var inhtm2= document.getElementById("inhtm2");
inhtm2.innerHTML=parm2;

var inhtm3= document.getElementById("inhtm3");
inhtm3.innerHTML=parm3;
//alert(parm1);

var inhtm4= document.getElementById("inhtm4");
inhtm4.innerHTML=parm4;

document.getElementById("inhtm5").value=parm4;

步骤如下:

1、点弹出框的时候,应该显示“公司代码,公司名称”,但是显示出来的是“口口口口”。

2、在F5执行程序,在取值的地方下断点,显示取到的值是正确的就可以了。

3、F10继续执行代码,查看所传值的参数selectname显示为“口口口”的乱码。

4、修改程序,所取的字符串前增加,将中文转码之后再开始传值,将值带到跳转的界面中,系统会自动转码成中文 ,&FROM=" + from + "&RET=" + ret + "&PAGE。

5、执行程序,执行到context的时候查看值,变成了正常的81%ef%bc%8c%e5%85%ac%e5%8f%b8%,在网上对应的在线翻译网站中可以查到,公司代码,公司名称的转码,到此说明已经修改成功

扩展资料:

超级文本标记语言文档制作不是很复杂,但功能强大,支持不同数据格式的文件镶入,这也是万维网(WWW)盛行的原因之一,其主要特点如下:

1、简易性:超级文本标记语言版本升级采用超集方式,从而更加灵活方便。

2、可扩展性:超级文本标记语言的广泛应用带来了加强功能,增加标识符等要求,超级文本标记语言采取子类元素的方式,为系统扩展带来保证。

3、平台无关性:虽然个人计算机大行其道,但使用MAC等其他机器的大有人在,超级文本标记语言可以使用在广泛的平台上,这也是万维网(WWW)盛行的另一个原因。

4通用性:另外,HTML是网络的通用语言,一种简单、通用的全置标记语言。它允许网页制作人建立文本与图片相结合的复杂页面,这些页面可以被网上任何其他人浏览到,无论使用的是什么类型的电脑或浏览器。

参考资料:百度百科-HTML

参考技术A

1:点弹出框的时候,应该显示“公司代码,公司名称”,但是显示出来的是“口口口口”。

2:在F5执行程序,在取值的地方下断点,显示取到的值是正确的就可以了。

3:F10继续执行代码,查看所传值的参数selectname显示为“口口口”的乱码。

4:修改程序,所取的字符串前增加,将中文转码之后再开始传值,将值带到跳转的界面中,系统会自动转码成中文 ,&FROM=" + from + "&RET=" + ret + "&PAGE。

5:执行程序,执行到context的时候查看值,变成了正常的81%ef%bc%8c%e5%85%ac%e5%8f%b8%,在网上对应的在线翻译网站中可以查到,公司代码,公司名称的转码,到此说明已经修改成功

参考技术B

可以在页面a用encodeURI 编码url,在b页面用decodeURI解码url

页面a

function totest()

 

var parm1=document.getElementById("tx1").value;

var parm2=document.getElementById("tx2").value;
var parm3=document.getElementById("tx3").value;
var parm4=document.getElementById("tx4").value;
var myurl="zhongji2.html"+"?"+"parm1="+parm1+"&parm2="+parm2+"&parm3="+parm3+"&parm4="+parm4;
window.location.assign(myurl);
 
页面b
function getvalue()


///test2.html?parm1=myimg1&parm2=myimg2
//获得第一个属性
var url=location.href;
var tmp1=url.split("?")[1];
var tmp2=tmp1.split("&")[0];
var tmp3=tmp2.split("=")[1];
var parm1=tmp3;
//获得第二个属性

var tmp6=url.split("?")[1];
var tmp4=tmp6.split("&")[1];
var tmp5=tmp4.split("=")[1];
var parm2=tmp5;

var tmp9=url.split("?")[1];
var tmp7=tmp9.split("&")[2];
var tmp8=tmp7.split("=")[1];
var parm3=tmp8;

var tmp12=url.split("?")[1];
var tmp10=tmp12.split("&")[3];
var tmp11=tmp10.split("=")[1];
var parm4=tmp11;

var inhtml= document.getElementById("inhtml");
inhtml.innerHTML=parm1;
var inhtm2= document.getElementById("inhtm2");
inhtm2.innerHTML=parm2;

var inhtm3= document.getElementById("inhtm3");
inhtm3.innerHTML=parm3;
//alert(parm1);

var inhtm4= document.getElementById("inhtm4");
inhtm4.innerHTML=parm4;

document.getElementById("inhtm5").value=parm4;

拓展资料:HTML全称为超文本标记语言,标准通用标记语言下的一个应用。 

“超文本”就是指页面内可以包含图片、链接,甚至音乐、程序等非文字元素。 超文本标记语言的结构包括“头”部分(英语:Head)、和“主体”部分(英语:Body),其中“头”部提供关于网页的信息,“主体”部分提供网页的具体内容。

每种HTML标记符在使用中可带有不同的属性项,用于描述该标记符说明的内容显示不同的效果。

    BGCOLOR 用于定义网页的背景色

    BACKGROUND 用于定义网页背景图案的图像文件

    TEXT 用于定义正文字符的颜色,默认为黑色

    LINK 用于定义网页中超级链接字符的颜色,默认为蓝色

    VLINK 用于定义网页中已被访问过的超接链接字符的颜色,默认为紫红色

    ALINK 用于定义被鼠标选中,但未使用时超链字符的颜色,默认为红色

参考技术C

可以在页面a用encodeURI 编码url  在b页面用decodeURI解码url

页面a

 function totest()
  
               var parm1=document.getElementById("tx1").value;
               var parm2=document.getElementById("tx2").value;
   var parm3=document.getElementById("tx3").value;
var parm4=document.getElementById("tx4").value;
                var myurl="zhongji2.html"+"?"+"parm1="+parm1+"&parm2="+parm2+"&parm3="+parm3+"&parm4="+parm4;
                // encodeURI 编码
                 window.location.assign(encodeURI(myurl));
                        


页面b

function getvalue()
///test2.html?parm1=myimg1&parm2=myimg2 
//获得第一个属性 
//decodeURI 解码
var url=decodeURI(location.href);
var tmp1=url.split("?")[1]; 
var tmp2=tmp1.split("&")[0]; 
var tmp3=tmp2.split("=")[1]; 
var parm1=tmp3;
...

本回答被提问者采纳
参考技术D

在head 标签中修改编码格式   <meta charset="utf-8" />  乱码的原因就是编码格式不一样的导致的

资料拓展: 

超文本标记语言,标准通用标记语言下的一个应用。“超文本”就是指页面内可以包含图片、链接,甚至音乐、程序等非文字元素

以上是关于jsp中用javabean读取值出现乱码的主要内容,如果未能解决你的问题,请参考以下文章

jsp+Servlet+javabean 出现乱码问题

JSP开发模式

href 传值 中文乱码问题

求JSP.NET中文乱码问题解决方案

JSP中JavaBean中传输数据的乱码问题

在jsp页面中用<%@ include file="head.txt"%>引用其他文件的代码,但是引用的那部分出现中文乱码,应该怎