⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 64.html

📁 写给JSP初级程序员的书
💻 HTML
📖 第 1 页 / 共 2 页
字号:
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<meta name="description" content="Java,JDBC,EJB,Open Source,jdk,rmi">
<meta name="Keywords"
content="Java, servlets, Java servlet, Javascript, ActiveX, VRML,
        applet, applets, directory, news, jdbc, applications, 
        Java applications, Java developer, Java development, developer, 
        classes, Jars.com, Jars, intranet, Java applet, Javabeans, 
        Java products, JDK, Java development kit, java development environment, JIT,
        JavaPlan, enterprise tools, JVM, Java Virtual Machine, Java resources, 
        SUN, CGI, Perl, database, network, html,
        xml, dhtml, rating, ratings, review, jars, cgi, programming,
        software review, software rating">
<title>csdn_一个开发人员眼中的JSP技术</title>
<style>
.news {   BACKGROUND: #007cd3;  font-family: "宋体"; font-size: 9pt }
.t {  font-family: "宋体"; font-size: 9pt }
.t1 { color:#007cd3;  font-family: "宋体"; font-size: 9pt }
.white { font-family: "宋体"; font-size: 9pt;color:#FFFFFF }
.red { font-family: "宋体"; font-size: 9pt;color:#FF0000 }
A:visited {color:#0000FF}
A:hover {color: #ff6666; text-decoration: none}
.text {font-size: 12px; line-height: 160%; font-family: "宋体"}
.text1 {color:#000000; font-size: 12px; line-height: 130%; font-family: "宋体"; text-decoration: none}
.text1:visited {color:#000000}
.text1:hover {color: #000000}
.text2 {color:#000000; font-size: 12px; line-height: 130%; font-family: "宋体"; text-decoration: none}
.text2:visited {color:#000000}
.text2:hover {color: #000000}
.text3 {font-size: 12px; line-height: 100%; font-family: "宋体"; text-decoration: none}
.large {font-size: 14.8px; line-height: 130%}
</style>
</head>

<body


<center>




  <tr>
    <td WIDTH="100%" VALIGN="TOP">
      <tr>
        <td WIDTH="100%" CLASS="white"></td>
      </tr>
    
      <tr>
        <td WIDTH="50%" bordercolor="#FFFFFF" CLASS="t1" bgcolor="#F0F0F0" align="center" nowrap>一个开发人员眼中的JSP技术  </td>
     <p>   <td WIDTH="50%" bordercolor="#FFFFFF" CLASS="t1" bgcolor="#F0F0F0" align="center" nowrap>作者:天译编译 </td></p>
      </tr>
      <tr>        <td WIDTH="100%" bordercolor="#FFFFFF" CLASS="t" bgcolor="#F0F0F0" colspan="2">
           JavaServer<sup>TM</sup> Pages(JSP)技术为我们提供了一种建立动态网页的简单方法,而且也简化了构造web程序的工作。本文从一个开发人员的角度对JSP技术做了一个全面介绍(并提供了一些JSP实例程序)。
<BR>
    <strong>前言</strong>
<BR>
    JavaServer Pages技术可以让web开发人员和设计人员非常容易的创建和维护动态网页,特别是目前的商业系统。作为Java<sup>TM</sup>技术的一部分,JSP能够快速开发出基于web、独立于平台的应用程序。JSP 把用户界面从系统内容中分离开来,使得设计人员能够在不改变底层动态内容的前提下改变整个网页布局。
<BR>
    那么什么是JavaServer Page呢?简单的说,一个JSP网页就是在HTML网页中包含了能够生成动态内容的可执行应用程序代码。此应用程序可能包含JavaBean<sup>TM</sup>,JDBC<descript><sup>TM</sup></descript>对象,Enterprise <A NAME="TRSHL1"><FONT COLOR=RED>Java</FONT></A> Bean<descript><sup>TM</sup></descript> (EJB)和Remote Method Invocation (RMI)对象,所有的部分都可以非常容易的从JSP网页上访问到。例如,一个JSP网页可以包含 HTML代码所显示的静态文本和图像,也可以调用一个JDBC对象来访问数据库;当网页显示到用户界面上以后,它将包含静态HTML内容和从数据库中找到相应的动态信息。
<BR>
  在JSP网页中,要把用户界面和应用程序分开可以考虑在网页设计人员和开发人员之间执行一个非常方便的授权任务。它也允许开发人员去建立灵活的代码,从而非常容易的进行更新和重复利用。由于JSP网页能够根据需要自动进行编译,web设计人员无须重新编译应用程序逻辑就可以改变表述代码。这也使得JSP与<A NAME="TRSHL2"><FONT COLOR=RED>Java</FONT></A> servlet(它是JavaSever Pages功能的扩展)相比成为一种可以更灵活生成动态web内容的方法。
<BR><BR>    <strong>JSP和Servlet</strong>
<BR>
  如果你已经用过<A NAME="TRSHL3"><FONT COLOR=RED>Java</FONT></A> servlet,那么你就会知道servlet可以让你建立动态生成的网页,而网页中包含有从服务器方的<A NAME="TRSHL4"><FONT COLOR=RED>Java</FONT></A>对象中所获得的数据。但是你也得知道servlet 生成网页的方法就是在<A NAME="TRSHL5"><FONT COLOR=RED>Java</FONT></A>类中嵌入HTML标签和表述代码。这就意味着改变表述代码需要修改和重新编译servlet源文件。因为设计HTML页面的设计人员可能与编写servlet代码的开发人员不是同一个人,更新基于servlet的web应用程序就成了一件非常棘手的事情。
<BR><BR>  Enter JavaServer Page是Servlet API的一个扩展。事实上,JSP网页在编译成servlet之前也可以使用,所以它们也具有servlet的所有优势,包括访问<A NAME="TRSHL6"><FONT COLOR=RED>Java</FONT></A> API。由于JSP 是嵌入到servlet中关于应用程序的一般表述代码,所以他们能够被看成一种“彻底”的servlet。
<BR><BR>  JSP网页主要提供了一种建立servlet的高水平方法,它还带来了其他的优点。即使你已经为web应用程序编写了servlet,使用JSP仍然有很多优势:
<BR><BR>  JSP网页可以非常容易的与静态模板结合,包括HTML 或XML 片段,以及生成动态内容的代码。
<BR><BR>  JSP网页可以在被请求的时候动态的编译成servlet,所以网页的设计人员可以非常容易的对表述代码进行更新。如果需要的话,JSP网页还可以进行预编译。
<BR><BR>  为了调用JavaBean组件,JSP标签可以完全管理这些组件,避免网页设计人员复杂化应用程序。
<BR><BR>  开发人员可以提供定制化的JSP标签库。
<BR><BR>  网页设计人员能够改变和编辑网页的固定模板部分而不影响应用程序。同样,开发人员也无须一个个编辑页面而只须对组件进行合理的改变。
<BR><BR>  通常,JSP允许开发人员向许多网页设计人员分发功能性应用程序。这些设计人员也不必知道<A NAME="TRSHL7"><FONT COLOR=RED>Java</FONT></A>编程语言或任何servlet代码,所以他们能够集中精力去编写HTML代码,而编程人员就可以集中精力去建立对象和应用程序。
<BR><BR>    <strong>建立JSP页面</strong>
<BR>
  粗略看来,JSP网页和HTML (或XML)网页非常相似——都包含用标签封装的文本(在“<>”之间被定义)。当HTML标签被用户的浏览器处理以显示网页的时候,JSP标签能够通过web服务器的处理来生成动态内容。这些JSP标签能够定义个别的操作,比如说用一个方法来调用JavaBean,或者包含标准的<A NAME="TRSHL8"><FONT COLOR=RED>Java</FONT></A>代码块(也就是所谓的scriptlet),这些代码块能够在网页被访问的时候被执行。
<BR><BR>  为了了解它们如何使用,下面我们介绍了一个JSP网页的简单例子,在这个JSP网页中包含了静态HTML内容和从JavaBean生成的动态数据。当用户访问这个网页的时候,它可以显示当前的日期,并根据当前的时间增加相应的问候语(例如“早上好”和“下午好”)。为简单起见,JSP标签显示在块中:
<BR><BR>  &lt;HTML&gt;
<BR><BR>  &lt;%@ page language=&quot;<A NAME="TRSHL9"><FONT COLOR=RED>java</FONT></A>&quot; imports=&quot;<A NAME="TRSHL10"><FONT COLOR=RED>java</FONT></A>.util.*&quot; %&gt;
<BR><BR>  &lt;H1&gt;Welcome&lt;/H1&gt;
<BR><BR>  &lt;P&gt;Today is &lt;/P&gt;
<BR><BR>  &lt;jsp:useBean id=&quot;clock&quot; class=&quot;jspCalendar&quot; /&gt;
<BR><BR>  &lt;UL&gt;
<BR><BR>  &lt;LI&gt;Day: &lt;%= clock.getDayOfMonth() %&gt;
<BR><BR>  &lt;LI&gt;Year: &lt;%= clock.getYear() %&gt;
<BR><BR>  &lt;/UL&gt;
<BR><BR>  &lt;%-- Check for AM or PM --%&gt;
<BR><BR>  &lt;%! int time = Calendar.getInstance().get(Calendar.AM_PM); %&gt;
<BR><BR>  &lt;%
<BR><BR>  if (time == Calendar.AM) {
<BR><BR>  %&gt;
<BR><BR>  早上好
<BR><BR>  &lt;%
<BR><BR>  }
<BR><BR>  else {
<BR><BR>  %&gt;
<BR><BR>  下午好
<BR><BR>  &lt;%
<BR><BR>  }
<BR><BR>  %&gt;
<BR><BR>  &lt;%@ include file=&quot;copyright.html&quot; %&gt;
<BR><BR>  &lt;/HTML&gt;
<BR><BR>  上面的JSP例子是不是很简单?我们在JSP网页中使用了几个不同的组件。这些组件包括下面的内容:
<BR><BR>  JSP action (或JSP标签)使用了多种函数并扩展了JSP的功能。JSP action使用的是一种类似XML的语法,并且被用来处理JavaBean组件。在上面的例子中,jsp:useBean action初始化了一个JavaBean ,JavaBean将在网页的后面部分被用到:
<BR><BR>  &lt;jsp:useBean id==&quot;clock&quot; class==&quot;jspCalendar&quot; /&gt;
<BR><BR>  如果在网页中需要获得和设置这个Bean的属性,另一个JSP action将被给出,使用的是下面的语法:
<BR><BR>  &lt;jsp:getProperty name=&quot;bean&quot; property=&quot;property&quot; /&gt;
<BR><BR>  &lt;jsp:setProperty name=&quot;bean&quot; property=&quot;property&quot; value=&quot;value&quot; /&gt;
<BR><BR>  当网页被编译成一个servlet的时候,Directive将被JSP引擎处理。Directive被用来设置页面级的指令、从外部文件插入数据以及制定定制的标签库。Directive被定义在&lt;%@ 和 %&gt;之间。 在上面的例子中,Directive定义了页面所使用的语言(<A NAME="TRSHL11"><FONT COLOR=RED>Java</FONT></A>),为了关联<A NAME="TRSHL12"><FONT COLOR=RED>Java</FONT></A>类需要植入代码并指定一个将要插入页面底部的HTML文件内容:
<BR><BR>  &lt;%@ page language==&quot;<A NAME="TRSHL13"><FONT COLOR=RED>java</FONT></A>&quot; imports==&quot;<A NAME="TRSHL14"><FONT COLOR=RED>java</FONT></A>.util.*&quot; %&gt;
<BR><BR>  &lt;%@ include file==&quot;copyright.html&quot; %&gt;
<BR><BR>  声明与<A NAME="TRSHL15"><FONT COLOR=RED>Java</FONT></A>中的变量声明相似,它也是为了后面表达式或scriptlet的需要来定义变量。声明被定义在&lt;%! 和 %&gt;之间。在上面的例子中,“int”声明并给出了一个当前时间的相应值 (AM 或 PM):
<BR><BR>  &lt;%! int time = Calendar.getInstance().get(Calendar.AM_PM); %&gt;
<BR><BR>  表达式可以是变量或常量,它插在由web服务器所返回的数据里,并用&lt;%= 和 %&gt;来定义。在上面的例子中,表达式将调用JavaBean组件并在页面中插入结果数据:
<BR><BR>  &lt;%= clock.getDayOfMonth() %&gt;
<BR><BR>  &lt;%= clock.getYear() %&gt;
<BR><BR>  Scriptlet将作为一个<A NAME="TRSHL16"><FONT COLOR=RED>Java</FONT></A>代码块植入JSP页面中。Scriptlet代码被一一插入由页面所产生的servlet中,它被定义在&lt;% 和%&gt;之间。上面例子中的scriptlet可以根据当前用户产生相应的时间和问候语:
<BR><BR>  &lt;%
<BR><BR>  if (time == Calendar.AM) {
<BR><BR>  %&gt;
<BR><BR>  早上好
<BR><BR>  &lt;%
<BR><BR>  }
<BR><BR>  else {
<BR><BR>  %&gt;
<BR><BR>  下午好
<BR><BR>  &lt;%

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -