jsp、servlet笔记

这篇具有很好参考价值的文章主要介绍了jsp、servlet笔记。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、init    初始化Jsp&Servlet方法    destroy 销毁Jsp&Servlet之前的方法    service 对用户请求生成响应的方法 2、Jsp文件必须在jsp服务器内运行    Jsp文件必须生成servlet执行    每个jsp页面的第一个访问者速度很慢,因为必须等待jsp编译为servlet    jsp页面的访问者无需安装任何客户端,甚至不需要java的运行环境,因为jsp页面输送到客户端的是标准的html页面 3、jsp注释:<%-- 注释内容 --%>    html注释:<!-- 注释内容 -->    jsp声明:<%! 声明部分 %>    jsp输出表达式:<%= jsp表达式 %> 4、通过jsp声明语法定义的变量和语法对应于servlet类里面的成员变量和方法,jsp脚本部分会转换为_jspService方法内的可执行代码,所以jsp脚本中不能定义方法,因为java不允许在方法内部定义方法 5、jsp三个编译指令:page 针对当前页面的指令 include 包含另一个页面(静态包含,会把被包含界面的编译指令也包含进来,但是动态的<jsp:include>不会) taglib 用于定义和访问自定义标签 6、jsp的七个动作指令:

<jsp:forward page="">
<jsp:param name="" value="">
</jsp:forward>  参数传递
<jsp:include> 动态包含(仅导入页面body内容)
<jsp:plugin> 用于下载javaBean或者Applet到客户端执行
<jsp:userBean> 创建javaBean实例
<jsp:setProperty> 设置javaBean实例的属性值
<jsp:getProperty> 输出javaBean实例的属性值

复制

-------------------------------------------------------------------------------------------------------------- ps: 执行forward时,用户请求的url不会发生改变,转发时客户端的请求参数不会丢失,但页面内容完全被forward目标页内容  所取代。相当于用新页面来生成或处理用户请求,所以请求参数、属性的信息不会丢失。 ps:静态导入和动态导入的区别: 1、静态导入是完全融合,两个页面融合为一个servlet;而动态导入则在servlet中使用include方法来引入被导入页面的b ody内容; 2、静态导入时被导入页面的编译指令会起作用,动态导入不会; 3、动态包含可以追加额外参数; -------------------------------------------------------------------------------------------------------------- 7、jsp中的九个内置对象 application(让多个jsp、servlet共享数据)、config(可以获取servlet在web.xml文件中的配置参数——config.getInitParameter("paramName"))、exception、request、response、out(输出流对象,out.write(...)等价于<%= jsp表达式 %>)、session、page、pageContext ps:四个map结构:page、request、session、application 8、在web.xml文件中配置application(servletContext实例)级别变量——在jsp中通过application.getInitParameter("driver")访问: 配置application级别变量:

<context-param>
<param-name>driver</param-name>
<param-value>com.mysql.jdbc.Driver</param-value>
</context-param>

复制

配置servlet初始化参数:

<servlet>
<init-param>
<param-name>name</param-name>
<param-value>jack</param-value>
</init-param>
</servlet>

复制

9、PageContext内置对象: 代表页面上下文,用于访问jsp之间的共享数据,使用PageContext可以访问page、request、session、application范围的变量 getAttribute(String name) setAttribute(String name,int scope),scope可以是如下四个值:PageContext.PAGE_SCOPE、PageContext.REQUEST_SCOPE、PageContext.SESSION_SCOPE、PageContext.APPLICATION_SCOPE PageContext.getRequest、PageContext.getResponse、PageContext.getServletConfig、 PageContext.getServletContext、PageContext.getSession 10、request对象: 获取请求头、请求参数;操作request范围的属性; -------------------------------------------------------------- 执行forward或者include——代替jsp提供的forward或者include指令。 HttpServletRequest类提供了一个getRequestDiapatcher(String path)(Path必须以"/开始")方法, 其中path就是希望forward或include的目标路径,该方法返回RequestDispatcher对象。该对象提供以下两个方法:

-> forward(ServletRequest request,ServletResponse response); //forward到path下页面
-> include(ServletRequest request,ServletResponse response); //将path页面include到本页面

复制

------------------------------------------------------------------ 11、response对象: 生成非字符响应(jsp的out对象属于JspWritter类,属于字符流的形式),对于字节流输出可以使用response 重定向:response.sendRedirect("") 增加cookie:

<%
String name = request.getParameter("name");
Cookie cookie = new Cookie("userName",name);
cookie.setMaxAge(24 * 3600);//设置cookie有效期为24h,如果不设置,则web应用关闭时cookie自动失效
response.addCookie(cookie);
%>
<%-- 获取本站保留的用户cookie --%>
<%
Cookie[] cookies = request.getCookies();
for(Cookie c: cookies){             //遍历cookie查找输出
if(c.getName().equals("userName")){
out.println(c.getValue());
}
}
%>

复制

如果cookie中出现中文字符,则必须使用java.net.URLEncoder进行编码,然后使用java.net.URLDecoder对其进行解码:

<%
//使用java.net.URLEncoder.encode进行编码
Cookie c = new Cookie("cnName",java.net.URLEncoder.encode("孙悟空"),"GBK");
cookie.setMaxAge(24 * 3600);//设置cookie有效期为24h,如果不设置,则web应用关闭时cookie自动失效
response.addCookie(cookie);

//获取cookie
Cookie[] cookies = request.getCookies();
for(Cookie c: cookies){             //遍历cookie查找输出
if(c.getName().equals("userName")){
//使用java.net.URLDecoder.decode进行解码
out.println(java.net.URLDecoder.decode(c.getValue()));
}
}
%>

复制

12、session对象:主要用于跟踪用户会话信息,如判断用户是否登录系统,或者在购物车应用中,用于跟踪用户购买的商品。 session范围的属性可以是多个页面的跳转之间共享,主要有setAttribute(String attName,Object attValue)、 getAttribute(String attName)两个常用方法。 session机制通常用于保存客户端的状态信息,这些状态信息需要保存到web服务器的硬盘上,所以要求session里的属性值必须是可序列化的,否则会引发不可序列化的异常。session的属性值可以是任何可序列化的java对象。 13、servlet介绍 servlet通常是服务端小程序,运行在服务器端,用于处理及响应客户端请求。 servlet是个特殊的java类,这个类必须继承HttpServlet,servlet提供不同的方法来响应客户端请求: doGet、doPost、doPut、doDelete分别用于响应各自请求。一般只有doGet、doPost两种。 大部分时候,servlet对于所有请求的响应都是一样的,此时,可以重写service()方法即可响应客户端的所有响应。 另外HttpServlet包含另外两个方法: -> init(ServletConfig config) //创建servlet实例时,调用该方法初始化该servlet资源 -> destroy() //销毁servlet时,自动调用该方法回收资源 ps:普通servlet类里的service()方法的作用,完全等同于jsp生成servlet类的_jspService()方法。 14、servlet的配置 配置servlet有2种方式:

-> 在servlet类中使用@WebServlet Annotation配置
-> 在web.xml文件中配置

复制

<servlet>
<servlet-name>aa</servlet-name>
<servlet-class>org.Class</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>aa</servlet-name>
<url-pattern>/aa</url-pattern>
</servlet-mapping>

复制

15、servlet的生命周期(servlet的创建销毁等都是由web容器决定) ->创建servlet实例->init()->完成初始化->响应客户请求->destroy()->资源回收完成->实例被销毁 servlet创建有2个时机,用户请求之时、应用启动之时(通常用于某些后台服务的servlet,或者用于拦截请求的servlet) load-on-startup:

->它的值必须是一个整数,表示servlet应该被载入的顺序
->当值为0或者大于0时,表示在容器启动的时候就被加载并初始化
->当值小于0或者没有指定时,表示该servlet被选择调用的时候才会去加载
->正数的值越小,该servlet的优先级越高,应用启动就越先加载
->当值相同时,容器会自主选择相应servlet的加载顺序

复制

16、Filter介绍 Filter可以认为是servlet的加强版,主要用于在request到达servlet之前进行预处理或者response到达客户端之前对response进行预处理操作。 Filter主要分类:

->日志Filter:只要用于记录用户每次的请求操作
->用户授权的Filter:负责检查用户请求,过滤非法请求
->负责解码的Filter:包括对非标准编码的请求解码
->XSTL:能改变xml内容的XSTL Filter
->一个Filter可以拦截多个用户请求,一个请求也可以被多个Filter拦截

复制

创建Filter只需要: ->创建Filter类 ->在web.xml文件中配置filter 创建Filter必须实现的接口javax.servlet.Filter接口,该接口中定义了三个方法:

->init(FilterConfig config)  //在config对象中可以获取该filter的一些初始化参数,获取方法同servlet
->destory() //完成对filter销毁前资源的回收
->doFilter(HttpServletRequest request,HttpServletResponse response,FilterChain chain)  //doFilter方法中的代码实际就是从多个servlet中的service()方法中抽调出来的通用代码,通过利用filter可以很好地实现代码复用。

复制

17、Listener类 创建listener步骤: ->创建listener实现类 ->在web.xml文件中配置该listener 常见的web事件监听器接口有以下几种:

->ServletContextListener,用于监听web应用的启动关闭,
->ServletContextAttributeListener,用于监听ServletContext(application)范围内属性的改变
->ServletRequestListener,用于监听用户请求
->ServletRequestAttributeListener,用于监听ServletRequest(request)范围的属性的改变
->HttpSessionListener,用于监听session的开始和结束
->HttpSessionAttributeListener,用于监听HttpSession(session)范围内属性的改变

复制

1)ServletContextListener

<context-param>
        <param-name>name</param-name>
        <param-value>value</param-value>
  </context-param>

->contextInitialized(ServletContextEvent sce),启动web应用时调用
->contextDestroyed(ServletContextEvent sce),关闭web应用时调用

复制

配置Listener 在listener实现类上添加注解@WebListener即可,或者在web.xml根目录中配置:

<listener>
<!-- 指定该listener的实现类 -->
<listener-class></listener-class>
</listener>

ServletContextAttributeListener
->attributeAdded(ServletContextAttributeEvent event),将存入一个属性至application调用
->attributeRemoved(ServletContextAttributeEvent event),将一个属性从application范围中删除时调用
->attributeReplaced(ServletContextAttributeEvent event),将一个属性替换时调用

复制

2)ServletRequestListener和ServletRequestAttributeListener

ServletRequestListener用于监听用户请求的到达,该接口的监听器需实现以下两个方法:
->requestInitialized(ServletRequestEvent event),用户请求到达、被初始化时调用
->requestDestroyed(ServletRequestEvent event),用户请求结束、被销毁时调用
ServletRequestAttributeListener用于监听request范围内属性的变化,该接口下方法如下:
->attributeAdded(ServletRequestAttributeEvent event)
->attributeRemoved(ServletRequestAttributeEvent event)
->attributeReplaced(ServletRequestAttributeEvent event)  //event.getName() or getValue()获取属性名、值

复制

3)HttpSessionListener和HttpSessionAttributeListener

->sessionCreated(HttpSessionEvent event),用户与服务器的会话开始、创建时触发该方法
->sessionDestroyed(HttpSessionEvent event),用户服务器的会话断开、销毁时调用
HttpSessionAttributeListener用于监听session范围内属性的变化,该接口下方法如下:
->attributeAdded(ServletRequestAttributeEvent event)
->attributeRemoved(ServletRequestAttributeEvent event)
->attributeReplaced(ServletRequestAttributeEvent event)

复制

18、表达式语言 ${expression} 在jsp页面中使用表达是语言可以直接获取请求参数值、获取javabean的指定属性值、获取请求头、获取各种范围属性值。 表达式语言内置11种:

->pageContext,同jsp内置对象中的PageContext对象
->pageScrope,用于获取page范围的属性值
->requestScrope,用于获取request范围的属性值
->sessionScrope,用于获取session范围属性值
->applicationScrope,用于获取application范围属性值
->param,用于获取请求的参数值
->paramValues,用于获取属性为数组的属性值
->header,用于获取请求头的属性值
->headerValues,用于获取请求头的属性值维数组的属性值
->initParam,用于获取web应用的初始化参数,即<context-param></context-param>中的值
->cookie,用于获取cookie值

复制

19、servlet 3.0的文件上传 表单文件form.jsp:

<form method="post" action="upload" enctype="multipart/form-data">
文件名:<input type="text" id="name" name="name" /></br>
选择文件:<input type="file" id="file" name="file" />
<input type="submit" value="上传" />
</form>

复制

UploadServlet如下:

@WebServlet(name="upload",urlPatterns={"/upload"})
@MultipartConfig   //该注解指定该servlet用于处理文件上传请求
public class UploadServlet extends HttpServlet{
public void service(HttpServletRequest request,HttpServletResponse response) throws Exception{
response.setContentType("text/html;charset=utf-8");
PrintWriter pw = response.getWriter();
//获取普通请求参数
String fileName = request.getParameter("name");
//获取上传文件域
Part part = request.getPart("file");
out.println("上传文件类型:"+ part.getContentType());
out.println("上传文件大小:"+ part.getSize());
//获取该文件上传域的Header Name
Collection<String> headerNames = part.getHeaderNames();
for(String headerName: headerNames){
out.println(headerName + "---" + part.getHeader(headerName));
}
//将上传的文件写入服务器uploadFiles文件夹下面
part.write(getServletContext().getRealPath("/uploadFiles") + "/" fileName);
}
}

复制文章来源地址https://www.toymoban.com/news/detail-495191.html

到了这里,关于jsp、servlet笔记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 神经网络的初始化方法

    对于神经网络的训练过程中,合适的参数初始化方法有助于更好的处理梯度消失和梯度爆炸问题。 通常有以下几种初始化方法: 随机初始化(Random Initialization):最简单的初始化方法是随机生成参数的初始值。可以根据一定的分布(如均匀分布或正态分布)从一个较小的范

    2024年02月15日
    浏览(45)
  • java中初始化数组的方法

    方式一: 注:此种方式创建的数组,如不显式初始化数组元素,则各元素为当前数据类型的默认值。基本数据类型为0,对象类型为null。所以使用前需要将各元素显式赋值。 方式二: 注:此方式与方式一的结果相同,但是更简便。 方式三: 注:此方式与方式一和方式二的结

    2024年02月12日
    浏览(45)
  • NumPy(1)-常用的初始化方法

    NumPy是Python中科学计算的基础包,它是一个Python库,提供多维数组对象,各种派生对象(如掩码数组和矩阵),以及用于数组快速操作的各种API,有包括数学、逻辑、形状操作、排序、选择、输入输出、离散傅立叶变换、基本线性代数,基本统计运算和随机模拟等等。 功能强

    2024年02月16日
    浏览(40)
  • STM32的GPIO初始化配置-学习笔记

            由于刚开始没有学懂GPIO的配置原理,导致后面学习其它外设的时候总是产生阻碍,因为其它外设要使用前,大部分都要配置GPIO的初始化,因此这几天重新学习了一遍GPIO的配置,记录如下。         首先我们要知道芯片上的引脚,并不是只有GPIO的功能,还能复用成

    2024年04月17日
    浏览(56)
  • Java开源项目mall学习笔记(1)——项目初始化

            该笔记是记录学习开源项目mall过程的文档笔记,完全原创,转载请声明。同时也对开源项目的作者表示感谢! mall: 🔥 mall项目是一套基于 SpringBoot + Vue + uni-app 实现的电商系统,包括前台商城项目及后台管理系统,采用Docker容器化部署。前台商城系统包含首页门户

    2024年02月12日
    浏览(45)
  • STM32 GPIO设置(GPIO初始化)学习笔记

    GPIO 都知道是 通用输入输出接口 的意思就不详细解释 那么我们就直接进入怎么设置GPIO接口: 这里我的编译软件是keil5,相信大家都应该知道stm32有各种的工作模式上拉、下拉、推挽、开漏等等。如果想要了解具体的工作模式原理这里我推荐大家看:推挽 开漏 高阻 这都是谁

    2024年03月28日
    浏览(59)
  • 初始化交换机的密码的方法介绍

    1、断开交换机的电源并重新给交换机加电,在给交换机加电的同时按住交换机前面板上的“模式(Mode)”按钮几秒钟,仔细观察超级终端程序中显示的交换机启动信息。 2、待出现交换机提示符switch:后,输入flash_init命令。 3、待上述命令执行完成后,输入load_helper命令。 4、待

    2024年02月05日
    浏览(44)
  • 【Java】构造方法及类的初始化

    活动地址:CSDN21天学习挑战赛 ✨ 博客主页: XIN-XIANG荣 ✨ 系列专栏: 【Java SE】 ✨ 一句短话: 难在坚持,贵在坚持,成在坚持! 构造方法(也称为构造器)是一个特殊的成员方法,其名字必须与类名相同,在创建对象时,由编译器自动调用,并且在整个对象的生命周期内只调用一次。

    2023年04月10日
    浏览(42)
  • c++初始化vector的几种方法

    在C++中,vector是一种动态数组,可以在运行时自由添加、删除元素。初始化vector是创建一个vector对象并为其分配内存空间的过程。以下是C++中初始化vector的几种方法: 默认构造函数 使用默认构造函数创建一个空的vector,如下所示: std::vectorint vec; // 创建空vector 这种方式可用

    2024年02月16日
    浏览(43)
  • 《C和指针》笔记22: 指针初始化和NULL指针

    下面的代码显示了一个常见的错误: a指向哪里呢?我们声明了这个变量,但从未对它进行初始化,所以我们没有办法预测。12这个值将存储于什么地方。从这一点看,指针变量和其他变量并无区别。如果变量是静态的,它会被初始化为0;但如果变量是自动的,它根本不会被

    2024年02月09日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包