在Struts中怎么把中文数据从JSP页面提交到MySql数据库中

suny999 2009-04-05 03:37:32
Struts中的Action文件代码:
public class TiJiaoAction extends Action {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {
ActionForward actionforward = new ActionForward();

UserInfoActionForm userInfoForm = (UserInfoActionForm)form;

request.setCharacterEncoding("gb2312");
String id = userInfoForm.getId();
String name = userInfoForm.getName();

Connection con = null;
Statement sta = null;

try{
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost/china";
String user = "root";
String pwd = "111";

con = DriverManager.getConnection(url,user,pwd);
sta = con.createStatement();

String sql = "insert into user_info values('"+id+"','"+name+"')";
sta.executeUpdate(sql);
actionforward = mapping.findForward("success");

}catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (sta != null) {
try {
sta.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (con != null) {
try {
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
return actionforward;
}
}
JSP页面中编码(<%@ page language="java" pageEncoding="gb2312"%>)也是GB2312。
但是在jsp页面提交时显示下面错误信息(在数据库平台可以直接向表中插入中文数据):
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'name' at row 1
跪求天下IT豪杰,代码尽量写的详细点,本人比较笨,思念答案早日到来...
...全文
152 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
suny999 2009-04-17
  • 打赏
  • 举报
回复
谢谢各位朋友
jixiuffff 2009-04-12
  • 打赏
  • 举报
回复
String sql = "insert into user_info values('"+id+"','"+name+"')";


打印一下sql这句话,然后复制到mysql 测试一下
suny999 2009-04-12
  • 打赏
  • 举报
回复
是UTF-8,有什么问题吗
流星谜 2009-04-12
  • 打赏
  • 举报
回复
这里有完整答案,慢慢看
http://topic.csdn.net/u/20090411/11/9457d41a-f7bd-48f3-ada7-b3a05a86f5f1.html
palm_civet 2009-04-07
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 suny999 的回复:]
各位前辈,不是数据长度不够,我已经测试过了,就算只输入一个汉字也会报错,数据库中的name字段长度为16,不短了,不是这个问题
[/Quote]

是字符编码不对,你mysql是什么编码的?
suny999 2009-04-07
  • 打赏
  • 举报
回复
各位前辈,不是数据长度不够,我已经测试过了,就算只输入一个汉字也会报错,数据库中的name字段长度为16,不短了,不是这个问题
jigjhajeig 2009-04-05
  • 打赏
  • 举报
回复
great1681 2009-04-05
  • 打赏
  • 举报
回复
是啊,你测试的时候将name输入的简短些,
例如:aa
看看如何?
或者将数据库的name字段长度加长些试试~~
jourqel 2009-04-05
  • 打赏
  • 举报
回复
Data too long for column 'name' at row 1
数据超出长度了~你把数据库里面的长度值改大些~如果数据比较长改成文本域类型吧~那样肯定不会超出长度~
源码链接: https://pan.quark.cn/s/d5c270d5abd6 依据所提供的文档资料,可以掌握若干有关VirtualBox COM对象获取无法成功的问题及其应对措施。 VirtualBox作为一款广受欢迎的开源虚拟化工具,能够让用户在当前运行的操作系统上建立及执行虚拟环境。 COM(Component Object Model)对象是应用于Windows平台的一种技术,旨在促成软件组件之间的交互。 若获取VirtualBox的COM对象遭遇失败,则意味着在与VirtualBox进行交互时遇到了某些障碍,这或许源于注册表设置存在偏差或某些组件未能正确部署。 此类问题的显现通常与安装Genymotion前需先安装VirtualBox有关,但在安装VirtualBox后却遭遇COM对象获取失败的情形。 这种情况可能会干扰VirtualBox的正常运作,使用户无法进行虚拟机的管理或构建。 解决方案包括若干步骤,其核心在于对Windows注册表的编辑操作。 注册表是Windows操作系统用于存储配置数据数据,其包含了系统软件与硬件的配置详情,亦涵盖了COM对象的相关信息。 一旦COM对象的注册资料出现异常,系统便无法准确加载及执行相应的组件。 根据文件所载信息,处理方案包含以下环节:1. 在Windows环境通过“regedit”指令启动注册表编辑器。 此步骤涉及在开始菜单的运行窗口键入指令并执行。 2. 随后,依照文件的指引,需要在注册数据定位特定的键值路径。 这些路径涵盖: - HKEY_CLASSES_ROOT\CLSID\{***-0000-0000-C000-***}\InprocServer32 - HKEY_CLASSES_ROOT\CLSID...
内容概要:本文介绍了一种基于局部高斯分布拟合能量驱动的活动轮廓模型,用于图像分割任务。该方法属于区域型主动轮廓模型,通过变分水平集方法实现轮廓演化,能够有效分割具有复杂边界或弱边界的图像目标。其核心思想是利用图像局部区域的灰度统计特性,构建基于高斯分布的能量函数,使轮廓在演化过程对噪声具有较强鲁棒性,并能准确捕捉目标边缘。该模型特别适用于不均匀光照、低对比度等挑战性图像的分割场景,Matlab代码实现便于科研人员理解算法细节并进行二次开发。; 适合人群:具备一定图像处理基础,从事计算机视觉、医学图像分析、遥感影像处理等领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①解决传统边缘检测方法在噪声干扰下分割效果差的问题;②实现对灰度不均、边界模糊图像的精确分割;③为后续的图像识别、目标测量等任务提供高质量的分割结果;④作为学习水平集方法与主动轮廓模型的经典案例进行教学与研究。; 阅读建议:建议读者结合Matlab代码逐步调试运行,观察水平集函数的演化过程,深入理解能量泛函构造、梯度下降法求解及水平集更新机制,同时可尝试在不同类型的图像上测试算法性能并进行参数调优。

81,115

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧