JavaEE-01 JSP动态网页基础

学习要点

  • B/S架构的基本概念
  • Web项目的创建和运行
  • JSP页面元素
  • MyEclipse创建和运行Web项目
  • Web程序调试

Web简史

web前端技术演进三阶段

  • WEB 1.0:信息广播。 
  • WEB 2.0:信息交互。 微博、博客等。
  • WEB 5.0:移动互联网。

动态网页服务器端技术演进

主流web程序应用平台

性能比较

LAMP

JavaEE

ASP.NET

运行速度

较快

一般

开发速度

非常快

一般

运行损耗

一般

较小

较大

难易程度

简单

简单

运行平台

Linux/Unix/Windows

绝大多数平台

仅Windows平台

软件架构

C/S架构

优点:响应速度快;个性化定制;事务处理能力强,减轻服务器压力;安全性高。

缺点:C端维护工作量大;不利于企业快速部署应用。

B/S架构

优点:分布广,只要有互联网的浏览器即可。部署灵活;维护方便。跨平台。

C/S与BS混合架构

企业内部操作数据采用C/S架构:外部用户不直接访问数据库服务器,保证企业数据库的相对安全。企业内部用户的交互性较强,数据操作响应速度较快。

企业外部采用B/S架构:企业外部用户修改和维护数据时,速度较慢,较烦琐,数据的动态交互性不强。适合简单数据查询和确认。

B/S架构

定义

常见web服务器分成三类:不带应用程序的服务器(存放html文件等)、带应用程序的服务器(例如可以存放JSP文件)、带应用程序和数据库的服务器(例如JSP+数据库)。

工作原理

B/S结构采用请求/响应模式进行交互。

HTTP

HTTP协议概述

HTTP规范1.0和1.1定义了HTTP消息格式。HTTP报文由从客户机到服务器的请求和从服务器到客户机的相应构成,所以HTTP消息分为请求消息和响应消息两类。

请求行

状态行

  • 状态行格式如下:

HTTP-Version Status-Code Reason-Phrase CRLF

其中,HTTP-Version表示服务器HTTP协议的版本;Status-Code表示服务器发回的响应状态代码;Reason-Phrase表示状态代码的文本描述。状态代码由三位数字组成,第一个数字定义了响应的类别,且有五种可能取值。

  • 常见状态码:
  1. 200 OK:客户端请求成功。
  2. 400 Bad Request:客户端请求有语法错误,不能被服务器所理解。
  3. 401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用。
  4. 403 Forbidden:服务器收到请求,但是拒绝提供服务。
  5. 404 Not Found:请求资源不存在,举个例子:输入了错误的URL。
  6. 500 Internal Server Error:服务器发生不可预期的错误。
  7. 503 Server Unavailable:服务器当前不能处理客户端的请求,一段时间后可能恢复正常,举个例子:HTTP/1.1 200 OK(CRLF)。

在浏览器查看请求和响应信息

URL

Uniform resource Locator,统一资源定位符

格式:

http://<IP地址>:[端口号]/路径/[?<查询信息>]

例如:

http://www.etc.com/book/index.html

http:超文本传输协议。FTP,telnet

www:代表一台web服务器

etc.com:服务器域名

book:站点上的目录

index.html:book文件夹中的一个HTML文件,即网页。

Web应用程序的部署

JavaEE

  • Java EE,Java 平台企业版(Java Platform Enterprise Edition),之前称为Java 2 Platform, Enterprise Edition (J2EE),2005年6月更名为JavaEE,2018年3月更名为 Jakarta EE。是 Sun 公司(2009年被Oracle公司收购)为企业级应用推出的标准平台,用来开发B/S架构软件。
  • Java EE 是一种规范,包括:JDBC(Java Database)数据库连接、JNDI(Java Naming and Directory Interfaces)Java的命名和目录接口、EJB(Enterprise JavaBean)、RMI(Remote Method Invoke)远程方法调用、Java IDL(Interface Dexcription Language)/CORBA(Common Object Broker Architecture)Java接口定义语言/公用对象请求代理程序体系结构、JSP(Java Server Pages)、Servlet、XML(Extensible Markup Language)可扩展标记语言、JMS(Java Message Service)Java消息服务、JTA(Java Transaction API)Java事务API、JTS(Java Transaction Service)Java事务服务、JavaMail。
  • JavaEE 是 Java 应用最广泛的部分。
  • JavaEE运行的基础是JavaSE。
  • JavaEE常见容器:Tomcat 容器(JSP/Servlet),JBoss容器(Servlet和EJB容器),Resin容器(Servlet,轻量级web容器;同级别商用容器:Weblogic、Websphere),Glassfish(Sun公司推出的JavaEE容器)。

Tomcat和JDK的版本配套关系

 

Tomcat、JDK、JavaEE、Servlet版本间的配套关系

eclipse和jdk的配套关系

参考eclipse安装文档 

https://wiki.eclipse.org/Eclipse/Installation#Install_a_JVM

配套参考表

Eclipse 4.8 (Photon)    Java8
Eclipse 4.7 (Oxygen)   Java8
Eclipse 4.6 (Neon)       Java8
Eclipse 4.5 (Mars)       Java7
Eclipse 4.4 (Luna)       Java7
Eclipse 4.3 (Kepler)     Java6

通常,在软件项目中,需要调整集成开发环境程序编译的JDK版本、JRE版本、以及tomcat使用的JRE版本。保持三个版本一致。

tomcat服务器的安装(以7为例)

  • 解压缩版本tomcat注意事项

添加系统变量,名称为CATALINA_HOME,设置值为Tomcat的安装目录。

  • 启动和停止tomcat服务器

在IE地址栏中输入http://localhost:端口号。

tomcat服务器目录

目录

 说明

/bin

存放各种平台下用于启动和停止Tomcat的脚本文件

/conf

存放Tomcat服务器的各种配置文件

/lib

存放Tomcat服务器所需的各种JAR文件

/logs

存放Tomcat的日志文件

/temp

Tomcat运行时用于存放临时文件

/webapps

当发布Web应用时,默认情况下会将Web应用的文件存放于此目录中

/work

Tomcat把由JSP生成的Servlet放于此目录下

tomcat端口配置

通过配置tomcat目录下conf中的server.xml文件修改Tomcat端口号

<Connector port="8080" protocol="HTTP/1.1"
        connectionTimeout="20000"
        redirectPort="8443" />

  

上机练习

安装tomcat,启动和停止tomcat,修改tomcat端口号。并测试。

Web应用程序

手动创建和部署web项目

1、在开发环境中创建web项目

在web-inf/web.xml中配置默认访问启始页面。

2、发布为war文件,拷贝到Tomcat 7.0webapps目录下,启动tomcat。观察webapps目录,可以看到war自动生成web应用程序。在ie中访问项目。

3、在服务器端web项目的目录结构: 

目录

说明

/

Web应用的根目录,该目录下所有文件在客户端都可以访问(JSP、HTML等)

/WEB-INF

存放应用使用的各种资源,该目录及其子目录对客户端都是不可以访问

/WEB-INF/classes

存放Web项目的所有的class文件

/Web-INF/lib

存放Web应用使用的JAR文件

上机练习

1、手动创建一个Web项目,实现项目发布,并能通过浏览器输入网址访问。

2、在myeclipse中创建一个项目导出为war文件,部署到服务器中并访问。

开发环境myeclipse和tomcat的整合

myeclipse和tomcat的整合

进入:windwos->prefereces->myeclipse->servers->tomcat7.x

启用tomcat7服务器,关联JDK。

关闭内置tomcat服务器。

注意:设置只针对工作空间有效

创建项目和部署项目

在myeclipse中启动tomcat服务器

上机练习

在myeclipse中创建项目,在myeclipse中部署项目,在myeclipse中启动服务器,在ie浏览器中访问项目。

JSP概念

JSP:Java Server Pages。在HTML中嵌入Java脚本代码。

例如:

在ie地址栏输入http://localhost:8080/chapter01/index.jsp

运行原理

JSP页面元素

page指令

  • 作用

通过设置内部的多个属性定义整个页面的属性。

  • 语法格式(一个属性中的多个值采用“,”号隔开)
<%@ page 属性1="属性值" 属性2="属性值1,属性值2"… 属性n="属性值n"%>

  

  • 常用属性
属性 描述 默认值
language 指定JSP页面使用的脚本语言 java
import 通过该属性来引用脚本语言中使用到的类文件
contentType 用来指定JSP页面所采用的编码方式

text/html,ISO-8859-1

小脚本与表达式

表达式:显示数据,系统将其作为一个值来进行计算和显示。(不能以;结尾)

上机练习

需求描述:编写JSP页面,计算1—100之间的所有素数之和

提示:1、素数——在一个大于1的自然数中,除了1和此整数自身外,不能被其他自然数整除的数。2、使用out内置对象输出信息。

声明

在编写JSP页面程序时候,有时需要为Java脚本定义成员变量和方法,这时就需要使用JSP声明来实现。

声明语法格式:

<%! Declaration;[ Declaration;]…%>

  

示例:假如以下代码需要在页面中多次使用,如何处理?

<%
	SimpleDateFormat formater = new SimpleDateFormat("yyyy年 MM月dd日");
	String strCurrentTime = formater.format(new Date());
%>

  

使用声明

JSP中的注释

注意:HTML注释在JSP文件被编译后保留,JSP注释则被丢弃。重要信息的注释不要使用HTML注释。

总结

上机练习

需求描述:

编写JSP页面,计算2000—3000年中存在几个闰年。

实现思路:

1. 声明方法boolean leapYear(int year),用于判断是否是闰年

2. 声明一个变量count ,用于统计闰年的个数

3. 设置循环,条件是从2000至3000年

4. 在循环内调用boolean leapYear(int year),根据返回结果,改变count的变量值

提示信息:

闰年的判断条件:能够被4整除而不能被100整除,或者能够被400整除。

JSP执行过程

Web容器处理JSP文件请求需要经过3个阶段

  1. 翻译阶段
  2. 编译阶段
  3. 执行阶段

第一次请求之后,Web容器可以重用已经编译好的字节码文件

如果对JSP文件进行了修改,Web容器会重新对JSP文件进行翻译和编译。

Web程序的调试与排错

运行Web程序时常犯的错误

  • 未启动tomcat
  • 未部署web应用
  • URL输入错误
  • 目录不能被引用
  • JSP脚本错误

错误调试

  • 未启动tomcat

如果服务器无法启动,需要修改端口号。

  • 未部署web应用

确认项目已经部署到tomcat服务器上。

  • URL输入错误

404错误,访问了不可访问的url资源。

  • 目录不能被引用

例如把文件创建到web-inf中,导致404错误。

  • JSP脚本错误

500错误。

按照java程序调试方式排错:阅读代码逻辑、输出数据、debug。

上机练习

需求描述:

  • 将新闻发布系统的静态页面转换成JSP页面后部署到Web项目中,并且可以通过浏览器访问各JSP页面。
  • 创建新闻发布系统数据库。
  • 通过MyEclipse统一设置字符集编码格式为“UTF-8
  • 在HTML页面中加入page指令
  • 将HTML的后缀名改为.jsp

提示: 

  • 通过MyEclipse统一设置字符集编码格式为“UTF-8
  • 在HTML页面中加入page指令
  • 将HTML的后缀名改为.jsp

数据库模型图

新闻主题表:topics

字段

数据类型

是否为空

备注

tid

int

新闻主题编号,主键,自增

tname

char(50)

新闻主题,非空,唯一约束

新闻表:news

字段

数据类型

是否为空

备注

nid

int

新闻编号,主键,自增

ntid

int

新闻主题编号,外键

ntitle

char(100)

新闻标题

nauthor

char(50)

作者

ncreatedate

datetime

发布日期,默认当前时间

npicpath

char(200)

图片路径

ncontent

text

新闻内容

nmodifydate

datetime

编辑日期

nsummary

char(255)

新闻概要

新闻评论表:comments

字段

数据类型

是否为空

备注

cid

int

评论编号,主键,自增

cnid

int

新闻编号,外键

ccontent

text

评论内容

cdate

datetime

评论日期,默认当前时间

cip

char(100)

评论人IP地址

cauthor

char(100)

评论作者

系统用户表:users

字段

数据类型

是否为空

备注

uid

int

用户编号,主键,自增

uname

char(20)

用户名,非空,唯一约束

upwd

char(20)

用户密码,非空



本博客文章未经许可,禁止转载和商业用途!

如有疑问,请联系: 2083967667@qq.com


原文地址:https://www.cnblogs.com/rask/p/8484928.html