总结:
1.severlet容器是通过JavaBean中的属性方法名来获取属性名的,然后根据此属性名来从request中取值
2.JavaBean中属性方法的命名,set后的名称要与你从request中传递过来的属性要一致,除第一个字母不区分大小写外,其他部分的大小写有严格的区分。
3.设置JavaBean属性的顺序是按照属性方法在JavaBean中出现的先后顺序来设置的。

1.实验:一个javabean程序+一个jsp页面// javabeapackage mycom;

public class Test
{
private String name;
private int age; public void setAge(int age)
{
this.age=age;
}
public void setName(String name)
{
this.name=name;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
} //jsp页面
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>

  <jsp:useBean id="test" class="mycom.Test" scope="page">
    <jsp:setProperty name="test" property="*" />
  </jsp:useBean>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>测试</title>
</head>

<body>
<%=test.getName()%>
</body>
</html>

2. 实验方式,通过改变url的方式,进行参数的传递,然后,查看jsp页面中的结果:

 我使用的resin,将上面的文件按要求放好后(这点俺就不强调了哈)。启动resin后,我们在浏览器中输入:http://localhost/mytest.jsp?name=mbq&age=21然后我们就可以看到显示的内容是mbq,这表示已经关联成功了。我现在想的第一个问题就是,request中的参数和bean中的属性名称到底有什么关系,容器是据什么来判断的?好的,我们先假设容器是根据请求中的参数来寻找bean中的属性设置方法,不过这有点问题了,就是如果请求中的参数对应的属性设置方法没有,那么调用bean的属性方法的话就会出错!基于此我们就反过来,就假设容器是根据bean的属性设置方法名来获得请求参数,这样即使请求参数没有的话,使用requset.getParameters(String pname)也只是返回null,而不是报错。
ok,假设成立了,以第二种假设来做,改Test.java文件,将设置姓名的属性方法名改为setNameTxt(String name),然后编译下。接着删除work目录下的所有文件,然后重新启动resin(以后的每次操作都这样做)。我们同样在浏览器中输入:http://localhost/mytest.jsp?name=mbq&age=21,我们在浏览器中看到的结果是null。然后我们打开jsp编译后的源程序,发现没改之前源程序中的request.getParameters("name")变成了request.getParameters("nameTxt")。很明显,这证明了我们的假设,即容器是根据bean的属性设置方法来取参数,如果有则设置该bean的属性。注意这里是属性设置方法,而不是属性!不信,你可以将属性name改成任何名称都是可以的。
好,现在来考虑第二个问题,那就是属性设置方法名的命名有什么要求?由于JavaBean中的方法都是由一系列set和get方法组成的(当然还有其他的,比如is方法)。是不是一定要是set开头呢?事实能说明一切,我们把上面的bean的属性方法该为mysetName(String name),然后编译重启resin,在浏览器中一样输入:http://localhost/mytest.jsp?name=mbq&age=21,发现结果仍然是null,再看编译后的源代码,发现request.getParameters("name")不见了,呵,因为容器没有发现该set方法嘛,所以容器是找所有以set方法开头的方法。由前面可知,那紧跟在set后面的应该是某个属性的名字了,对,是这样的,set后面的字符串就应该是bean中某个属性的名字,比如setName中的name就是该bean的属性。那后面的属性名的大小写有什么要求呢?我们改写bean的属性方法为setNameValue()和setnamevalue()试试,属性name不用改还是用它。然后在浏览器中输入http://localhost/mytest.jsp?name=mbq&age=21,我们现在不管结果,我们关心的是源码哈,然后看编译后的源码,发现getParameters的参数变成了nameValue,使用两个的效果是一样的。这样外面又可以得出:容器在通过属性设置方法取属性名的时候自动将第一个字母转换成小写了,这个其实很好理解。因为java中的方法命名都是第一个单词小写,后面的单词第一个字母大写来约定的,所以为保持这个约定,容器自动的将第一个字母换成小写了,虽然使用大小写没区别,但是都是约定成俗的嘛~~~
第三个问题就是顺序的问题了。这个现在也好说了,我们交换bean中setName和setAge两个方法的位置。然后编译,重启resion,照样输入前面的内容。再查看编译后的源文件,发现没改之前的先取age,然后再取name,变成了现在的先取name,然后再取age了。可见容器在从request中取参数的时候是根据bean中属性设置方法的先后顺序来取的。另外类型转换的问题,由于从request中取出的所有属性都是字符串形式的,容器的内在机制会自动把这些字符串转换成属性设置方法中的参数对应的类型。

  

jsp页面传递参数是如何与javabean进行关联的的更多相关文章

  1. JSP页面传递参数乱码问题整理

    1.JSP页面之间传递中文参数乱码 (1).a.jsp中正常传递参数,b.jsp 中 <% String projectName = new String(request.getParamete ...

  2. javascript通过url向jsp页面传递中文参数乱码解决方法

    解决方法:在传递参数前将中文参数进行两次编码,jsp页面获取参数后对中文参数进行一次解码,中文参数就不会变为乱码了! 参考例子: <%@ page language="java&quo ...

  3. JSP重定向传递参数

    我一个JSP程序,要实现前台提交数据给后台处理后,后台jsp自动跳转到另一个jsp页面,这种方式也叫重定向,重定向的方法有多种,暂时我试过的并且能成功的有两个: 一种是用 response.sendR ...

  4. <jsp:param>传递参数,出现乱码问题

    今天在学习<jsp:forward>和<jsp:param>时,用<jsp:param>传递参数时,出现乱码问题,部分代码如下: 1 <jsp:forward ...

  5. 前端 使用localStorage 和 Cookie相结合的方式跨页面传递参数

    A页面 html代码: 姓名:<input type="text" id="name1"> 年龄:<input type="text ...

  6. router-link跳转页面传递参数及页面刷新方法

    使用router-link传参: 第一种: 路径:http://localhost:8080/goodListP?id=2 跳转的页面获取参数: this.$route.query.id 第二种: 路 ...

  7. Jquery Javascript 跳转页面传递参数以及获取url的参数

    传递参数: window.location='editCourse.html?dataId='+dataId+''; 获取url中的参数(封装的方法):    function getUrlParam ...

  8. ionic 页面传递参数

    1.使用AngularJS自带的$cacheFactory服务 $cacheFactory 从字面直译即为缓存工厂,可以用它来生成缓存对象,缓存对象以key-value的方式进行数据的存储,在整个应用 ...

  9. jsp页面获取参数的方法(url解析、el表达式赋值、session取值)【原创】

    最近使用myEclispse做网站,使用jsp+js+css做页面,网站中常用到从列表进入详情页面的跳转,下面对详情页面的值填充方式做一个简单总结: 1.url中使用request获取参数 jsp上方 ...

随机推荐

  1. KnockoutJs学习笔记(四)

    由于Writable computed observables和How dependency tracking works的要求相对较高,我先跳过这两篇,学习Pure computed observa ...

  2. mysql sql语句中用括号处理or和and的运算顺序

    需求,我要检索出 a =1 或者 b=1 并且 c = 0 或者 c=1 时候的结果 例子: select * from test where a = 1 or b = 1 and ( c = 0 o ...

  3. HashMap 在 Java1.7 与 1.8 中的区别

    hashMap 数据结构 如上图所示,JDK7之前hashmap又叫散列链表:基于一个数组以及多个链表的实现,hash值冲突的时候,就将对应节点以链表的形式存储. JDK8中,当同一个hash值(Ta ...

  4. Hadoop自定义类型处理手机上网日志

    job提交源码分析 在eclipse中的写的代码如何提交作业到JobTracker中的哪?(1)在eclipse中调用的job.waitForCompletion(true)实际上执行如下方法 con ...

  5. XUtils开源框架的使用(HttpUtils支持多线程断点续传)

    XUtils项目下载地址:https://github.com/wyouflf/xUtils XUtils中包含的四大模块: 1.DbUtils模块 2.ViewUtils模块 3.HttpUtils ...

  6. slf4j logback pom

    pom: <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding&g ...

  7. 【Java】 用PriorityQueue实现最大最小堆

    PriorityQueue(优先队列),一个基于优先级堆的无界优先级队列. 实际上是一个堆(不指定Comparator时默认为最小堆),通过传入自定义的Comparator函数可以实现大顶堆. Pri ...

  8. java.lang.ClassNotFoundException: net.sf.ezmorph.Morpher

    java.lang.ClassNotFoundException: net.sf.ezmorph.Morpher 出现以上异常,可能是使用Json缺少ezmorph包: 以下是Json常用的包:ezm ...

  9. 【原创】Linux常用脚本

    #1.启用停用VIP sudo /etc/ha.d/resource.d/IPaddr 10.10.10.10 start sudo /etc/ha.d/resource.d/IPaddr 10.10 ...

  10. Ubuntu 16.04 64位 tftp服务器搭建

    TFTP(Trivial File Transfer Protocol,简单文件传输协议)是TCP/IP协议族中的一个用来在客户机与服务器之间进行简单文件传输的协议,提供不复杂.开销不大的文件传输服务 ...