JavaBean语法(下)

2008-03-01 – 21:02 - 421 views

为什么能通过property="*"的方式,将内容设置到Bean中,其根本原因是使用了Java的反射机制,根据传递参数的名称找到相应的方法,比如,参数名称为name,则自动找到setName方法。

  • 原则:使用JavaBean自动设置内容时,一定要让参数名称与Bean中的属性名称一致,这样通过Java的命名规范,可以达到统一
  • 当需要指定某个属性内容时候,可以在property中指定参数
    • <jsp:setProperty name="sb" property="*"/> 自动匹配,开发中常采用这种做法
    • <jsp:setProperty name="sb" property="name"/>:可以根据自己的需要设置需要的属性值
    • <jsp:setProperty name="sb" property="name" param="password"/>:可以根据自己的需要,任意选择传递参数
    • <jsp:setProperty name="sb" property="name" value="password"/>:根据用户的需要自己设置参数的值
      • 如果输入的值是一个变量,则需要表达式输出

JavaBean取得属性的方法:

  • <jsp:getProperty name="sb" property="name"/>取得属性没有自动匹配

使用JavaBean的setProperty方法可以自动将传递过来的只有数字的字符串变为整形,之后将内容赋值给具体的属性 -->智能

JavaBean的属性范围:

  • page范围:属性只在当前页有效,如果跳转其他页面,则需要重新实例化
    • 适用于:JSP页面操作资源时使用
  • request范围:属性只保存在一次服务器跳转中,前提是使用<jsp:forward>跳转才行
  • session范围:属性保存在一次会话中,可以任意方式连接其他页面,则此对象只实例化一次
  • application范围:属性公有,此对象在整个服务器上只实例化一次。尽量少用因为application会占用资源
 Tags: , , , , , ,

JavaBean语法(上)

2008-03-01 – 15:05 - 275 views

什么是JavaBean?JavaBean就是一个Java类,即意味着JAVA的一切特性都可以使用,此JavaBean没有图形显示代码,只是完成基本的业务逻辑。

  • JavaBean可以使用Java的封装、继承、多态
  • 使用JavaBean封许多可重复调用的代码-->JavaBean的开发过程是通过项目的不断积累经验的。
  • 使用JavaBean可以达到显示与业务的分离:显示用JSP,业务用JavaBean
    • JAVA开发人员专注于具体业务的开发,而JSP开发人员专注于效果的开发

将JavaBean编译好的*.class文件拷贝到WEB-INF/classes文件夹下,若无此文件夹可以自行建立

编写JavaBean必须需要满足的几点要求:

    1. 所有的JavaBean必须放在同一个包中
    2. JavaBean必须声明成public class类型 --> 文件名称与类名一致
    3. 所有属性必须封装
    4. 设置和取得属性可以通过setter、getter
    5. 使用JSP标签去调用JavaBean必须有一个无参构造方法

JAVA命名规范

  1. 包命名:全部字母小写
  2. 类命名:单词的首字母大写,eg.SimpleBean
  3. 属性名称:第一个单词的首字母小写,之后每单词的首字母大写,eg.studentName
  4. 方法命名:与属性命名相同,eg.public class sayHello(){}
  5. 常量命名:全部单词大写,eg.final String DBDRIVER = "XXXX";

对JAVA程序进行打包编译:javac -d . 文件名

JavaBean开发完成之后在JSP中调用过程:

  1. 使用<%@page import=""%> 使用导入指令
    • 实际上WEB-INF/classes是一个classpath路径,所有的class文件,只要放在此目录下,都可以被访问到
  2. 使用JSP的标签指令调用
    • <jsp:useBean
      id = "sb" //表示实例化对象的名称
      scope="page" //表示使用范围
      class="net.hialex.bean.SimpleBean"/> //对象所属包.类名称路径
    • Tomcat服务器在默认情况下是不能读取修改后的JavaBean如果要读取有以下两种方式:
      1. 重新启动服务器
      2. 配置%TOMCAT_HOME%/conf/web.xml参数reloadable="true"
        • 使用reloadable参数的时机选择:
          • 如果使用这个参数,则表示服务器要始终监视着是否类有改动--这样做影响服务器的性能
          • 在运行时,这个参数必须去掉
          • 在开发时,为了开发方便,可加入此参数

使用JavaBean的好处:

  • 必须结合用户参数提交才能够发现使用JavaBean的好处
  • 使用以下的代码可以替代一切的setter方法调用
    • <jsp:setProperty name = "sb" property="*"/>
      • name:已经声明过的JavaBean对象的id
      • property:表示要设置的属性,如果为"*"则表示自动匹配
 Tags: , , , , , ,

开学了

2008-02-21 – 20:50 - 1,140 views

1237714_316381

年已经过完,明天就要返校了,又是一个新学期,有点期待,又有点不安,这是我大学倒数第三个学期了,离毕业越近,心中越没底。现在过年已经没有以前那么开心了,人长大了,考虑的事情多了,再也不能像以前那样无忧无虑了,呵呵,这是好事。

还有不多的时间,多学点东西给自己壮壮胆吧!

开学啦……你准备好了吗?

我准备好了!!

 Tags: , , ,

JDBC连接Mysql数据库

2008-02-19 – 20:44 - 863 views

看了JDBC连接技术视频,特别想试着连连看,但是视频中老师是连接的Oracle数据库,而我的机器上并没有装Oracle,所以想连别的数据库,比如说Mysql。

按照视频中老师讲解的方法,JDBC连接任何数据库搞定两个步骤即可,一是找到欲连接的数据库的JDBC驱动,二是写好数据库连接地址,所以我照着这两点尝试着连Mysql:

第一步:找到Mysql的JDBC连接驱动(下载地址)。

第二步:将下载下来的文件解压,将其中的mysql-connector-java-5.1.5-bin.jar拷贝到%TOMCAT_HOME%\lib目录下。

第三步:在要连接数据库的JSP页面中填写参数,具体如下:

  • 数据库驱动程序为:"com.mysql.jdbc.Driver"
  • 数据库连接地址为:"jdbc:mysql://localhost/[数据库名]"

完成以上步骤,JDBC连接Mysql数据库的核心步骤基本就搞定了,剩下的就是JDBC的一些固定步骤了。

我在网上搜索jdbc连接mysql数据库的方法时发现了我在视频中学到的方法并不是和网上的方法完全一致,有点小的差别,但是我用以上的方法是能成功连接的。

附:JDBC连接Mysql数据库代码

 Tags: , , ,

(九)JDBC操作技术

2008-02-19 – 17:34 - 246 views

动态WEB的最大特点:可以操作数据库

  • JSP是通过JDBC(Java DataBase Connectivity)技术操作数据库的
  • 使用数据库之后可以发现,对数据的处理由数据库管理系统(DBMS)去完成,而程序只是将需要的数据进行显示

JDBC本身是JAVA连接数据库的一个标准,是JAVA操作数据库的方法,是SUN提供的,而微软操作数据库的方法是ODBC

JDBC 1.0:

  • 分类:
    1. JDBC-ODBC Bridge(JDBC-ODBC桥接方式):因为性能较差,在开发中不采用
    2. JDBC-native Driver Bridge:驱动有个数据库生产厂家提供
    3. JDBC-network Bridge
  • JDBC-ODBC:
    • JDBC-ODBC是在JDK中由SUN本身开发出来的一套数据访问操作,在JDBC-ODBC桥接中它的各种操作API都是最新的,但是性能不高
    • ODBC的基本原理
      • 通过一个数据源名称 ---> 数据库
      • 为数据库起了一个别名 ---> 程序通过别名访问数据库
      • 即:程序只认别名不认具体的数据库
  • 常用接口:
    1. 使用java.sql包
    2. 常用接口:--DriverManager --Connection --Statement --PreparedStatement --ResultSet
  • **利用JDBC开发WEB数据库应用框架
    1. 装入JDBC驱动程序
    2. 创建与数据库的连接
    3. 创建语句对象
    4. 利用语句对象执行SQL语句得到结果
    5. 处理结果
    6. JDBC应用结束,关闭各项操作
  • **JDBC具体使用--各条对应上面框架各条
    1. 通过Class.forName("XX"); eg.Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    2. Connection conn = DriverManager.getConnection(DBURL,USER,PASSWORD);
    3. 创建对象
      • 使用statement对象:Statement stmt = conn.createStatement();
      • 使用PreparedStatement对象:PreparedStatement pstmt = conn.PrepareStatement();
    4. 执行SQL语句返回ResultSet实例化对象
      • 查询数据库:stmt.ececuteQuery(sql);
        • 包括SELECT
      • 更新数据库:stmt.ececuteUpdate(sql);
        • 包括DELETE、INSERT、UPDATE
    5. 结果集ResultSet的处理
      • 使用getXXX();方法可以得到不同类型的结果值(参数可以是字段或编号)
      • next()方法可以使游标移动到下一条记录
    6. 数据库在每次使用之后都必要关闭,关闭数据库操作的顺序与打开数据库操作的顺序相反
  • PreparedStatement--Statement的子接口
    • 引入原因:当Statement所需要的SQL语句中包含“'”,会造成数据输入的不正确
    • 建议:在开发中尽量不去使用Statement对象,而去使用PreparedStatement操作数据库

Read the rest of this entry »

 Tags: , , , , ,