1 如何获取多个checkbox的值(注:checkbox的name值是相同的)?
jsp中choose是一组checkbox的名字
id是一组用来记录数据的名字,与checkbox对应
在服务器端
String[] id = request.getParameterValues("cid");
String[] choose = request.getParameterValues("choose");
for (int i = 0; i < id.length; i++) {
if (Boolean.valueOf(choose[i]).booleanValue()) { //加代码处理
}
}
2
Jsp中文乱码小议
-------郭鹏
Jsp是一个很热门的话题,但让大多数人都头痛的是JSP页面中的乱码问题,笔者身有体会;曾为了解决中文乱码问题郁闷了好几天,试了很多方法都不行。最后在JSP专业人士的帮助下,终于解决。之后笔者曾对此做了一些小的研究。
首先我们先了解一下问题的原因。一般情况在在每个JSP页的头部都有这样一条语句:
<% page contentType="text/html; charset=gb2312" %>这条语句决定了此页面使用GB2312编码形式,而在数据库中一般用的是iso-8859-1字符集存储数据. 而Java程序在处理字符时默认采用统一的ISO-8859-1字符集(体现Java国际化思想),所以在添加数据时,默认的字符集编码是iso-8859-1,而页面采用的是GB2312,所以就出现乱码问题。为解决此问题应在存储的时候把GB2312换转成iso-8859-1。有此时候在读出时也会出现乱码,那么只需反过来就可以了,把iso-8859-1转换成GB2312。
具体实例归纳了以下几点,也许会对大家有一些帮助。
1、 在建立JSP页面时应该注意在jsp页面的头部加入一下代码
<% page contentType="text/html; charset=gb2312" %>
此方法是解决JSP页面显示时的乱码。
2、 有时还需在HTML代码中的<head></head>中加入这句
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
3、 在bean中用的是iso-8859-1编码,在jsp中一般用GB2312编码,处理此类乱码问题如下
String str=new String(strName.getBytes(“iso-8859-1”),”GB2312”);
具体用到此方法的地方为,当提交表单到bean(bean的功能是存储数据到数据库)表单提交后,数据库中存入的数据确变成了????,因此在调用bean之前应对编码进行转换,方法:String str=new String(request.getParameter().getBytes(“iso-8859-1”),”GB2312”);
这样,存入数据库的数据库的数据就可见了。
4、 对于页面间的参数传递也可以用这个方法来处理乱码问题:
public String getStr(String str)
{
try
{
String temp_p=str;
byte[] temp_t=temp_p.getBytes("ISO8859-1");
String temp=new String(temp_t);
return temp;
}
catch(Exception e)
{}
return "null";
}
5、 在表单定义时加上这个属性有时也可以解决表单提交过程中出现的乱码
<form enctype="multipart/form-data"></form>
6、 提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF-8编码方式来发送请求,而UTF-8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。解决办法:通过request.setCharacterEncoding("gb2312")对请求进行统一编码,就实现了中文的正常显示。
3
一个 web提交页面,当用户单击返回或者停止按钮后再点击刷新时容易产生重复提交现象。
为了防止发生错误,避免重复提交,请提出一个解决方案
这个问题看起来简单,解决起来需要动脑筋的。
方法一:后台的 [提交] 逻辑(如编辑,删除等)处理完毕后,跳转到 [列表] jsp页面的时候,指定直接跳转模式;
如struts中action对应的forward的参数redirect="true",这样,即便点击刷新,也没有关系,刷新的是列表页面,而不是提交动作;
缺点,request范围变量丢失,只能利用session范围传值(struts比较cool,应运而生actionmessage,实现在session范围内调用一次,即可自动销毁,可以方便的应用在传递显示信息方面,如显示 删除成功,编辑成功等)
方法二:点击提交按钮后,将页面中的按钮等disable掉,简单的js即可做到,以下代码做参考:
function disableForm(theform) {
if (document.all || document.getElementById) {
for (i = 0; i < theform.length; i++) {
var tempobj = theform.elements[i];
if (tempobj.type.toLowerCase() == "button" || tempobj.type.toLowerCase() == "reset" || tempobj.type.toLowerCase() == "submit" )
tempobj.disabled = true;
}
}
}
有必要这么复杂吗?在返回的按钮下写 οnclick="history.back();"就OK