zoukankan      html  css  js  c++  java
  • Servlet小结(面试)

    1.doGet()和doPost()区别/get和post请求方法区别:

      (1)在form表单中:method  = “get/post”相对应doGet和doPost方法。

      (2)在http协议中:相对应http的GET和POST请求方法(http的请求方法有:GET,POST,PUT,HEAD,DELETE,OPTIONS,TRACE,CONNECT,PATCH)

      (3)get方法提交数据有大小的限制为1024字节左右,但是post方法没有数据大小的显示。

      (4)使用get方法会将form表单提交的数据存放在url中(以key-value形式),用户看得见;

    ,     但post方法将数据存放在http协议的请求体中,用户看不见。

          因此get方式的安全性差,post方法的安全性更高。

      (5)服务器获取数据:get方法中采用request.QueryString获取;post方法request.Form获取

                  服务器随机接受get方法的数据,而post方法服务器先接受数据信息的长度,再接受数据。

      (6)在数据查询的时候,建议使用get方式,而数据添加,修改,删除时,建议使用post方式。

    2.servlet的生命周期:

      

      声明:servlet接口只有上图这些方法,而doGet和doPost方法在类HttpServlet中,在eclipse中创建一个servlet类,这个类就继承了HttpServlet类。

      web容器加载servlet,生命周期开始。通过调用servlet的init()方法进行servlet初始化。通过调用service()方法实现(客户端发送的请求都是交给service方法),

      根据请求的不同调用不同的do**()方法。结束service()方法后,web容器调用destroy()方法,销毁。

    3.Cookie和Session:

       http是一种无状态的协议,客户端和服务器端建立连接并传输数据,数据传输完成后,连接断开,当再次需要交互数据时,需要建立新的连接,

       因此,服务器无法从连接上跟踪会话也不知道用户上次做了什么。

      (1)Cookie的原理:

        Cookie是解决http无状态协议的有效方式(本质),服务器可以设置或读取cookie所包含的信息。

        Cookie是通过set-cookie响应头和cookie请求头将会话中产生的数据保存在客户端的技术。

        客户端发送请求给服务器端,服务器端将获取到的数据通过set-cookie响应头发送给浏览器,浏览器将cookie以文件的形式保存在浏览器内部,

        当客户端再次发送请求的时候,服务器可以通过cookie请求头获取上次发送给浏览器的cookie心意,通过这种方式保存会话中产生的数据。

      (2)session原理:

        session也是解决http协议无状态(不能维持现状)的问题。

        session产生于服务器端,以对象的形式保存在服务器端。服务器端每产生一个新的session对象都会分配一个唯一的id,

        并且这个id值将以cookie的形式保存在客户端,cookie的键就是jsessionid,将cookie值放在浏览器,当客户端再次发送请求的时候,

        将携带cookie信息到浏览器,服务器通过该cookie就可以根据jsessionid的值得知当前会话保存的session。

        关闭浏览器,便获取不到上次保存的session,并不是因为session被销毁了(session销毁的原因是因为在一定的时间内没有被操作,才会被销毁),

        而是因为丢失了sessionid(sessionid默认在浏览器关闭的时候销毁)。

      (3)session和cookie的区别:

        a.cookie数据存放在客户端,session存放在服务器端

          cookie不安全(别人可以分析存放在本地的cookie进行cookie欺骗)

          session在一定时间内保存在服务器上,当访问增多是,比较占用服务器的性能

        b.用户可以设置cookie功能禁用,但是session不能。

        c.cookie只能设置存储文本类型,session中能存取object值。

        d.cookie有大小限制以及浏览器存放的cookie个数也有限制(各个浏览器的限制是不一样的),而session没有大小限制。

       (4)相同点(理解):

        a.都是在服务器端产生。

        b.都是解决http协议无状态问题。

        c.都是key-value形式保存。

        d.都是跟踪会话。

    以上三个问题都被面试管问过,尤其是第三个,被问多次。

    4.jsp和servlet的区别: 

      jsp是servlet技术的扩展,本质上是servlet的简易方式,更强调外观上的表达。

      主要的不同点在于,servlet的应用逻辑在java文件中,并且完全从表示层中的html里分离出来。jsp是java和HTML组合而成。

      jsp注重视图,servlet注重控制逻辑。

     

  • 相关阅读:
    21-while里的break简单用法
    20-使用while循环求从1累加至100的值
    19-random猜数
    18-random猜数,直到正确。
    17-简化后的石头剪刀布
    16-if实现石头剪刀布
    生成随机数
    转换数字的进制(Integer、Long)
    数字的舍入
    格式化数字
  • 原文地址:https://www.cnblogs.com/spring-effort/p/11552125.html
Copyright © 2011-2022 走看看