【JSP入门】只知道HTML却不知道JSP?_如何快速通过html界面找到jsp_abcccccccccccccccode的博客-程序员宅基地

技术标签: Java Web  java  javaweb  jsp  servlet  前端  

前言

今天我们继续来总结学习JSP相关知识,上一篇我们学习了Servlet的基础入门,如果你还对Servlet那么建议你先去看一下上篇博客再回来。

传送门:【Servlet入门】一篇文章让你从没听过到了熟于心

在之前我们已经学习了HTML,CSS,JS,XML,Servlet了,那么JSP又是什么呢?为什么要学这个JSP呢?

JSP概述

JSP(全称Java Server Pages)是由 Sun Microsystems 公司倡导和许多公司参与共同创建的一种使软件开发者可以响应客户端请求,而动态生成 HTML、XML 或其他格式文档的Web网页的技术标准。

JSP特征

(1)JSP文件后缀名为 *.jsp
(2)JSP 技术是以 Java 语言作为脚本语言的,JSP 网页为整个服务器端的 Java 库单元提供了一个接口来服务于HTTP的应用程序。
(3) JSP是一种动态网页开发技术。它使用JSP标签在HTML网页中插入Java代码。标签通常以<%开头以%>结束。
(4)JSP是一种Java servlet,主要用于实现Java web应用程序的用户界面部分。网页开发者们通过结合HTML代码、XHTML代码、XML元素以及嵌入JSP操作和命令来编写JSP。
(5)JSP可以通过网页表单获取用户输入数据、访问数据库及其他数据源,然后动态地创建网页。
(6)JSP标签有多种功能,比如访问数据库、记录用户选择信息、访问JavaBeans组件等,还可以在不同的网页中传递控制信息和共享信息。

JSP运行要求:

可以正常运行的Tomcat
所有的JSP页面扩展名必须是.JSP
JSP页面应该放在Web应用程序目录下

JSP的动态生成

其实JSP最重要的一个特点就是可以动态的生成网页,接下来我们使用HTML与JSP生成同样的页面来比较一下吧。

接下来我们完成这样的一个页面:
在这里插入图片描述
正常做出来之后应该是这样的:
在这里插入图片描述
首先我们使用HTML来完成,很简单我们一行一行打出来即可,代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<table>
		<tr>
			<th>year</th>
			<th>salary</th>
		</tr>
		<tr>
			<td>0</td>
			<td>1500</td>
		</tr>
		<tr>
			<td>1</td>
			<td>1650</td>
		</tr>
		<tr>
			<td>2</td>
			<td>1800</td>
		</tr>
		<tr>
			<td>3</td>
			<td>1950</td>
		</tr>
		<tr>
			<td>4</td>
			<td>2100</td>
		</tr>
		<tr>
			<td>5</td>
			<td>2250</td>
		</tr>
		<tr>
			<td>6</td>
			<td>2550</td>
		</tr>
		<tr>
			<td>7</td>
			<td>2850</td>
		</tr>
		<tr>
			<td>8</td>
			<td>3150</td>
		</tr>
		<tr>
			<td>9</td>
			<td>3450</td>
		</tr>
		<tr>
			<td>10</td>
			<td>3750</td>
		</tr>
		<tr>
			<td>11</td>
			<td>4125</td>
		</tr>
	</table>
</body>
</html>

效果如下:
在这里插入图片描述
效果是没问题的,只不过代码有些繁琐,而且答案都是我们自己算出来写上面的。而且我们只写出来了11年时候的工资,如果是50那么还得继续算和写下去,十分麻烦。

那么JSP是可以动态的生成的,我们使用JSP怎么完成呢?

其实很简单,我们按照案例中给出来规律来写即可自动生成,如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<table>
		<tr>
			<th>year</th>
			<th>salary</th>
		</tr>
		<%
			for(int i=0;i<=50;i++){
				out.println("<tr>");
				out.println("<td>" + i + "</td>");
				int sal=0;
				if(i<=5){
					sal = 1500 + i*150;
				}else if(i>5&&i<=10){
					sal=1500 + 5*150 + 300*(i-5);
				}else if(i>10){
					sal = 1500+5*150+5*300+375*(i-10);
				}
				out.println("<td>" + sal + "</td>");
				out.println("</tr>");
			}
		
		%>
	</table>
</body>
</html>

我们直接生成了50年的,代码是不是看起来很简便啊,那我们看看输出的页面怎么样:
在这里插入图片描述
都是相同的效果。

通过比较大家应该就可以理解它们的差距了吧。

JSP的执行过程

我们刚才写的JSP中既有HTML语言,又有Java语言,最后又是Servlet执行了。那么JSP的执行过程到底是怎么样的一个过程呢?

当第一次访问jsp页面时,会向一个servlet容器(tomcat等)发出请求,servlet容器先要把jsp页面转化为servlet代码(.java),再编译成.class 文件再进行调用。当再次访问jsp页面时跳过翻译和编译的过程直接调用。

执行过程:

(1)客户端发出请求
(2)web容器将jsp转化为servlet代码(.java)
(3)web容器将转化为servlet代码编译(.class)
(4)web容器加载编译后的代码并执行
(5)将执行结果响应给客户端

图示:
在这里插入图片描述
示例:
在这里插入图片描述

JSP的基本语法

JSP语法特别简单,按照功能可分为:

(1)JSP代码块
(2)JSP声明构造块
(3)JSP输出指令
(4)JSP处理指令

接下来就分别介绍一下他们是干什么的吧

JSP代码块

JSP代码块用于在JSP中嵌入Java代码,其语法格式为:

<% Java代码 %>

示例:

<% System.out.println("hello,baibai!"); %>

JSP声明构造块

JSP声明构造块用于声明变量或方法,其语法格式为:

<%! 声明语句 %>

示例:

<%!public int add(int a,int b){
    
	return a+b;
}%>

JSP输出指令

JSP输出指令用于在JSP页面中显示Java代码执行结果,其语法格式为:

<%=Java代码%>

示例:

<%="<b>" + name +"</b>"%>

JSP处理指令

JSP处理指令用于提供JSP执行过程中的辅助信息,其语法格式为:

<%@ JSP指令 %>

示例:

<%@ page import = "java.until.*" %>

JSP常用处理指令

1.定义当前JSP页面全局设置

<%@ page %>

2.将其他JSP页面与当前JSP页面合并

<%@ include %>

3.引入JSP标签库

<%@ taglib %>

JSP中注释的区别

1.JSP注释,被注释语句不做任何处理

<%--注释--%>

2.用于注释<%%>Java代码,被注释代码不执行

//注释/*注释*/

3.HTML注释,被注释的语句不会被浏览器解释

<!--html-->

语法练习

找质数

题目:
在这里插入图片描述
代码:

<%@page import="java.util.*,java.text.*" contentType="text/html; charset=UTF-8" %>
<%!
	boolean isPrime(int num){
    
		boolean flag = true;
		for(int j=2;j<num;j++){
    
			if(num%j==0){
    
				flag=false;
				break;
			}
		}
		return flag;
	}

%>

<%
	List<Integer> primes = new ArrayList();
	for(int i=2;i<1000;i++){
    
		if(isPrime(i)){
    
			//out.println("<h1> " + i + "</h1>");
			primes.add(i);
		}
	}
%>

<%
	for(int p:primes){
    
		//out.println("<h1>" + p +"是质数</h1>");
%>
	<h1 style="color:red;"><%=p %>是质数</h1>
<%
	}
%>

输出:
在这里插入图片描述

JSP页面复用

在javaweb开发过程中,要写许多个jsp页面,而这些页面又有许多的相似之处,比如页头、页脚和导航栏等等这些相同又重复的部分如果每个jsp页面都写的话会造成代码的冗余且不易管理维护,这时可以通过页面复用的方式来提高效率。

那么我们又该怎么样来实现页面的复用呢?

将每个页面中相同且重复的代码封装在一个JSP页面中,再通过以下方式引用即可:

<%@ include file=xxx.jsp">

示例:

比如一个某新闻页面为:
在这里插入图片描述

每一次我们只改变的是新闻的内容,即上图中红框内的东西,那么页头页脚都是复用的,我们就可以把它们分别封装为JSP页面,在使用的时候调用即可。我们实现一下:

对于页头:

<%@page contentType="text/html; charset=utf-8"%>
要闻|推荐|财经|娱乐

对于页脚:

<%@page contentType="text/html; charset=utf-8"%>
<hr/>
Copyright 1999-3274

对于每一个要输出的新闻页面:

<%@page contentType="text/html; charset=utf-8" %>
<%@include file="include/header.jsp" %>
<%
	out.println("<h1>新闻标题</h1>");
	out.println("<h1>正文</h1>");
%>
<%@include file="include/footer.jsp" %>

在这里插入图片描述

输出为:
在这里插入图片描述
成功了,页面复用我们在很多场景都能遇到,还是比较重要的,也比较简单。

结语

本篇JSP入门的内容到此为止了,但是JSP的内容不止于此,JSP是与Servlet一起联用的,我们下篇博客就一起来看看它们到底是怎么要一起联合使用的吧!

持续更新中…

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/apple_51673523/article/details/122889395

智能推荐

C语言那些关键字_Joker......的博客-程序员宅基地

Static关键字 static 的作用是什么?这个简单的问题很少有人能回答完全。在 C 语言中,关键字 static 有三个明显的作用:在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 在模块内(函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用。大多数应试者能正确回答第一部分,一部分能正.

Opencv2.4.10版本lib名称_opencv2410lib-程序员宅基地

releaseopencv_calib3d2410.libopencv_contrib2410.libopencv_core2410.libopencv_features2d2410.libopencv_flann2410.libopencv_gpu2410.libopencv_highgui2410.libopencv_imgproc2410.libopencv_legac..._opencv2410lib

遍历HashMap和HashSet的方法-程序员宅基地

遍历HashMap的五种方法public static void main(String[] args){ //构建一个map Map<String, String> map = new HashMap<>(); map.put("1","a"); map.put("2","b"); //第一种方法:普遍使用,通过Map.keySet()遍历key,然后获取相应value for(String key:map.keySet()){ System.out.printl

python average函数怎么用_python之函数的使用-程序员宅基地

2.1 定义函数def函数名(参数):代码1代码2......2.2 调⽤函数函数名(参数)注意:1. 不同的需求,参数可有可⽆。2. 在Python中,函数必须先定义后使⽤。2.3 快速体验需求:复现ATM取钱功能。1. 搭建整体框架(复现需求)print('密码正确登录成功')#显示"选择功能"界⾯print('查询余额完毕')#显示"选择功能"界⾯print('取了2000元钱')#显示"选..._python average

python 爬虫问题解决_f.read().decode() 爬虫-程序员宅基地

1、爬取晋江网页(1)报错:UnicodeDecodeError: 'utf-8' codec can't decode byte 0x8b in position 1: invalid start by...(2)原因:网站发包是gzip格式,因此解码会是乱码:headers['Accept-Encoding']="gzip(3)解决用gzip包解压传回来的网页正常def askURL(url): head = { "User-Agent": "M.._f.read().decode() 爬虫

Adobe Illustrator 中的路径查找器_在illustrator中,两个图形,使用路经查找器减去顶层,底层图形的路径产生什么变化-程序员宅基地

Adobe Illustrator 是一款矢量绘图工具,通常我们用它来制作LOGO、海报等设计。既然是矢量绘图,那就离不开路径,以下介绍AI中的路径查找器功能:_在illustrator中,两个图形,使用路经查找器减去顶层,底层图形的路径产生什么变化

随便推点

leetcode hot100(第一部分) + python(c++)_leetcode hot100 python_薛定谔的智能的博客-程序员宅基地

1-1.两数之和思路1:两层for循环 O(n2)class Solution: def twoSum(self, nums, target): res = [] for i in range(len(nums)): for j in range(i+1, len(nums)): if nums[i]+nums[j]==target: res.extend(_leetcode hot100 python

知识点-os文件地址读取与拼接、pip安装豆瓣源例子和endswith startswith使用_os endswith-程序员宅基地

1.pip安装豆瓣源例子#只要正常pip install ***,install后面添加 -i https://pypi.douban.com/simple 就行,这样用了国内库源加快下载安装速度2.os(join abspath dirname)文件地址读取与拼接1)dirname 读取当前文件的文件夹名称 os.path.dirname(file)2)abspath 获取当前文件的..._os endswith

c语言关键字总结_c语言local关键字-程序员宅基地

以下是阿鲤对c语言中关键字的总结复习,希望对大家有所帮助1:auto 2:const 3:break continue4:switch case default5:char int long float double6:while do7:if else8:for9:enum10:extern11:go to12:register..._c语言local关键字

《操作系统实用教程--螺旋方法》习题答案_实用操作系统教程答案-程序员宅基地

第一章:入门1.1操作系统是为普通用户和编程人员提供服务,从而使计算机的使用无须处理那些低级的、难以掌控的硬件命令的软件。1.2略1.3(1)操作系统可以把安装在游戏系统上的各种不同游戏所需要的公共模块整合到一起并统一管理(2)操作系统可以处理异常事件。(3)一些重要的操作系统概念已经融入该游戏系统中,例如当游戏被启动时,其部分软件模块被加载进内存,而其他部分可能被预装进ROM。1.4..._实用操作系统教程答案

三类XML文件的解析方法_解析xml文件的三种方式-程序员宅基地

XML文件的解析mybatis的学习当中,配置的加载传统的是通过解析用户配置的文件,获取到数据库连接与对象实体映射关系的,书中有描述到DOM\SAX\StAX 几种方案,一方面是夯实基础,一方面是了解三种方法的优缺点,今天就学习一下XML文件的解析一、XML的解析方式DOM 解析XML底层接口之一,跨平台,跨语言SAX 解析XML底层接口之一Jdom/dom4J 基于底层API的封装,Java语言,更方便便捷二、DOM解析DOM 解析的原理:树形结构,依赖内存加载文件,树在内存中_解析xml文件的三种方式

【Android】监测root权限:通过判断su文件确定-程序员宅基地

最开始的思路是执行su命令,查看返回结果,实际测试发现程序会停滞(对程序的操作程序不能及时反应),陷入苦苦思索,后来想到root权限其实关键是su文件,那能不能通过判断su文件是否存在来做root权限检测呢? private enum RootState {NA, NO, OK} private static RootState rootState = RootState.NA;