最近在用JspSmartUpload完成上传图书信息的一个功能,出现了中文乱码的问题。百度了很多方法,还是没有解决中文乱码问题。忽然,有一天,看到一篇有关上传文字乱码的文章,经过测试,问题得到了解决,所以,写出来,帮助更多的人。具体代码如下:
一开始,我的数据库是用MySQL,UTF-8编码。用MyEclipse开发项目,用的也是UTF-8,修改了很多遍编码格式还是不行。
我的解决办法是将jsp页面的编码改为gb2312,就好了。 这里注意几点: 1、首先上传页面和接收页面都必须制定编码格式为gb2312; <%@ page language=”Java” import=”java.util.*” pageEncoding=”gb2312”%> 2、注意上传时表单要指定编码为:enctype=”multipart/form-data” (这个很重要) 3、注意上传时表单要指定方法为:method=”post”
<%@ page contentType="text/html; charset=gb2312" language="java" import="com.jspsmart.upload.*" errorPage=""%> <%@ page info="database handler"%> <!--告诉编译器使用SQL包--> <%@ page import="java.sql.*"%> <html> <head> <title>文件上传处理页面</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> </head> <body> <jsp:useBean id="connect" scope="request" class="bean.StudentInfo" /> <% // 新建一个SmartUpload对象 SmartUpload su = new SmartUpload(); // 上传初始化 su.initialize(pageContext); // 设定上传限制 // 1.限制每个上传文件的最大长度。 //su.setMaxFileSize(10000); // 2.限制总上传数据的长度。 //su.setTotalMaxFileSize(20000); // 3.设定允许上传的文件(通过扩展名限制),仅允许doc,txt,jpg文件。 su.setAllowedFilesList("doc,txt,jpg"); // 4.设定禁止上传的文件(通过扩展名限制),禁止上传带有exe,bat, //jsp,htm,html扩展名的文件和没有扩展名的文件。 su.setDeniedFilesList("exe,bat,jsp,htm,html,,"); try { // 上传文件 su.upload(); // 将上传文件全部保存到指定目录 int count = su.save("D:/upload/"); out.println(count + "个文件上传成功!<br>"); // 利用Request对象获取参数之值 out.println("TEST=" + su.getRequest().getParameter("TEST") + "<BR><BR>"); // 逐一提取上传文件信息,同时可保存文件。 for (int i = 0; i < su.getFiles().getCount(); i++) { com.jspsmart.upload.File file = su.getFiles().getFile(i); // 若文件不存在则继续 if (file.isMissing()) continue; // 显示当前文件信息 out.println("<TABLE BORDER=1>"); out.println("<TR><TD>表单项名(FieldName)</TD><TD>" + file.getFieldName() + "</TD></TR>"); out.println("<TR><TD>文件长度(Size)</TD><TD>" + file.getSize() + "</TD></TR>"); out.println("<TR><TD>文件名(FileName)</TD><TD>" + file.getFileName() + "</TD></TR>"); out.println("<TR><TD>文件扩展名(FileExt)</TD><TD>" + file.getFileExt() + "</TD></TR>"); out.println("<TR><TD>文件全名(FilePathName)</TD><TD>" + file.getFilePathName() + "</TD></TR>"); out.println("</TABLE><BR>"); // 将文件另存 file.saveAs("D:/upload/" + file.getFileName()); // 另存到以WEB应用程序的根目录为文件根目录的目录下 //file.saveAs("/upload/" + file.getFileName(), su.SAVE_VIRTUAL); // 另存到操作系统的根目录为文件根目录的目录下 //file.saveAs("c:\temp\" + file.getFileName(), su.SAVE_PHYSICAL); } } catch (Exception e) { out.println("<b>Wrong selection : </b>" + e.toString() + "<a href='javascript:history.back()'>返回</a>" + "<br>"); return; } String name = su.getRequest().getParameter("name"); String num = su.getRequest().getParameter("xuehao"); String department = su.getRequest().getParameter("xibie"); String subject = su.getRequest().getParameter("zhuanye"); String email = su.getRequest().getParameter("email"); String grade = su.getRequest().getParameter("chengji"); String sqlinsert = "insert into student_info(sno,sname,department,subject,email,grade) values(\'" + num + "\',\'" + name + "\',\'" + department + "\',\'" + subject + "\',\'" + email + "\',\'" + grade + "\')"; String sqlquery = "select * from student_info"; try { connect.setInsert(sqlinsert); connect.InsertResult(); out.println("<br>操作数据表,数据插入成功!" + "<br>"); out.println(sqlinsert + "<br>"); } catch (Exception err) { err.printStackTrace(); } finally { connect.setquery(sqlquery); connect.getQueryResult(); ResultSet rs = connect.result; out.println("<table border=1 width=600>"); while (rs.next()) { String col1 = rs.getString("sno"); String col2 = rs.getString("sname"); String col3 = rs.getString("department"); String col4 = rs.getString("subject"); String col5 = rs.getString("email"); String col6 = rs.getString("grade"); //打印所显示的数据 out.println("<tr><td>" + col1 + "</td><td>" + col2 + "</td><td>" + col3 + "</td><td>" + col4 + "</td><td>" + col5 + "</td><td>" + col6 + "</td></tr>"); } out.println("</table>"); if (rs != null) { rs.close(); } } %> </body> </html>