• Java面试题复习笔记(Web方向)


    1.Http中get和post请求的区别?

    共同点:都是Http请求方式,用户可以通过不同的请求方式完成对资源(Url)的操作。具体来讲就是get一般用于获取/查询资源信息,post用于更新资源信息。

    增,删,改,查——put、delete、post、get

    区别:

      (1)get请求的数据会在地址栏显示出来,而post不会。

      原因:get提交,请求的数据会附在Url之后,以?分割Url和数据,多个参数之间用&连接;post提交的数据放在Http包的包体中。

      (2)传输数据大小不同。

      原因:浏览器对地址长度是有限制的,get请求的数据因此受限。

      (3)安全性,post安全性高于get。

      原因:get请求的数据会显示在地址栏中,可以通过历史纪录找到密码等重要信息。

    2.Servlet是什么?说一下对它的理解?

    Servlet(Server Applet)是用Java编写的服务器端程序;主要功能是交互式的浏览和修改数据,生成动态Web内容;Servlet运行于支持Java的应用服务器中;实际在编写过程中,继承HttpServlet,重写doGet和doPost方法或者重写Service方法完成对get和post请求的响应

    3.Servlet的生命周期?

    Servlet有良好的生存期定义,包括加载,实例化,初始化,处理请求和服务结束。这个生存期由Java.servlet.Servlet接口的init,service和destroy方法表达。

    加载Servlet的class-------->实例化Servlet-------->调用Servlet的init完成初始化-------->响应请求(Servlet的service方法)-------->服务结束,服务器Servlet容器关闭(Servlet的destroy方法)

    流程详解:Servlet启动时,开始加载Servlet生命周期。Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost等),当服务器决定将实例销毁时调用其destroy方法。

    4.Sevlet API中forward()于redirect()的区别?

    forward仅是服务器容器中控制权的转向,在客户端浏览器地址栏中不会显示转向后的地址;redirect则是完全的跳转,浏览器()客户端将会得到跳转的地址并重新发起请求链接。forward还是原来的请求,而redirect是重新发起请求,前者更高效,在前者满足其需求的前提下尽可能使用forward,并且这样也有助于隐藏实际的链接。有些情况下必须使用SendRedirect方法,比如需要跳转到另一个服务器上的资源。

    总结:

      (1)forwaord是服务器端的转向,而redirect是客户端的跳转。

      (2)使用forward浏览器的地址不会发生改变,而使用redirect会改变。

      (3)forward是再一次请求中完成,而redirect是发起新的请求。

      (4)forward是在服务器短完成的,不需要客户端重新发起请求,效率更高。

    5.JSP与Servlet由哪些相同点和不同点,他们之间的联系是什么?

    相同点:Jsp是Servlet技术的扩展,Jsp的所有文件最后都会被翻译为一个继承HttpServlet的类,所以Jsp最终也是一个servlet,但是这个servlet是对外提供服务的。

    不同点:

       (1)Jsp侧重于视图,而servlet主要用于控制逻辑。

       (2)Servlet如果要实现html的功能必须使用Writer输出html文件,比较麻烦,而Jsp可以把Java 和html结合成一个后缀名为.jsp的文件使页面展示比较方便,到那时嵌入逻辑比较复杂。

    6.Jsp与纳西额内置对象?作用分别是什么?分别有哪些方法?

    9个内置对象:

       (1)request——用户端请求,此请求会包含来自get/post请求的参数

       (2)response——网页传回用户端的回应

       (3)pageContext——网页的属性是在这里管理的。

       (4)session——与请求有关的会话期

       (5)application——servlet正在执行的内容

       (6)out——用来传送回应的输出

       (7)config——servlet的构架部件

       (8)page——Jsp网页本身

       (9)sxception——针对错误网页,未捕捉的例外

    四大作用域:request、pageContext、session、application可以通过jstl用四大作用域中取值

    Jsp传递值:request、session、application、cookie

    7.session和cookie的区别?你在项目中哪些地方使用了?

    相同点:都是会话跟踪技术,cookie通过在客户端记录信息确定用户身份,session通过在服务器记录信息确定用户身份。但是sessiong的实现依赖于cookie、sessionID(sessiong的唯一标识,需要存放在客户端)

    区别:

      (1)cookie数据存放在客户浏览器上,而session存放在服务器上

      (2)cookie不是很安全,别人可以通过分析存放在本地的cookie进行cookie欺骗,考虑到安全性问题应该使用session

      (3)session会一定时间保存在服务器上,当访问增多时会比较占用服务器性能,看绿岛减轻服务器性能压力应该使用cookie

      (4)单个cookie保存的数据不能超过4k,很多浏览器都限制一个站点最多保存20个cookie

    个人建议:将登陆信息等重要信息存放在session中,无关紧要的信息可以存放在cookie中(比如购物车)

    扩展:购物车最好使用cookie,到那时cookie是可以在浏览器禁用的,这时候需要使用cookie+数据库的方式实现,当不能呢从cookie中取数据的时候就从数据库取。

    8.MVC各个部分都由哪些技术实现?

    M(Model模型)——javabean;V(View视图)——html、Jsp;C(Control控制器)——Servlet、Action

    最经典(简单)的MVC模式:Jsp+Servlet+javabean

    实际上就是Model2的实现方式,把逻辑和视图隔离。

    Model1:Jsp+service+dao

    Model2:Jsp+servlet+service+dao

    使用structs2和spring后:Jsp+核心控制器+action+javabean

  • 相关阅读:
    css 笔记
    解决谷歌浏览器中的input背景色默认是黄色
    lunbo
    操作json进行分组再组
    点击返回顶部
    关于有的手机浏览器下载APK时会成TXT
    火狐浏览器jsonshow插件
    微信web开发者工具
    浏览器UA
    click多次注册事件会导致一个事件被触发多次的解决方法
  • 原文地址:https://www.cnblogs.com/edward-life/p/10556919.html
Copyright © 2020-2023  润新知