存档

文章标签 ‘jsp’

Servlet程序设计

2008年4月2日

Java Servlet是一种使用Java编写的CGI程序

  • CGI:通用网关接口
  • 与传统的CGI不同,Servlet是一种多线程处理模式–性能较高
  • 在Servlet中可以控制输出HTML代码,则所有的HTML代码必须使用out.println()一行一行输出

Servlet的生命周期

  1. 初始化(1次)
    • public void init(ServletiConfig config) throws ServletException
      Servlet初始化有两种方式

      • init():当不需要传递初始化参数时使用
      • init(ServletConfig config) :如果使用这种初始化方法,则上面的无参初始化方法无效,这种方式适用于需要传递初始化参数
  2. 服务(多次)
    • doGet();表单和地址输入都为GET请求
    • doPost(); 只有表单输入为POST请求
  3. 销毁(1次)
    • 服务器关闭
    • 此Servlet长时间不使用

简单Servlet编写

  1. Servlet直接继承直HttpServlet
  2. 在doPost(doGet)方法中写入相应的程序代码
  3. 配置WEB.XML文件
    • JSP程序的功能与Servlet一致,意味着Servlet程序同样可以被外部所访问,就必须有一个地址,这只能通过WEB映射解决
      • 修改web.xml文件可以配置映射地址
        //表示要使用一个Servlet
      • <servlet>  
              //在web.xml文件内部起作用的名字  
              </servlet><servlet -name>Simple</servlet>  
              //servlet程序所在包.类名称  
              <servlet -class>net.hialex.Servlet.SimpleServlet</servlet>       
         
        //servlet映射地址               
        <servlet -mapping>  
             //在web.xml文件内部起作用的名字,与上面的名字一致  
             </servlet><servlet -name>Simple</servlet>  
             //具体映射路径,前面必须要有一个/  
             <url -pattern>/demo</url>
  4. 注意:
    • 在编译servlet时可能会遇到找不到servlet包的问题,这是因为servlet为JDK的扩展包,所以在使用时需要指定classpath
    • 若不指定classpath可以将servlet.jar文件拷贝到JSK安装路径下的jre\lib\ext下
  5. 结论:在Tomcat中,存在servlet的全部库文件(%Tomcat_HOME%\lib\servlet-api.jar)

HttpServlet类

  • 继承自GenericServlet类并增加了doGet()、doPost()等七个方法
  • doGet()方法:当客户端发送get请求时就调用doGet()方法,HTTP缺省的就是Get
  • doPost()方法:当客户端发送HTTP请求调用POST方法调用doPost()方法

对于一个基本的Servlet程序必须注意以下几点:

  1. 首先一定要符合Servlet程序的开发框架
  2. 配置web.xml文件
  3. Servlet的缺点是不适合输出大量的HTML代码

阅读全文…

alex Java , , , , , ,

JavaBean语法(下)

2008年3月15日

为什么能通过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会占用资源

alex Java , , , , ,

(九)JDBC操作技术

2008年3月1日

动态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应用结束,关闭各项操作

    阅读全文…

alex Java , , ,

JavaBean语法(上)

2008年3月1日

什么是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:表示要设置的属性,如果为"*"则表示自动匹配

alex Java , , , , , ,

JDBC连接Mysql数据库

2008年2月19日

看了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数据库代码

<%
//定义数据库操作的常量及对象
//数据库驱动程序
final    String    DBDRIVER            =    "com.mysql.jdbc.Driver"    ;
//数据库连接地址
final    String    DBURL                =    "jdbc:mysql://localhost/jsp"    ;
//数据库用户名
final    String    DBUSER            =    "root"    ;
//数据库密码
final    String    DBPASSWORD        =    "root"    ;
//声明一个数据库连接对象
Connection        conn                =    null;
//声明一个数据库操作对象
Statement    stmt                    =    null;
//声明一个结果集对象
ResultSet    rs                        =    null;
String        sql                        =    null;
%>
 
<%
//进行数据库操作
try
{
//加载驱动程序
Class.forName(DBDRIVER)     ;
//连接数据库
conn    =    DriverManager.getConnection(DBURL,DBUSER,DBPASSWORD)    ;
//实例化数据库操作对象
stmt    =    conn.createStatement()    ;
//编写SQL语句
sql        =    " SELECT name FROM person WHERE id='"+name+"' AND password='"+password+"'";
//查询记录
rs    =    stmt.executeQuery(sql)    ;
if (rs.next())
{
//如果有记录,执行此段代码
flag     =    true    ;
}
//依次关闭
rs.close()    ;
stmt.close()    ;
conn.close()    ;
}
catch (Exception e)
{
}
%>

alex 工作学习 , , ,