50分谢谢解决 JSP页面乱码问题
<%@ include file= "../conn.jsp "%>
<%
request.setCharacterEncoding( "GB2312 ");
String username=request.getParameter( "username ");
String password=request.getParameter( "password ");
String sql= "select * from scott.admin where username = ' " + username + " ' and password = ' " + password + " ' ";
ResultSet rs=stmt.executeQuery(sql);
if(rs.next()){
session.putValue( "admin ",rs.getString( "username "));
session.putValue( "flag ",rs.getString( "flag "));
response.sendRedirect( "manage.jsp ");
}else{
out.print( " <LINK rel= 'stylesheet ' type= 'text/css ' href= 'style.css '> ");
out.print( " <TITLE> 管理员身份验证 </TITLE> ");
out.print( " <BODY bgcolor= '#39867B '> ");
out.print( " <BR> <BR> <BR> ");
out.print( " <TABLE align= 'center ' width= '300 ' cellpadding= '1 ' cellspacing= '1 '> " );
out.print( " <TR bgcolor= '#CCCCCC '> ");
out.print( " <TD colspan= '2 ' height= '15 ' bgcolor= '#E1F4EE '> " );
out.print( " <DIV align= 'center '> 操作:确认身份失败! </DIV> ");
out.print( " </TD> ");
out.print( " </TR> " );
out.print( " <TR> ");
out.print( " <TD colspan= '2 ' height= '23 ' bgcolor= '#E1F4EE '> ");
out.print( " <DIV align= 'center '> <BR> <BR> 非法登陆,您的操作已经被记录!!! <BR> ");
out.print( " <BR> <A href= 'login.jsp '> 再次登录! </A> <BR> ");
out.print( " <BR> ");
out.print( " </DIV> ");
out.print( " </TD> ");
out.print( " </TR> " );
out.print( " </TABLE> " );
}
rs.close();
%>
conn.jsp
<%@page contentType= "text/html;charset=GB2312 "%>
<%@ page import= "java.sql.* "%>
<%Class.forName( "com.mysql.jdbc.Driver ").newInstance();
//数据库用户名
String userName= "root ";
//密码
String userPasswd= "123456 ";
//数据库名
String dbName= "scott ";
//联结字符串
String url= "jdbc:mysql://localhost/ "+dbName+ "?user= "+userName+ "&password= "+userPasswd;
Connection conn= DriverManager.getConnection(url);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
%>
[解决办法]
插入数据库乱码 楼住不妨试试看str=(new String(str.getBytes( "iso-8859-1 "), "gb2312 ")).trim();
读取的时候如果出现乱码可以将字符串给一个new String(str.getBytes( "iso-8859-1 "), "gb2312 "))
我就是这样解决的
[解决办法]
doPost
它用于客户端把数据传送到服务器端,也会有副作用。但好处是可以隐藏传送给服务器的任何数据。Post适合发送大量的数据。
例:
jsp页代码:
<form action= "/doget_servlet " method= "post ">
………
<textarea name= "name " cols= "50 " rows= "10 "> </textarea>
………
</form>
servlet代码:
public class DoPostServlet extends HttpServlet {
public void doPost(HttpServletRequest req,HttpServletResponse res) throws IOException,ServletException {
request.setCharacterEncoding( "gb2312 ");
response.setContentType( "text/html;charset=gb2312 ");
PrintWriter out = response.getWriter();
out.println( "The Parameter are : "+request.getParameter( "name "));
}
}
[解决办法]
页面中文:
<%@ page contentType= "text/html; charset=gb2312 " language= "java " import= "java.sql.* " errorPage= " " %>
编码中文:
<meta http-equiv= "Content-Type " content= "text/html; charset=gb2312 ">
提交时候 中文编码
<%
request.setCharacterEncoding( "GB2312 ");
%>
连接MYSQL数据库的问题
<%
//for mysql
Class.forName( "org.gjt.mm.mysql.Driver ").newInstance();
Connection conn=java.sql.DriverManager.getConnection( "jdbc:mysql://127.0.0.1/mysql?user=test&password=&useUnicode=true&characterEncoding=utf8 ");
Statement stmt=conn.createStatement();
%>
[解决办法]
String temp_p=request.getParameter( "传进来的参数名 ");
byte[] temp_t=temp_p.getBytes ( "ISO8859-1 ");
String 在JSP里的变量名=new String(temp_t, "gb2312 ");
这断代码是把iso8859-1转GB2312的,反着做就是转回去
以此类推
[解决办法]
这段时间经常看到有人问到web开发中怎么中文总是?号。原因其实很简单,因为大家大多用的是tomcat服务器,而tomcat服务器的默认编码为 iso-8859-1(西欧字符)。就是因为iso-8859-1(西欧字符)编码造成了我们经常看到?号。关于iso-8859-1(西欧字符)更多知识请看《字节,字符和编码》这篇文章。
方法一:最简单也是用的最多的方法。
<%@ page language= "java " pageEncoding= "GBK " %>
或者 <%@ page contenttype= "text/html;charset=gbk ";> 这里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
这个方法用于jsp页面中的中文显示。
方法二:使用过滤器。
过滤器使用主要针对表单提交,插入数据库的数据都是?号。这也是应为tomcat不按request所指定的编码进行编码,还是自作主张的采用默认编码方式iso-8859-1编码。
编写一个SetCharacterEncodingFilter类。
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class SetCharacterEncodingFilter implements Filter {
protected String encoding = null;
protected FilterConfig filterConfig = null;
protected boolean ignore = true;
public void init(FilterConfig filterConfig) throws ServletException {
this.filterConfig=filterConfig;
this.encoding=filterConfig.getInitParameter( "encoding ");
String value=filterConfig.getInitParameter( "ignore ");
if(value==null)
this.ignore=true;
else if(value.equalsIgnoreCase( "true "))
this.ignore=true;
else
this.ignore=false;
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
// TODO 自动生成方法存根
if (ignore || (request.getCharacterEncoding() == null)) {
String encoding = selectEncoding(request);
if (encoding != null)
request.setCharacterEncoding(encoding);
}
chain.doFilter(request, response);
}
public void destroy() {
// TODO 自动生成方法存根
this.encoding = null;
this.filterConfig = null;
}
protected String selectEncoding(ServletRequest request) {
return (this.encoding);
}
}
然后再web.xml加上
<!-- Set Character Encoding-->
<filter>
<filter-name> Set Character Encoding </filter-name>
<filter-class> com.struts.common.SetCharacterEncodingFilter </filter-class>
<init-param>
<param-name> encoding </param-name>
<param-value> UTF-8 </param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name> Set Character Encoding </filter-name>
<url-pattern> /* </url-pattern>
</filter-mapping>
<!-- Set Character Encoding-->
使用过滤器的好处很多,特别是项目之中。
而且在使用国际化时就更有用了,只要在页面指定 <%@ page language= "java " pageEncoding= "UTF-8 " %> ,服务器就会根据本地Locale来显示正确的字符集。
所以我特别推荐使用过滤器。
方法三:修改tomcat的server.xml文件中URIEncoding。
<Connector
debug= "0 "
acceptCount= "100 "
connectionTimeout= "20000 "
disableUploadTimeout= "true "
port= "80 "
redirectPort= "8443 "
enableLookups= "false "
minSpareThreads= "25 "
maxSpareThreads= "75 "
maxThreads= "150 "
maxPostSize= "0 "
URIEncoding= "GBK "
>
</Connector>
这个方法主要针对从url中获取字符串的问题。
在tomcat5.0及以上版本,post和get方法在处理编码时有所不同。如果你在url中获取中文就会出现?号。但在tomcat4.1版本没有问题,因为tomcat4.1的post和get方法在处理编码时是一样的。