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); } }
作者:程序员小波与Bug
出处:https://codetrips.cn
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。如有问题,可以邮件:caiya928@aliyun.com
QQ:1419901425 联系我
如果喜欢我的文章,请关注我的公众号:程序员小波与Bug