html转jsp_052、Java-jsp

1.JSP 技术

概念:

JSP 全名为 Java Server Pages,中文名叫 java 服务器页面,其根本是一个简化的 Servlet 设计,它 [1] 是由 Sun Microsystems 公司倡导、许多公司参与一起建立的一种动态网页技术标准。

特点:

本质上还是 Servlet

跨平台,一次编写处处运行

组件跨平台

健壮性和安全性

JSP的本质就是一个Servlet.

JSP的执行过程:

1.翻译阶段:将JSP翻译成java源文件(Servlet).

2.编译阶段:将JSP编译成class文件(字节码文件)

3.执行字节码

JSP页面的组成部分:

1.指令元素:page指令,include指令, taglib指令。

语法:<%@ 指令元素的名称 属性1="值1" 属性2="值2"...%>

page指令:设置页面的信息 <%@ page language="脚本语言" import="包名.类名" pageEncoding="页面编码集"%>

eg:<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

include指令: 静态引入(静态包含)<%@include file="url" %>

<%@include file="commons.jsp"%>

第一个jsp页面

<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>

e2021c3e14756c80382234c3b5fb1d1e.png

2.jsp的访问原理

35c6e10f8b7f1d8d555ea34e2687a171.png

508e642f29ed9b3208f61b2057e4b20f.png

jsp的访问原理:

浏览器发起请求,请求 JSP,请求被 Tomcat 服务器接收,执行JspServlet 将请求的 JSP 文件转义成为对应的 java 文件(也是Servlet),然后执行转义好的 java 文件。

注意:

jsp中可以书写java代码,但是java代码会被原样转译到其对应的java文件中执行。

3.jsp的page指令

page指令:

设置页面的信息 <%@ page language="脚本语言" import="包名.类名" pageEncoding="页面编码集"%>

page指令的属性:

<%

page指令的作用:

设置jsp转译的时候的一些配置信息。

4.jsp的局部代码块和全局代码块和脚本段语句

局部代码块

声明方式:<% java代码 %>

特点:

使用局部代码块声明的java代码会被原样转译到_jspService方法中。也就是局部代码。

<%
   

全局代码块

声明方式:<%! 声明全局java代码%>

特点:

全局代码块中声明的java代码,在被转译时,会转译成jsp对应的java文件的全局的代码。

作用:

声明方法和全局量等

注意:

使用全局代码块声明方法,使用局部代码块调用方法。

<%!
	

fda8e51db7448d17a1845cc4eeb04280.png

java脚本段、表达式

声明方式:<%=变量名或者方法名()%>

作用:

将java代码的运算结果数据或者其他数据响应给浏览器

注意:

在该表达式中不能使用分号结尾

<

局部代码块声明和全局代码块声明的区别

使用局部代码块声明的java代码会被原样转译到_jspService方法中。也就是局部代码。

全局代码块中声明的java代码,在被转译时,会转译成jsp对应的java文件的全局的代码。

5.jsp的注释

jsp的注释:

HTML注释:会被转译也会被响应给浏览器,但是浏览器不会执行。

CSS注释:会被转译也会被响应给浏览器,但是浏览器不会执行。

js注释:会被转译也会被响应给浏览器,但是浏览器不会执行。

java注释:会被转译,但不会执行

jsp注释:注释内容不会被转译,也不会被执行

格式:%-- 注释内容 --%

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

6.jsp的动态引入和静态引入

问题:

发现,不同的jsp页面会使用相同的资源。如果将资源在每个jsp页面都单独声明则会造成代码的冗余量过高,不易于代码的维护和升级。

解决:

使用静态引入和动态引入的方式

使用:

静态引入:

<%@include file="要引入的资源的相对路径"%>

特点:

被引入的jsp文件和原有jsp文件被转译成一个java文件使用。

注意:静态引入的相关jsp文件中不能声明同名变量。

动态引入:

<jsp:include page="static.jsp"></jsp:include>

特点:

被引入的文件会被单独转译,原有jsp文件会调用被引入的jsp文件。

注意:动态引入的相关jsp文件中可以声明同名变量。

作用:

实现了不同jsp之间的资源共享。

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
 	<head>
 	</head>
 	<body>
 		<h3>我是静态引入和动态引入学习</h3>
		<hr>
		<%-- <i>&copy;网站声明,手机号:77889900,网站备案号等</i> --%>
		<%int a=3; %>
		<!--静态引入  -->
			<%-- <%@include file="static.jsp"%> --%>
		<!--动态引入  -->
		<jsp:include page="static.jsp"></jsp:include>
 	</body>
 </html>	

4f2eae6273683213f83787876c32ef39.png

静态引入和动态引入的区别

相同点:都可以实现页面包含(引入)的效果

不同的:

1.语法不同

静态包含:<%@include file="包含的页面"%>

动态包含:<jsp:include page="包含的页面"/>

2.编译的文件个数不同

动态包含最终编译输出的文件为2个(被包含的页面单独编译), 包含页面和被包含的页面的变量名可用相同。

静态包含最终编程输出的文件为1个,不允许包含页面和被包含的页面的变量名相同。

7.jsp的forward标签

jsp之间的资源转发:

问题:

不同的jsp在处理请求时,有可能会将当前的请求转发给另外的jsp进行处理。

解决:

使用forward动作指令

使用:

<jsp:forward page="要转发的jsp的相对路径"></jsp:forward>

特点:

从当前jsp跳转另外一个jsp页面。

注意:

forward标签中除了<jsp:param value="" name=""/>子标签以外不能出现其他内容,否则会报错。

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
 	<head></head>
 	<body>
 		<h3>forward转发标签学习</h3>
 		<hr/>
 		<%
 			int a=1;
 			if(a>2){
 		%>
 			<b>欢迎访问本网站</b>
 		<%
 			}else{
 		%>
 			<!--转发其他jsp页面  -->
 			<jsp:forward page="common.jsp">
 				<jsp:param value="zhangsan" name="uname"/>
 			</jsp:forward>
 		<% }%>
 	</body>
 </html>
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'common.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  <%
  	request.setCharacterEncoding("utf-8");
  	String uname = request.getParameter("uname");
  	System.out.println(uname);
  %>
  <body>
    <b>这位客官你的请求被屏蔽了,请及时充值</b>
  </body>
</html>

b18394448351665cd774379fb175ecc4.png

9e08c35b78dd84ae0c02fa42d167b2bb.png

8.jsp的内置对象

内置对象:

jsp在转译成其对应的java文件(也就是Servlet)时,会默认在_jspService方法中声明创建几个对象。

特点:

我们可以在jsp页面中声明java局部代码块,在代码块中直接使用内置对象。

JSP的内置对象(九个内置对象/隐式对象)

(1)request对象(HttpServletRequest):封装用户请求数据,通过该对象可以获取用户请求的相关数据。

常用的方法:

request.getParameter(String name)--->String: 根据参数的名称获取参数的值。

request.getParameterValues(String name)--->String[]:根据参数的名称获取参数的值。主要用于复选框。

request.setAttribute(String name,Object value):将指定的值存到request范围中.

request.getAttribute(String name):通过名称从request返回中获取值。

request.getRequestDispatcher(String url).forward(request,response):请求转发

request.setCharacterEncoding(String encoding):设置请求编码集,可以解决post提交的乱码问题。

request.getSession():获取会话对象。

需要了解的方法

request.getScheme():获取协议 --->http

request.getServerName():获取服务器名称或IP地址

request.getServerPort():获取服务器端口号

request.getContextPath():获取上下文路径(默认是项目名)

(2)response对象(HttpServletResponse):封装响应数据。

常用的方法:

response.setContentType(String content);--->response.setContentType("text/html;charset=utf-8");

response.sendRedirect(String url):重定向

response.getWriter()--->JspWriter:获取输出流进行输出

(3)session对象(HttpSession):封装会话信息(浏览器和服务器之间的会话),一个会话中多次请求数据共享。

常用的方法

session.setAttribute(String name,Object value):存值

session.getAttribute(String name):取值

session.invalidate():销毁会话

(4)application对象(ServletContext):封装Servlet上下文信息,整个应用程序共享。

常用的方法

application.setAttribute(String name,Object value):存值

application.getAttribute(String name):取值

(5)out对象(PrintWriter):在页面输出信息

out.print(Object content)/out.println(Object content);

out.write(Object content)

(6)pageContext对象:页面上下文对象,可以通过该对象获取其他8个内置对象

pageContext.setAttribute(String name,Object value):存值

pageContext.getAttribute(String name):取值

(7)page对象(this):当前页面

(8)config对象(ServletConfig):封装配置信息

(9)exception(Exception):封装异常信息

注意:

对象的名字必须是转译好的java文件中声明的对象名。

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
	//获取请求数据
	String uname = request.getParameter("uname");
	System.out.println(uname);
	int a=3;
	session.setAttribute("str", "我是session");
%>

32a86823108252f135cde17a7f1fd04d.png

四大作用域:

page(pageContext)|request|session|application作用域的区别

page:作用域范围仅限于当前页面。

request:作用域范围仅限于一次请求之间(包含当前页面)。注意:如果在A页面存值,在B页面取值,则A页面跳转B页面必须使用请求转发。

session:作用域范围仅限于一次会话之间(包含当前页面和多次用户请求)。

application:作用域范围是整个应用程序(项目)共享

其范围大小:application>session>request>page

JSP 负责页面展现,Servlet 负责业务逻辑处理。

9.Servlet中请求转发和重定向的绝对路径

问题:

在jsp页面中进行资源之间的跳转时,如果书写的是相对路径

这样会造成如果当前文件的路径发生变更,从当前路径查找资源的相对路径都要重新进行书写。

解决:

将相对路径变成绝对路径

使用:

在jsp中路径中的第一个/表示服务器根目录。

示例:

<a href="/虚拟项目名/资源路径">访问关键字</a>

注意:

在Myeclipse中创建的jsp页面会自动生成路径处理代码basePath

而basePath的值为当前项目根目录,并且在head标签中使用了<base href="<%=basePath%>">

相当于将当前页面的资源全部默认定位为从项目根目录开始查找,我们就不需要写第一个/了

注意:

basePath方式和添加/方法只能二选一。

文件路径

eed182fb10fe1de076166915075290b9.png

path.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'path.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
   </head>
  
  <body>
    	我是path.jsp
    	<a href="a/a.jsp">a.jsp</a>
  </body>
</html>

a.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'a.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
    	我是a.jsp
    	<!-- <a href="a/b/b.jsp">b.jsp</a> -->
    	<a href="./path.jsp">path.jsp</a>
  </body>
</html>

b.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'b.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
    	我是b.jsp
    	<a href="path.jsp">path.jsp</a>
  </body>
</html>

9ad2334d13c72a5f387d1a36db1724fd.png

ad2be1dc06627b370cb9069236975558.png

edc200cbbdd879d7dbd45d3c8549a20f.png

路径问题(基础路径:主要解决跳转时目录路径问题,通过基础路径每次从项目的根目录开始查找,可以省去相对路径之间的进退文件夹的问题)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值