1、页面间传值

一、在页面间传递数据时的方法:

切记text框的name属性,只有设置name属性,下一个页面的request才可以获取数据.id属性不行,因为id属性主要是为了JavaScript操作

1.

通 过<a href="judge.jsp?name=<%=user.getName() %>&pass=<%=user.getPass() %> " />此方法安全性不好,可以用于传递不涉及安全限制的数据;但是不局限于该页面是否有form,并且也不用跳转动作,多省事啊!!!

2.

通过form传值,form的method用post安全性好,并且不易于出现乱码;

而get安全性不好,适合传递少量数据,并且易出现乱码;

二、下面讲乱码的出现情况及处理方法:

1.

request.getParameter("name");出现乱码:使用request之前先设置request的编码方式:request.setCharacterEncoding("utf-8");

2.

获取form数据出现乱码:将form的method改为post;

3.

修改页面的字符集:在head标签之间添加<meta charset="utf-8" />

三、request.getParameter()与request.getParameterValues()不同之处,参见:http://blog.csdn.net/moreorless/article/details/4199677

四、JavaScript验证表单

1.

提交表单时验证表单内容,form格式如下

<form name="form" method="post" onsubmit="return check()">
    <input type="text" name="name" id="name"/>
    <input type="submit" value="提交" />
</form>

切记:(1)写着return;(2)check()内无需加参数;

验证JavaScript格式如下:

<script language="javascript">
function check() {
    name=document.getElementById("name");
    if(name!==""){
        return true;
    } else {
        return false;
    }
}
</script>



2.

判断表单内text内容是否为空,用=="",而不是==null,否则验证无效;

最后都用上,如此:

String name = getElementById("name");
if (name != null && name != "") {
    //do something
}



在<%%>中java脚本段判断亦是如此;

 





原文地址:https://www.cnblogs.com/zmpandzmp/p/3648789.html