zoukankan      html  css  js  c++  java
  • jsp内置对象分析

    1.html表单的提交方式比较:

      1.1.get方式:将表单内容经过编码之后 ,通过URL发送, 使用get方式发送时有255个字符的限制。

      1.2.post方式:将表单的内容通过http发送,post没有字符长度的限制 。

    2.jsp内置对象:JSP 内置对象是 Web 容器创建的一组对象 ,是可以直接在JSP页面使用的对象 ,无需使用“new”获取实例。

    3.分类:共分为9类:

      3.1.out对象:out对象用于向客户端输出数据

        3.1.1.主要方法:print(),eg:<% out.print(" hello 51px" ); %>

      3.2.page对象:page 对象代表JSP本身,只有在JSP页面内才是合法的。 page隐含对象本质上包含当前 Servlet接口引用的变量,类似于Java编程中的 this 指针。

      3.3.request对象:request对象主要用于处理客户端请求

        3.3.1.常用方法:

          a.String getParameter(String name):根据页面表单组件名称获取页面提交数据

          b.String[ ] getParameterValues (String name):获取一个页面表单组件对应多个值时的用户的请求数据

          c.void setCharacterEncoding (String charset):指定每个请求的编码 在调用request.getParameter()之前进行设定,可以解决中文乱码问题

          d.request.getRequestDispatcher(String path):返回一个javax.servlet.RequestDispatcher对象,该对象的forward方法用于转发请求

      3.4.response对象:response对象用于响应客户请求并向客户端输出信息

          3.4.1.主要方法:void sendRedirect (String location):将请求重新定位到一个不同的URL

      3.5.session对象:一个会话就是浏览器与服务器之间的一次通话,它包含浏览器与服务器之间的多次请求、响应过程。会话是同一连接者所有网页共用的内置对象, JSP中使用session表示会话,Session对于连接者来说是私有的。

        3.5.1.主要方法:

          a.void setAttribute(String key, Object value):以键/值的方式,将一个对象的值存放到session中

          b.Object getAttribute(String key):根据名称去获取session中存放对象的值

          c.int getMaxInactiveInterval():获取session的有效非活动时间,以秒为单位

          d.setMaxInactiveInterval(int ):设置session的有效非活动时间,以秒为单位

          e.String getId():获取session对象的编号

          f.void invalidate():设置session对象失效

          g.void removeAttribute(String key):移除指定的session对象

      3.6.application对象:application是所有连接者所有网页共用的对象,类似于系统的“全局变量”,用于实现用户之间的数据共享

        3.6.1.常用方法:

          a.void setAttribute(String key, Object value):以键/值的方式,将一个对象的值存放到application中

          b.Object getAttribute(String key):根据键去获取application中存放对象的值

          c.String getRealPath(String path):返回相对路径的真实路径

        3.6.2.application对象实现服务内数据的共享, 在服务内值存在一个对象实例

        3.6.3.与session的区别:Application是所有连接者所有页面共用的对象; Session是同一连接者所有页面共用的对象

      3.7.exception对象:exception 对象的作用是显示异常信息,只有在包含 isErrorPage="true" 的页面中才可以被使用,在一般的JSP页面中使用该对象将无法编译JSP文件。excepation对象和Java的所有对象一样,都具有系统提供的继承结构。exception 对象几乎定义了所有异常情况。在Java程序中,可以使用try/catch关键字来处理异常情况; 如果在JSP页面中出现没有捕获到的异常,就会生成 exception 对象,并把 exception 对象传送到在page指令中设定的错误页面中,然后在错误页面中处理相应的 exception 对象。

      3.8.config对象:config 对象的主要作用是取得服务器的配置信息。通过 pageConext对象的 getServletConfig() 方法可以获取一个config对象。当一个Servlet 初始化时,容器把某些信息通过 config对象传递给这个 Servlet。 开发者可以在web.xml 文件中为应用程序环境中的Servlet程序和JSP页面提供初始化参数。

      3.9.pagecontext对象:pageContext 对象的作用是取得任何范围的参数,通过它可以获取 JSP页面的out、request、reponse、session、application 等对象。pageContext对象的创建和初始化都是由容器来完成的,在JSP页面中可以直接使用 pageContext对象。

    4.关于重定向和请求转发的对比:请求转发与重定向都能实现将页面从一个界面转到了另外一个界面,它们的区别如下:

      4.1. 重定向 response.sendRedirect("welcome.jsp"); 地址栏发生变化,请求没有被转发,新的请求开始了,原来的请求结束了。

      4.2. 请求转发 request.getRequestDispatcher("error.jsp“).forward(request,response); 地址栏不发生变化,请求被转发,请求没有结束,与前一个页面时同一个请求

    5.include指令:可以将一些共性的内容写入一个单独的文件中,然后通过include指令引用该文件,从而降低代码的冗余问题,也便于修改共性内容

    6.cookie对象:Cookie是Web服务器保存在客户端的一系列文本信息。

      6.1.Cookie的作用 a.对特定对象的追踪 b.统计网页浏览次数 c.简化登录

      6.2.安全性能: 容易信息泄露

      6.3.cookie 的创建:Cookie newCookie=new Cookie("parameter", "value");

        说明: a.parameter:用于代表cookie的名称(key)          b.value:用于表示当前key名称所对应的值

        使用:a.写入cookie:response.addCookie(newCookie)   b.读取cookie:Cookie [] cookies = request.getCookies();

      6.4.主要方法:

        a.void setMaxAge(int expiry):设置Cookie的有效期,以秒为单位

        b.void setValue(String value):在Cookie创建后,对Cookie进行赋值

        c.String getName():获取Cookie的名称

        d.String getValue():获取Cookie的值

        e.String getMaxAge():获取Cookie的有效时间,以秒为单位

      6.5.分类:

        6.5.1.临时cookie:不设置setMaxAge的cookie是临时cookie 保存在客户端内存中,浏览器关闭后就销毁了

        6.5.2. 永久cookie 设置了setMaxAge的cookie是永久cookie 保存在客户端文件中,到了setMaxAge设置的时间后销毁 销毁永久cookie,的方法setMaxAge(0)

      6.6.注意事项:

        a.向Cookie存储中文时必须进行编码 eg.String cookievalue = java.net.URLEncoder.encode(username,”utf-8”);

        b.从cookie中读取cookie时要进行解码 String cookievalue = java.net.URLDecoder.decode(username,”utf-8”)

    7.cookie 和 session 的比较

      a.session是在服务器端保存用户信息,Cookie是在客户端保存用户信息

      b. session中保存的是对象,Cookie保存的是字符串

      c.session随会话结束而关闭,Cookie可以长期保存在客户端

      d.Cookie通常用于保存不重要的用户信息,重要的信息使用session保存

    8.jsp的动作标签:

      8.1.请求转发:为了使界面中尽量不出现java代码,请求转发和重定向可以使用jsp的动作标签来实现

    <jsp:forward page="index.jsp"> <jsp:param value="12" name="id"/> </jsp:forward>

      8.2.动态包含:

    (静态包含 将一个jsp文件含入到另外一个jsp文件中可以通过 <%@ include file=“index.jsp” %>实现,这种含入称为静态含入,相当于将index.jsp文件中的源代码拷贝到当前jsp页面中,因此在含入和被含入的jsp文件中不能有相同的变量名。)

    动态包含 使用动作标签<jsp:include page=“index.jsp”></jsp:include>也可以将一个jsp文件含入到另外一个jsp文件中,但动作标签含入时,是将被含入的文件运行的结果(html)含入到当前jsp页面中。因此被含入文件与当前文件中有相同变量名时并不影响。

  • 相关阅读:
    HTML-标题
    HTML-属性
    HTML-元素
    前端 vue Request Payload VS Form Data
    JWT,Session、Cookie(httpOnly,secure) 登录认证
    js 定位当前城市(ip,省份,城市,邮编)接口定位(搜狐、新浪、百度、腾讯API)
    sqlsugar 使用汇总
    asp.net 跨域
    asp.net core程序发布(Webapi,web网站)
    .net 多线程发展1.0--4.0
  • 原文地址:https://www.cnblogs.com/g177w/p/8546975.html
Copyright © 2011-2022 走看看