热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

request内置对象,什么是JSP

这里是修真院前端小课堂,本篇分析的主题是【什么是jsp?jsp的内置对象有哪些?】每篇分享文从【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论


这里是修真院尖端小教室,本篇分析的主题是


【什么是jsp? jsp的内置对象是什么? 】


所有的共享语句都是


【背景介绍】【知识分析】【常见问题】【解决方案】【编码实战】【思维拓展】【更多讨论】【参考文献】


从8个方面深入解析前端知识/技能,本篇分享的是:


【什么是jsp? jsp的内置对象是什么? 】


1、背景介绍百度百科这样介绍JSP :“JSP是动态网页技术标准。 其根本原因是为了简化servlet的设计,是由Sun Microsystems公司提出并由多家企业参与设立的动态web技术标准。 ”


通过以上介绍,可以看到servlet先出,jsp后出。


所以,如果你想知道jsp,请先学习servlet。


在地址栏中键入test3访问servlet时,浏览器将返回与以下内容类似的结果:


在网页源代码上单击鼠标右键,可以看到它是一个非常常见的HTML代码。


也就是说,servlet将各种HTML代码连接在一起,最终将HTML页返回给客户端。


我们要做的动态网站,如果所有的HTML页面都是这样形成的,会不会太繁琐了?


于是,jsp诞生了。


jsp怎么样呢?


访问浏览器的结果:


如您所见,jsp页面的


%for(intI=0; i4; I )等中嵌入的类似java代码的东西消失了。 出现了四次helloworld这个词。 因此,jsp推测是不是要在HTML页面中嵌入java代码,以某种方式执行这些java代码,最终返回到想要生成的HTML页面。


在系统所在的路径下,可以找到由tomcat解析为java类的jsp页。 然后一个是. class文件,另一个是java文件。


这不是我们熟悉的java类及其编译到. class字节码文件中吗?


打开test_jsp文件可以看到重要的部分。


publicvoid_JSP服务(final javax.servlet.http.httpservletrequestrequest,final javax.servlet.http.http servlet respop javax.servlet.servlet exception javax.servlet.http.http会话会话=null; final javax.servlet.servlet上下文APP; final javax.servlet.servletconfig config; jvax.servlet.JSP.jspwriter out=null; final java.lang.Object page=this; jvax.servlet.JSP.jspwriter _ jspx _ out=null; avax.servlet.JSP.pagecontext _ jspx _ page _ cOntext=null; try { response.set content type (' text/html; charset=UTF-8 '; pagecOntext=_ jspx factory.get pagecontext (this,request,response,null,true,8192,true ); _jspx_page_cOntext=pageContext; application=pagecontext.getservletcontext (; cOnfig=pagecontext.get servletconfig (; session=pageContext.getSession (; out=pageContext.getOut (; _jspx_out=out; out.write('\r\n ' ); out.write('\r\n ' ); out.write(html\r\n ); out.write(head\r\n ); out.write(title测试/title\r\n ); out.write ()/head\r\n ); out.write(body\r\n ); out.write('\r\n ' );

out.write(" "); for(int i=0; i<4;i++) { out.write("\r\n"); out.write(" helloWorld!
\r\n"); out.write("\r\n"); out.write(" "); } out.write("\r\n"); out.write("\r\n"); out.write("\r\n"); out.write("\r\n"); } catch (java.lang.Throwable t) { if (!(t instanceof javax.servlet.jsp.SkipPageException)){ out = _jspx_out; if (out != null && out.getBufferSize() != 0) try { if (response.isCommitted()) { out.flush(); } else { out.clearBuffer(); } } catch (java.io.IOException e) {} if (_jspx_page_context != null) _jspx_page_context.handlePageException(t); else throw new ServletException(t); } } finally { _jspxFactory.releasePageContext(_jspx_page_context); } }

 

2、知识剖析:


来看一下jsp的执行流程:

 

注意,只有jsp是新创建或是修改后第一次访问时,jsp parser才会将其编译成servlet程序。之后调用JSDK将对应的servlet程序编译成servlet字节码。

而且,它并非是将页面本身发送给客户端,而是把页面执行的结果发送给客户端。
客户端收到这个文件后,就可以正常显示在客户端了。

比如我要要访问test.jsp,然后利用Tomcat的解析器,他会将jsp文件转化为java文件,这个java文件就是servlet,
所以jsp本质上就是servlet。
jsp能实现的,servlet也能实现。不管你最终写的是一个多么复杂的jsp文件,它最后总能转化为一个html文件。

jsp的9个内置对象和4个作用域:

request 请求对象  类型 javax.servlet.ServletRequest 作用域 Requestresponse 响应对象 类型 javax.servlet.SrvletResponse 作用域 PagepageContext 页面上下文对象 类型 javax.servlet.jsp.PageContext 作用域 Pagesession 会话对象 类型 javax.servlet.http.HttpSession 作用域 Sessionapplication 应用程序对象 类型 javax.servlet.ServletContext 作用域 Applicationout 输出对象 类型 javax.servlet.jsp.JspWriter 作用域 Pageconfig 配置对象 类型 javax.servlet.ServletConfig 作用域 Pagepage 页面对象 类型 javax.lang.Object 作用域 Pageexception 例外对象 类型 javax.lang.Throwable 作用域 page

同样 来看一个例子:
这里有两个jsp页面,page01和page02。

jsp useBean 标签表示 创建一个由class属性指定的类的实例,然后把它绑定到其名字由id属性给出的变量上。
那这里我创建了4个字符串缓冲类的实例,他们的作用域分别是page, request, session,application。

<%@ page language="java" cOntentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <% pageVar.append("page01"); requestVar.append("page01"); sessionVar.append("page01"); applicationVar.append("page01");%> <%@ page language="java" import="java.util.*" cOntentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> 这里是page02,是从page1转来的
name<% pageVar.append("page02"); requestVar.append("page02"); sessionVar.append("page02"); applicationVar.append("page02");%>

page

= <%=pageVar.toString()%>

request

= <%=requestVar.toString()%>

session

= <%=sessionVar.toString()%>

application

= <%=applicationVar.toString()%>

jsp forward 标签表示 当走到这里的时候,页面会跳转到page02.jsp。 这刚好就是一个会话的场景,

 

 

现在我们刷新一下页面,可以看到,page作用域变量的输出的值为page02,原本它的page01已经不见了。

request作用域的变量只在当前请求的中有效,当前的请求就是从page01到page02的一次跳转。
所以它的值把page01和page02都显示出来了。

session作用域的变量为当前会话,也就是只要浏览器不关闭,page02能一直叠加到上去。
application 对所有应用有效,也就是只要这个应用启动着,都要叠加。

 


推荐阅读
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 本文详细介绍了如何准备和安装 Eclipse 开发环境及其相关插件,包括 JDK、Tomcat、Struts 等组件的安装步骤及配置方法。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • JavaScript 中创建对象的多种方法
    本文详细介绍了 JavaScript 中创建对象的几种常见方式,包括对象字面量、构造函数和 Object.create 方法,并提供了示例代码和属性描述符的解释。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • andr ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
author-avatar
零乱772_553
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有