WEB方面面试题详解

  1. WEB 应用中如果有.class 和.jar 类型的文件一般分别应该放

    在什么位置?

    答:

    .class 文件放在 WEB-INF/classes 文件下,.jar 文件放在 WEB-INF/lib

    文件夹下

  2. 元素中有一个输入框(<input type=”text” name=”

    username”id=”username”value=””/>,请用 JavaScript

    语言写一行代码,取得这个输入框中的值。

    答:

    document.getElementById(“username”).value;

  3. 简单描述一下 Servlet 与 JSP 的的相同点和区别点。

    区别:

    JSP 是在 HTML 代码里写 JAVA 代码,框架是 HTML;而 Servlet 是在 JAVA 代

    码中写 HTML 代码,本身是个 JAVA 类。

    JSP 使人们把显示和逻辑分隔成为可能,这意味着两者的开发可并行进行;

    而 Servlet 并没有把两者分开。

    Servlet 独立地处理静态表示逻辑与动态业务逻辑.这样,任何文件的变动都

    需要对此服务程序重新编译;JSP 允许用特殊标签直接嵌入到 HTML 页面,

    HTML内容与JAVA内容也可放在单独文件中,HTML内容的任何变动会自动

    编译装入到服务程序.

    Servlet 需要在 web.xml 中配置,而 JSP 无需配置。

    目前 JSP 主要用在视图层,负责显示,而 Servlet 主要用在控制层,负责调

    联系:

    都是 Sun 公司推出的动态网页技术。

    先有 Servlet,针对 Servlet 缺点推出 JSP。JSP 是 Servlet 的一种特殊形式,

    每个 JSP 页面就是一个 Servlet 实例——JSP 页面由系统翻译成 Servlet,

    Servlet 再负责响应用户请求。

  4. 请简单描述下几个您熟悉 JavaScript 库,它们有哪些作用和

    特点?

    JavaScript 高级程序设计(特别是对浏览器差异的复杂处理),通常很困难

    也很耗时。为了应对这些调整,许多的 JavaScript 库应运而生。这些

    JavaScript 库常被称为 JavaScript 框架。

    jQuery:

    Ext JS - 可定制的 widget,用于构建富因特网应用程序(rich Internet

    applications)。

    Prototype

    MooTools。

    YUI - Yahoo! User Interface Framework,涵盖大量函数的大型库,从简

    单的 JavaScript 功能到完整的 internet widget。

  5. 简单描述 HTML,CSS,Javascript 在 Web 开发中分别起

    什么作用?

    1、什么是 HTML(超文本标记语言 Hyper Text Markup Language),

    HTML 是用来描述网页的一种语言。

    2、CSS(层叠样式表 Cascading Style Sheets),样式定义如何显示 HTML

    元素,语法为:selector {property:value} (选择符 {属性:值})

    3、JavaScript 是一种脚本语言,其源代码在发往客户端运行之前不需经过

    编译,而是将文本格式的字符代码发送给浏览器由浏览器解释运行

    对于一个网页,HTML 定义网页的结构,CSS 描述网页的样子,JavaScript

    设置一个很经典的例子是说 HTML 就像 一个人的骨骼、器官,而 CSS 就是

    人的皮肤,有了这两样也就构成了一个植物人了,加上 javascript 这个植物

    人就可以对外界刺激做出反应,可以思 考、运动、可以给自己整容化妆(改

    变 CSS)等等,成为一个活生生的人。

    如果说 HTML 是肉身、CSS 就是皮相、Javascript 就是灵魂。没有

    Javascript,HTML+CSS 是植物人,没有 Javascript、CSS 是个毁容的植物

    人。

    如果说 HTML 是建筑师,CSS 就是干装修的,Javascript 是魔术师。

  6. 当 DOM 加载完成后要执行的函数,下面哪个是正确的()

    A JQuery(expression, [context])

    B. JQuery(html, [ownerDocument])

    C. JQuery(callback)

    答案:C

  7. 举例说明 JAVA 中如何解析 xml,不同方式有和优缺点?

    答:

  8. DOM(Document Object Model)

    DOM是用与平台和语言无关的方式表示XML 文档的官方W3C标准。DOM

    是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在

    树中寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然

    后才能做任何工作。由于它是基于信息层次的,因而 DOM 被认为是基于树

    或基于对象的。

    【优点】

    ①允许应用程序对数据和结构做出更改。

    ②访问是双向的,可以在任何时候在树中上下导航,获取和操作任意部分的

    数据。

    【缺点】

    ①通常需要加载整个 XML 文档来构造层次结构,消耗资源大。

  9. SAX(Simple API for XML)

    SAX 处理的优点非常类似于流媒体的优点。分析能够立即开始,而不是等待

    所有的数据被处理。而且,由于应用程序只是在读取数据时检查数据,因此

    不需要将数据存储在内存中。这对于大型文档来说是个巨大的优点。事实上,

    应用程序甚至不必解析整个文档;它可以在某个条件得到满足时停止解析。

    一般来说,SAX 还比它的替代者 DOM 快许多。

    选择 DOM 还是选择 SAX? 对于需要自己编写代码来处理 XML 文档的开

    发人员来说, 选择 DOM 还是 SAX 解析模型是一个非常重要的设计决策。

    DOM采用建立树形结构的方式访问XML文档,而SAX采用的是事件模型。

    DOM 解析器把 XML 文档转化为一个包含其内容的树,并可以对树进行遍

    历。用DOM解析模型的优点是编程容易,开发人员只需要调用建树的指令,

    然后利用 navigation APIs 访问所需的树节点来完成任务。可以很容易的添

    加和修改树中的元素。然而由于使用 DOM 解析器的时候需要处理整个 XML

    文档,所以对性能和内存的要求比较高,尤其是遇到很大的 XML 文件的时

    候。由于它的遍历能力,DOM 解析器常用于 XML 文档需要频繁的改变的

    服务中。

    SAX 解析器采用了基于事件的模型,它在解析 XML 文档的时候可以触发一

    系列的事件,当发现给定的 tag 的时候,它可以激活一个回调方法,告诉该

    方法制定的标签已经找到。SAX 对内存的要求通常会比较低,因为它让开发

    人员自己来决定所要处理的 tag.特别是当开发人员只需要处理文档中所包

    含的部分数据时,SAX 这种扩展能力得到了更好的体现。但用 SAX 解析器

    的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数

    据。

    【优势】

    ①不需要等待所有数据都被处理,分析就能立即开始。

    ②只在读取数据时检查数据,不需要保存在内存中。

    ③可以在某个条件得到满足时停止解析,不必解析整个文档。

    ④效率和性能较高,能解析大于系统内存的文档。

    【缺点】

    ①需要应用程序自己负责 TAG 的处理逻辑(例如维护父/子关系等),文档

    越复杂程序就越复杂。

    ②单向导航,无法定位文档层次,很难同时访问同一文档的不同部分数据,

    不支持 XPath。

  10. JDOM(Java-based Document Object Model)

    JDOM 的目的是成为 Java 特定文档模型,它简化与 XML 的交互并且比使用

    DOM 实现更快。由于是第一个 Java 特定模型,JDOM 一直得到大力推广

    和促进。正在考虑通过“Java 规范请求 JSR-102”将它最终用作“Java 标

    准扩展”。从 2000 年初就已经开始了 JDOM 开发。

    JDOM 与 DOM 主要有两方面不同。首先,JDOM 仅使用具体类而不使用

    接口。这在某些方面简化了 API,但是也限制了灵活性。第二,API 大量使

    用了 Collections 类,简化了那些已经熟悉这些类的 Java 开发者的使用。

    JDOM 文档声明其目的是“使用 20%(或更少)的精力解决 80%(或更多)

    Java/XML 问题”(根据学习曲线假定为 20%)。JDOM 对于大多数 Java/XML

    应用程序来说当然是有用的,并且大多数开发者发现 API 比 DOM 容易理解

    得多。JDOM 还包括对程序行为的相当广泛检查以防止用户做任何在 XML

    中无意义的事。然而,它仍需要您充分理解 XML 以便做一些超出基本的工

    作(或者甚至理解某些情况下的错误)。这也许是比学习 DOM 或 JDOM 接

    口都更有意义的工作。

    JDOM 自身不包含解析器。它通常使用 SAX2 解析器来解析和验证输入 XML

    文档(尽管它还可以将以前构造的 DOM 表示作为输入)。它包含一些转换

    器以将 JDOM 表示输出成 SAX2 事件流、DOM 模型或 XML 文本文档。

    JDOM 是在 Apache 许可证变体下发布的开放源码。

    【优点】

    ①使用具体类而不是接口,简化了 DOM 的 API。

    ②大量使用了 Java 集合类,方便了 Java 开发人员。

    【缺点】

    ①没有较好的灵活性。

    ②性能较差。

  11. DOM4J(Document Object Model for Java)

    虽然 DOM4J 代表了完全独立的开发结果,但最初,它是 JDOM 的一种智

    能分支。它合并了许多超出基本 XML 文档表示的功能,包括集成的 XPath

    支持、XML Schema 支持以及用于大文档或流化文档的基于事件的处理。

    它还提供了构建文档表示的选项,它通过 DOM4J API 和标准 DOM 接口具

    有并行访问功能。从 2000 下半年开始,它就一直处于开发之中。

    为支持所有这些功能,DOM4J 使用接口和抽象基本类方法。DOM4J 大量

    使用了 API 中的 Collections 类,但是在许多情况下,它还提供一些替代方

    法以允许更好的性能或更直接的编码方法。直接好处是,虽然 DOM4J 付出

    了更复杂的 API 的代价,但是它提供了比 JDOM 大得多的灵活性。

    在添加灵活性、XPath 集成和对大文档处理的目标时,DOM4J 的目标与

    JDOM 是一样的:针对 Java 开发者的易用性和直观操作。它还致力于成为

    比 JDOM 更完整的解决方案,实现在本质上处理所有 Java/XML 问题的目

    标。在完成该目标时,它比 JDOM 更少强调防止不正确的应用程序行为。

    DOM4J 是一个非常非常优秀的 Java XML API,具有性能优异、功能强大

    和极端易用使用的特点,同时它也是一个开放源代码的软件。如今你可以看

    到越来越多的 Java 软件都在使用 DOM4J 来读写 XML,特别值得一提的是

    连 Sun 的 JAXM 也在用 DOM4J.

    【优点】

    ①大量使用了 Java 集合类,方便 Java 开发人员,同时提供一些提高性能的

    替代方法。

    ②支持 XPath。

    ③有很好的性能。

    【缺点】

    ①大量使用了接口,API 较为复杂。

    二、比较

  12. DOM4J 性能最好,连 Sun 的 JAXM 也在用 DOM4J。目前许多开源项目

    中大量采用 DOM4J,例如大名鼎鼎的 Hibernate 也用 DOM4J 来读取 XML

    配置文件。如果不考虑可移植性,那就采用 DOM4J.

  13. JDOM 和 DOM 在性能测试时表现不佳,在测试 10M 文档时内存溢出,

    但可移植。在小文档情况下还值得考虑使用 DOM 和 JDOM.虽然 JDOM 的

    开发者已经说明他们期望在正式发行版前专注性能问题,但是从性能观点来

    看,它确实没有值得推荐之处。另外,DOM 仍是一个非常好的选择。DOM

    实现广泛应用于多种编程语言。它还是许多其它与 XML 相关的标准的基础,

    因为它正式获得 W3C 推荐(与基于非标准的 Java 模型相对),所以在某些

    类型的项目中可能也需要它(如在 JavaScript 中使用 DOM)。

  14. SAX 表现较好,这要依赖于它特定的解析方式-事件驱动。一个 SAX 检

    测即将到来的 XML 流,但并没有载入到内存(当然当 XML 流被读入时,会

    有部分文档暂时隐藏在内存中)。

    我的看法:如果 XML 文档较大且不考虑移植性问题建议采用 DOM4J;如

    果 XML 文档较小则建议采用 JDOM;如果需要及时处理而不需要保存数据

    则考虑 SAX。但无论如何,还是那句话:适合自己的才是最好的,如果时间

    允许,建议大家讲这四种方法都尝试一遍然后选择一种适合自己的即可。

  15. char 型变量中能不能存储一个中文汉字?

    答:

    1.java 采用 unicode 编码,2 个字节(16 位)来表示一个字符, 无论是汉

    字还是数字,字母,或其他语言都可以存储。

    2.char 在 java 中是 2 个字节,所以可以存储中文

  16. 一个类可以实现多个接口,但只能继承一个抽象类。

    下面接着再说说两者在应用上的区别:

    接口更多的是在系统架构设计方法发挥作用,主要用于定义模块之间的通信

    契约。而抽象类在代码实现方面发挥作用,可以实现代码的重用,例如,模

    板方法设计模式是抽象类的一个典型应用,假设某个项目的所有 Servlet 类

    都要用相同的方式进行权限判断、记录访问日志和处理异常,那么就可以定

    义一个抽象的基类,让所有的 Servlet 都继承这个抽象基类,在抽象基类的

    service 方法中完成权限判断、记录访问日志和处理异常的代码,在各个子

    类中只是完成各自的业务逻辑代码,伪代码如下:

    public abstract classBaseServlet extends HttpServlet{

    public final void service(HttpServletRequest

    request,HttpServletResponse response) throws

    IOExcetion,ServletException {

    记录访问日志

    进行权限判断

    if(具有权限){

    try{

    doService(request,response);

    }

    catch(Excetpion e) {

    记录异常信息

    } }

    }

    protected abstract void doService(HttpServletRequest

    request,HttpServletResponse response) throws

    IOExcetion,ServletException;

    //注意访问权限定义成 protected,显得既专业,又严谨,因为它是专门给

    子类用的

    }

    public class MyServlet1 extendsBaseServlet

    {

    protected voiddoService(HttpServletRequest request,

    HttpServletResponse response) throwsIOExcetion,ServletException

    {

    本 Servlet 只处理的具体业务逻辑代码

    } }

    父类方法中间的某段代码不确定,留给子类干,就用模板方法设计模式。

    备注:这道题的思路是先从总体解释抽象类和接口的基本概念,然后再比较

    两者的语法细节,最后再说两者的应用区别。比较两者语法细节区别的条理

    是:先从一个类中的构造方法、普通成员变量和方法(包括抽象方法),静

    态变量和方法,继承性等 6 个方面逐一去比较回答,接着从第三者继承的角

    度的回答,特别是最后用了一个典型的例子来展现自己深厚的技术功底。

  17. 比较一下 Java 和 JavaSciprt

    答:JavaScript 与 Java 是两个公司开发的不同的两个产品。Java 是原 Sun

    公司推出的面向对象的程序设计语言,特别适合于互联网应用程序开发;而

    JavaScript 是 Netscape 公司的产品,为了扩展 Netscape 浏览器的功能而

    开发的一种可以嵌入 Web 页面中运行的基于对象和事件驱动的解释性语言,

    它的前身是 LiveScript;而 Java 的前身是 Oak 语言。

    下面对两种语言间的异同作如下比较:

    1)基于对象和面向对象:Java 是一种真正的面向对象的语言,即使是开发

    简单的程序,必须设计对象;JavaScript 是种脚本语言,它可以用来制作与

    网络无关的,与用户交互作用的复杂软件。它是一种基于对象

    (Object-Based)和事件驱动(Event-Driven)的编程语言。因而它本身

    提供了非常丰富的内部对象供设计人员使用;

    2)解释和编译:Java 的源代码在执行之前,必须经过编译;JavaScript 是

    一种解释性编程语言,其源代码不需经过编译,由浏览器解释执行;

    3)强类型变量和类型弱变量:Java 采用强类型变量检查,即所有变量在编

    译之前必须作声明;JavaScript 中变量声明,采用其弱类型。即变量在使用

    前不需作声明,而是解释器在运行时检查其数据类型;

    4)代码格式不一样。

    补充:上面列出的四点是原来所谓的标准答案中给出的。其实 Java 和

    JavaScript 最重要的区别是一个是静态语言,一个是动态语言。目前的编程

    语言的发展趋势是函数式语言和动态语言。在 Java 中类(class)是一等公

    民,而 JavaScript 中函数(function)是一等公民。对于这种问题,在面试

    时还是用自己的语言回答会更加靠谱。

  18. 什么时候用 assert?

    答:assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中

    都支持这种机制。一般来说,assertion 用于保证程序最基本、关键的正确

    性。assertion 检查通常在开发和测试时开启。为了提高性能,在软件发布

    后, assertion 检查通常是关闭的。在实现中,断言是一个包含布尔表达式

    的语句,在执行这个语句时假定该表达式为 true;如果表达式计算为 false,

    那么系统会报告一个 AssertionError。

    断言用于调试目的:

    assert(a > 0); // throws an AssertionError if a <= 0

    断言可以有两种形式:

    assert Expression1;

    assert Expression1 : Expression2 ;

    Expression1 应该总是产生一个布尔值。

    Expression2 可以是得出一个值的任意表达式;这个值用于生成显示更多调

    试信息的字符串消息。

    断言在默认情况下是禁用的,要在编译时启用断言,需使用 source 1.4 标

    记:

    javac -source 1.4 Test.java

    要在运行时启用断言,可使用-enableassertions 或者-ea 标记。

    要在运行时选择禁用断言,可使用-da 或者-disableassertions 标记。

    要在系统类中启用断言,可使用-esa 或者-dsa 标记。还可以在包的基础上

    启用或者禁用断言。可以在预计正常情况下不会到达的任何位置上放置断言。

    断言可以用于验证传递给私有方法的参数。不过,断言不应该用于验证传递

    给公有方法的参数,因为不管是否启用了断言,公有方法都必须检查其参数。

    不过,既可以在公有方法中,也可以在非公有方法中利用断言测试后置条件。

    另外,断言不应该以任何方式改变程序的状态。

  19. UML 是什么?UML 中有哪些图?

    答:UML 是统一建模语言(Unified Modeling Language)的缩写,它发

    表于 1997 年,综合了当时已经存在的面向对象的建模语言、方法和过程,

    是一个支持模型化和软件系统开发的图形化语言,为软件开发的所有阶段提

    供模型化和可视化支持。使用 UML 可以帮助沟通与交流,辅助应用设计和

    文档的生成,还能够阐释系统的结构和行为。UML 定义了多种图形化的符

    号来描述软件系统部分或全部的静态结构和动态结构,包括:用例图(use

    case diagram)、类图(class diagram)、时序图(sequence diagram)、

    协作图(collaboration diagram)、状态图(statechart diagram)、活动

    图(activity diagram)、构件图(component diagram)、部署图

    (deployment diagram)等。在这些图形化符号中,有三种图最为重要,

    分别是:用例图(用来捕获需求,描述系统的功能,通过该图可以迅速的了

    解系统的功能模块及其关系)、类图(描述类以及类与类之间的关系,通过

    该图可以快速了解系统)、时序图(描述执行特定任务时对象之间的交互关

    系以及执行顺序,通过该图可以了解对象能接收的消息也就是说对象能够向

    外界提供的服务)。

    用例图:

    类图:

    时序图:

  20. XML 文档定义有几种形式?它们之间有何本质区别?解析

    XML 文档有哪几种方式?

    答: XML 文档定义分为 DTD 和 Schema 两种形式;其本质区别在于

    Schema 本身也是一个 XML 文件,可以被 XML 解析器解析。对 XML 的解

    析主要有 DOM(文档对象模型)、SAX、StAX(JDK 1.6 中引入的新的解析

    XML 的方式,Streaming API for XML) 等,其中 DOM 处理大型文件时

    其性能下降的非常厉害,这个问题是由 DOM 的树结构所造成的,这种结构

    占用的内存较多,而且 DOM 必须在解析文件之前把整个文档装入内存,适

    合对 XML 的随机访问(典型的用空间换取时间的策略);SAX 是事件驱动

    型的 XML 解析方式,它顺序读取 XML 文件, 不需要一次全部装载整个文

    件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发

    一个事件,用户通过在其回调事件中写入处理代码来处理 XML 文件,适合

    对 XML 的顺序访问;如其名称所暗示的那样,StAX 把重点放在流上。实

    际上,StAX 与其他方法的区别就在于应用程序能够把 XML 作为一个事件流

    来处理。将 XML 作为一组事件来处理的想法并不新颖(事实上 SAX 已经

    提出来了),但不同之处在于 StAX 允许应用程序代码把这些事件逐个拉出来,

    而不用提供在解析器方便时从解析器中接收事件的处理程序。

  21. 你在项目中哪些地方用到了 XML? 答: XML 的主要作用有两个方面:数据交换(曾经被称为业界数据交换的

    事实标准,现在此项功能在很多时候都被 JSON 取代)和信息配置。在做数

    据交换时,XML 将数据用标签组装成起来,然后压缩打包加密后通过网络

    传送给接收者,接收解密与解压缩后再从 XML 文件中还原相关信息进行处

    理。目前很多软件都使用 XML 来存储配置信息,很多项目中我们通常也会

    将作为配置的硬代码(hard code)写在 XML 文件中,Java 的很多框架也

    是这么做的。

  22. 用 JavaScript 实现用正则表达式验证,某个字符串是合法的

    6 位数字的邮编的函数

    Function testE(ss){

    var reg=/[1][0-9]{5}$/;

    if(req.test(ss)){

    alert(“邮编 OK”)

    }else{

    alert(“邮编格式不正确”); } }

  23. 请使用 JQuery 将页面上的所有元素边框设置为 2pix 宽的虚

    线?

    $(“*”).css(“border”,”2px dashed”)

  24. 如何设定 JQuery 异步调用还是同步调用?

    答案:

    调用 jQuery 中的 ajax 函数,设置其 async 属性来表明是异步还是同步,

    如下:

    $.ajax({

    async:true//表示异步,false 表示同步

    })

  25. 说出 3 条以上 firefox 和 IE 的浏览器兼容问题?

    答案:

    兼容 firefox 的 outerHTML,FF 中没有 outerHtml 的方法

    IE 下,可以使用()或[]获取集合类对象;Firefox 下,只能使用[]获取集合类对象.

    解决方法:统一使用[]获取集合类对象.

    IE 下,可以使用获取常规属性的方法来获取自定义属性,也可以使用

    getAttribute()获取自定义属性;Firefox 下,只能使用 getAttribute()获取自

    定义属性.解决方法:统一通过 getAttribute()获取自定义属性

  26. 请用 Jquery 语言写出 ajax 请求或者 post 请求代码

    $.post(“show”,{uname=”张三”,pwd=”123”},function(data){

    alert(data)

    })

  27. body中的onload()函数和jQuery中document.ready()

    有什么区别?

    答案:

    ready 事件的触发,表示文档结构已经加载完成(不包含图片等非文字媒体

    文件)

    onload 事件的触发,表示页面包含图片等文件在内的所有元素都加载完成。

  28. jQuery 中有哪几种类型的选择器?

    答案:

    基本选择器

    层次选择器

    基本过滤选择器

    内容过滤选择器

    可见性过滤选择器

    属性过滤选择器

    子元素过滤选择器

    表单选择器

    表单过滤选择器

  29. EasyUI 中 datagrid 刷新当前数据的方法?

    答案:使用 reload()即可

  30. 分别写出一个 div 居中和其中的内容居中的 css 属性设置

    Div 居中:

    margin:auto 0px;

    内容居中:

    text-align:center;

  31. 概述一下 session 与 cookie 的区别

    答案:

    存储角度:

    Session 是服务器端的数据存储技术,cookie 是客户端的数据存储技术

    解决问题角度:

    Session 解决的是一个用户不同请求的数据共享问题,cookie 解决的是不

    同请求的请求数据的共享问题

    生命周期角度:

    Session 的 id 是依赖于 cookie 来进行存储的,浏览器关闭 id 就会失效

    Cookie 可以单独的设置其在浏览器的存储时间。

  32. JavaScript 中 null 和 undefined 是否有区别?有哪些区

    别?

    答案:

    赋值角度说明:

    null 表示此处没有值,undefined 表示此处定义了但是没有赋值

    从数据转换角度:

    Null 在做数值转换时会被转换为 0,undefined 会被转换为 NaN

  33. Servlet 中的 doPost 和 doGet 方法有什么区别?它们在传递

    和获取参数上有什么区别?

    答案:

    区别:doPost 用来处理 post 请求,doGet 用来处理 get 请求,获取参数:

    获取的参数是相同的都是 HttpServletRequest \HttpServletResponse

  34. 请写出一段 jQuery 代码,实现把当前页面中所有的 a 元索中

    class 属性为“view-link”的链接都改为在新窗口中打开

    答案:

    $(“a[class=view-link]”).attr(“target”,”_blank”)

  35. 如下 JavaScript 代码的输出为:

    var scope ="global scope";

    function checkscope() {

    var scope ="local scope”;

    return function() { return scope}

    }

    console.log (checkscope()());

    输出:global scope

  36. Jquery 中’.get()’与’.eq()’的区别

    eq 返回的是一个 jquery 对象 get 返回的是一个 html 对象

  37. 如何给 weblogic 定内存的大小?

    在启动 Weblogic 的脚本中(位于所在 Domian 对应服务器目录下的

    startServerName),增加 set MEM_ARGS=-Xms32m -Xmx200m,可以

    调整最小内存为 32M,最大 200M

  38. TCP 为何采用三次握手来建立连接,若釆用二次握手可以吗,

    请说明理由?

    三次握手是为了防止已失效的连接请求再次传送到服务器端。 二次握手不

    可行,因为:如果由于网络不稳定,虽然客户端以前发送的连接请求以到达

    服务方,但服务方的同意连接的应答未能到达客户端。则客户方要重新发送

    连接请求,若采用二次握手,服务方收到重传的请求连接后,会以为是新的

    请求,就会发送同意连接报文,并新开进程提供服务,这样会造成服务方资

    源的无谓浪费

  39. 以下 HTTP 相应状态码的含义描述正确的是()

    A. 200ok表示请求成功

    B. 400 不良请求表示服务器未发现与请求 URL 匹配内容

    C. 404未发现表示由于语法错误儿导致服务器无法理解请求信息

    D. 500 内部服务器错误,无法处理请求

    答案:D

    分析:

    A 200ok 表示的意思是一切正常。一般用于相应 GET 和 POST 请求。这

    个状态码对 servlet 是缺省的;如果没有调用 setStatus 方法的话,就会得

    到 200。

    B 400 表示指出客户端请求中的语法错误

    C 404 客户端所给的地址无法找到任何资源

  40. JSP 页面包括哪些元素?()

    A. JSP命令

    B. JSP Action

    C. JSP脚本

    D. JSP 控件

    答案:C

    分析:JSP 页面元素构成如下,因此 ABD 错误

  41. Ajax 有四种技术组成:DOM,CSS,JavaScript,

    XmlHttpRequest,其中控制文档结构的是()

    A. DOM

    B. CSS

    C. JavaScript

    D. XmlHttpRequest

    答案:A

  42. 下面关于 session 的用法哪些是错误的?()

    A. HttpSession session=new HttpSession();

    B. String haha=session getParameler(:haha”);

    C. session.removeAttribute(“haha”);

    D. session.setAttribute(:haha:);XmlHttpRequest

    答案:A

  43. Jsp 九大内置对象

    答案:

    1、request 对象

    request 对象是 javax.servlet.httpServletRequest 类型的对象。 该对象代

    表了客户端的请求信息,主要用于接受通过 HTTP 协议传送到服务器的数据。

    (包括头信息、系统信息、请求方式以及请求参数等)。request 对象的作用

    域为一次请求。

    2、response 对象

    response 代表的是对客户端的响应,主要是将 JSP 容器处理过的对象传回到

    客户端。response 对象也具有作用域,它只在 JSP 页面内有效。

    3、session 对象

    session 对象是由服务器自动创建的与用户请求相关的对象。服务器为每个用

    户都生成一个 session 对象,用于保存该用户的信息,跟踪用户的操作状态。

    session 对象内部使用 Map 类来保存数据,因此保存数据的格式为

    “Key/value”。 session 对象的 value 可以使复杂的对象类型,而不仅仅局

    限于字符串类型。

    4、application 对象

    application 对象可将信息保存在服务器中,直到服务器关闭,否则

    application 对象中保存的信息会在整个应用中都有效。与 session 对象相比,

    application 对象生命周期更长,类似于系统的“全局变量”。 5、out 对象

    out 对象用于在 Web 浏览器内输出信息,并且管理应用服务器上的输出缓冲

    区。在使用 out 对象输出数据时,可以对数据缓冲区进行操作,及时清除缓

    冲区中的残余数据,为其他的输出让出缓冲空间。待数据输出完毕后,要及时

    关闭输出流。

    6、pageContext 对象

    pageContext 对象的作用是取得任何范围的参数,通过它可以获取 JSP 页面

    的 out、request、reponse、session、application 等对象。pageContext

    对象的创建和初始化都是由容器来完成的,在 JSP 页面中可以直接使用

    pageContext 对象。

    7、config 对象

    config 对象的主要作用是取得服务器的配置信息。通过 pageConext 对象的

    getServletConfig() 方法可以获取一个 config 对象。当一个 Servlet 初始化

    时,容器把某些信息通过 config 对象传递给这个 Servlet。 开发者可以在

    web.xml 文件中为应用程序环境中的 Servlet 程序和 JSP 页面提供初始化参

    248

    尚学堂 Java 面试题大全及参考答案

    数。

    8、page 对象

    page 对象代表 JSP 本身,只有在 JSP 页面内才是合法的。 page 隐含对象

    本质上包含当前 Servlet 接口引用的变量,类似于 Java 编程中的 this 指针。

    9、exception 对象

    exception 对象的作用是显示异常信息,只有在包含 isErrorPage="true" 的

    页面中才可以被使用,在一般的 JSP 页面中使用该对象将无法编译 JSP 文件。

    excepation 对象和 Java 的所有对象一样,都具有系统提供的继承结构。

    exception 对象几乎定义了所有异常情况。在 Java 程序中,可以使用

    try/catch 关键字来处理异常情况; 如果在 JSP 页面中出现没有捕获到的异

    常,就会生成 exception 对象,并把 exception 对象传送到在 page 指令

    中设定的错误页面中,然后在错误页面中处理相应的 exception 对象。

  44. 如何配置一个 servlet?

    在 web.xml 中使用如下标签:

    或者使用注解方式:

    @WebServlet(name="servlet", urlPatterns={"/*"})

  45. JavaScript,如何定义含有数值 1 至 8 的数组?

    答: var arr=[1,2,3,4,5,6,7,8]

  46. 以下 JavaScipt 语句会产生运行错误的是_()

    A. var obj=( );

    B. var obj=[ ];

    C. var obj=//;

    D. var obj=1;

    答案:AC

  47. 在 JSP 中,下面__()__块中可以定义一个新类:

    A. <% %>

    B. <% ! %>

    C. <%@ %>

    D. <%=%>

    答案:B

    分析:B <% ! %> 可用作声明

    A 不正确

    C 为引用 xxx,比如<% @page xxxxx%>

    D 为表达式

  48. HTML 含义和版本变化

    HTML 含义:

    Hyper Text Markup Language 超文本标记语言,是一种用来制作“网页”

    的简单标记语言;用 HTML 编写的超文本文档称为 HTML 文档,HTML 文

    档的扩展名是 html 或者 htm

    版本变化:

    HTML1.0——在 1993 年 6 月作为 IETF 工作草案发布(并非标准)

    HTML 2.0——1995 年 11 月作为 RFC 1866 发布

    HTML 3.2——1997 年 1 月 14 日,W3C 推荐标准

    HTML 4.0——1997 年 12 月 18 日,W3C 推荐标准

    HTML 4.01(微小改进)——1999 年 12 月 24 日,W3C 推荐标准

    HTML 5—2014 年 10 月 28 日,W3C 推荐标准 HTML 文档结构;

    HTML 5.1 - 2016 年

    HTML 5.2 – 2018 年最新版本

    HTML 5.3 is coming…

  49. 什么是锚链接

    锚链接是带有文本的超链接。可以跳转到页面的某个位置,适用于页面内容

    较多,超过一屏的场合 。分为页面内的锚链接和页面间的锚链接 。

    例如:

    1F2F

    跳转到 2F 标记位置

    说明:

    1.在标记位置利用 a 标签的 name 属性设置标记。

    2.在导航位置通过 a 标签的 href 属性用#开头加 name 属性值即可跳转

    锚点位置。

  50. HTML 字符实体的作用及其常用字符实体

    有些字符,比如说“<”字符,在 HTML 中有特殊的含义,因此不能在文本

    中使用。想要在 HTML 中显示一个小于号“<”,需要用到字符实体:<

    或者<

    字符实体拥有三个部分:一个 and 符号(&),一个实体名或者一个实体号,

    最后是一个分号(;)

    常用字符实体:

    显示结果 描述 实体名 实体号

    空格 ? ?

    < 小于 < <

大于 > >

& and 符号 & &

‘ 单引号 ‘ (IE 不支持) ‘

" 引号 " "

£ 英镑 £ £

¥ 人民币元 ¥ ¥

§ 章节 § §

? 版权 ? ?

  1. HTML 表单的作用和常用表单项类型

    表单的作用:

    利用表单可以收集客户端提交的有关信息。

    常用表单项类型:

    input 标签

    type 属性

    功能 input 标签

    type 属性

    功能

    text 单行本框 reset 重置按钮

    password 密码框 submit 提交按钮

    radio 单选按钮 textarea 文本域

    checkbox 复选框 select 下拉框

    button 普通按钮 hidden 隐藏域

  2. 表格、框架、div 三种 HTML 布局方式的特点

    优点 缺点 应用场合

    表格 方便排列有规律、结

    构均匀的内容或数据

    产生垃圾代码、影响

    页面下载时间、灵活

    内容或数据整齐的

    页面

    性不大难于修改

    框架 支持滚动条、方便导

    节省页面下载时间等

    兼容性不好,保存时

    不方便、应用范围有

    小型商业网站、论坛

    后台管理

    Div 代码精简、提高页面

    下载速度、表现和内

    容分离

    比较灵活、难于控制 复杂的不规则页面、

    业务种类较多的大

    型商业网站

  3. form 中 input 设置为 readonly 和 disabled 的区别

    readonly disabled

    有效对象 .只针对 type 为

    text/password 有效

    对所有表单元素有效

    表单提交 当表单元素设置 readonly

    后,表单提交能将该表单元

    素的值传递出去。

    当表单元素设置 disabled 后,表

    单提交不能将该表单元素的值传

    递出去。

  4. CSS 的定义和作用

    CSS 的定义:CSS 是 Cascading Style Sheets(层叠样式表)的简称。

    CSS 是一系列格式规则,它们控制网页内容的外观。CSS 简单来说就是用来

    美化网页用的。

    CSS 的具体作用包括:

    使网页丰富多彩,易于控制。

    页面的精确控制,实现精美、复杂页面 。

    样式表能实现内容与样式的分离,方便团队开发。

    样式复用、方便网站的后期维护。

  5. CSS2 常用选择器类型及其含义

    选择器名称 案例 语法格式

    标签选择器 h3{font-size:24px;font-famil

    y:"隶书“; }

JSP

元素标签名{样式属性}
类选择器 .red {color:#F00;}

  • Oracle
  • . 元素标签 class 属性值
    {样式属性}
    ID 选择器 #p1
    {background-color:#0F0;}

    content

    #元素标签 id 属性值{样式
    属性}
    包含选择器 div h3{color:red;}

    CSS 层叠样式表

    父元素标签 子元素标签{
    样式属性
    }
    子选择器 div>ul{color:blue;}

    父元素标签名>子元素名{
    样式属性

    • 测试 1

      1. 嵌套元素
      2. 嵌套元素
      3. 嵌套元素
      4. 嵌套元素
    • 测试 1
    • 测试 1

    }
    339. 引入样式的三种方式及其优先级别
    三种引用方式:
    1. 外部样式表(存放.css 文件中)
    不需要 style 标签

    2. 嵌入式样式表

    p{color:red;}

    3.内联样式
    标签属性名为 style

    优先级级别:内联定义最高、内部 CSS 次之、外部 CSS 优先级最低。。
    340. 盒子模型
    盒子模型类似于生活中的盒子,具有 4 个属性,外边距,内
    边距,边框,内容。
    外边距:margin,用于设置元素和其他元素之间的距离。
    内边距:padding,用于设置元素内容和边框之间的距离。
    边框:border,用于设置元素边框粗细,颜色,线型。
    内容:width,height,用于设置元素内容显示的大小。
    例如:

    body{
    margin: 0; /*取消body默认的外边距*/
    }
    #img1{
    width:200px; /*设置图片的宽度*/
    border: 2px solid black; /*设置图片边框*/
    margin: 5px;
    /*设置图片外边距(表示该图片与其他图片的距离为5px)*/
    padding:10px; /*设置图片与边框之间的距离*/
    }
    #img2{
    height: 200px; /* 设置图片的高度*/
    border: 2px solid black; /*设置图片的边框*/
    margin: 5px; /*设置图片外边距*/
    padding: 20px; /*设置图片与边框之间的距离*/
    }



    341. JavaScript 语言及其特点
    Javascript 一种基于对象(object-based)和事件驱动(Event Driven)的简单
    的并具有安全性能的脚本语言。特点:
    解释性: JavaScript 不同于一些编译性的程序语言,例如 C、C++等,它
    是一种解释性的程序语言,它的源代码不需要经过编译,而直接在浏览器中
    运行时被解释。
    基于对象:JavaScript 是一种基于对象的语言。这意味着它能运用自己已经
    创建的对象。因此,许多功能可以来自于脚本环境中对象的方法与脚本的相
    互作用。
    事件驱动:JavaScript 可以直接对用户或客户输入做出响应,无须经过 Web
    服务程序。它对用户的响应,是以事件驱动的方式进行的。所谓事件驱动,
    就是指在主页中执行了某种操作所产生的动作,此动作称为“事件”。比如
    按下鼠标、移动窗口、选择菜单等都可以视为事件。当事件发生后,可能会
    引起相应的事件响应。
    跨平台:JavaScript 依赖于浏览器本身,与操作环境无关,只要能运行浏览器
    的计算机,并支持 JavaScript 的浏览器就可正确执行。
    342. JavaScript 常用数据类型有哪些
    1、数值型(Number):整数和浮点数统称为数值。例如 85 或 3.1415926
    等。
    2、字符串型(String):由 0 个,1 个或多个字符组成的序列。在 JavaScript
    中,用双引号或单引号括起来表示,如“您好”、‘学习 JavaScript’等。
    尚学堂 Java 面试题大全及参考答案
    260
    不区分单引号、双引号。
    3、逻辑(布尔)型(Boolean):用 true 或 false 来表示。
    4、空(null)值(Null):表示没有值,用于定义空的或不存在的引用。
    要注意,空值不等同于空字符串""或 0。 5、未定义(Undefined)值:它也是一个保留字。表示变量虽然已经声明,
    但却没有赋值。
    除了以上五种基本的数据类型之外,JavaScript 还支持复合数据类型,包括
    对象和数组两种。
    343. html 语法中哪条命令用于使一行文本折行,而不是插入一个
    新的段落? (B)
    A.
    B.

    C.

    D.

    分析:
    A

    定义标准表格
    C

    表示文本一个段落
    D

    表示对文本标题进行强调的一种标签
    344. Ajax 的优点和缺点
    优点:减轻服务器的负担,按需取数据,最大程度的减少冗余请求,局部
    刷新页面,减少用户心理和实际的等待时间,带来更好的用户体验,基于 xml
    尚学堂 Java 面试题大全及参考答案
    标准化,并被广泛支持,不需安装插件等,进一步促进页面和数据的分离
    缺点:AJAX 大量的使用了 javascript 和 ajax 引擎,这些取决于浏览器
    的支持.在编写的时候考虑对浏览器的兼容性.
    345. 怎样防止表单刷新重复提交问题?(说出思路即可)
    JS 脚本方式:
    第一种:定义全局变量,在 form 提交前判断是否已有提交过

    第二种:单击提交按钮后,立刻禁用改按钮
    第三种:单击提交按钮后,弹出屏蔽层,防止用户第二次点击
    346. JQuery.get()和 JQuery.ajax()方法之间的区别是什么?
    JQuery.ajax()是对原生的 javaScript 的 ajax 的封装,简化了 ajax 的步骤,
    用户可用 JQuery.ajax()发送 get 或者 post 方式请求,Jquery.get()是对 ajax
    的 get 方式的封装,只能发送 get 方式的请求。
    347. Jquery 里的缓存问题如何解决?例如($.ajax()以及$.get())
    $.ajax()请求时候加上 cache:false 的参数,如:
    $.ajax({
    type : "get",
    url : "XX",
    dataType : "json",
    cache:false,
    success : function(json) {
    }
    });
    $.get()请求时候加上时间,如:
    $.get("url","data"+new Date(),function(data){
    );
    348. Javascript 是面向对象的,怎么体现 Javascript 的继承关
    系?
    Javascript 里面没有像 java 那样的继承,javascript 中的继承机制仅仅是靠
    模拟的,可以使用 prototype 原型来实现
    349. Javascript 的有几种种变量。变量范围有什么不同?
    可以分为三种
    1、原生类型(string,number,boolean)
    2、对象(Date,Array)
    3、特殊类型(var vara;(只什么没有定义),var varb = null;(定义一个变
    量并赋值为 null))
    350. Js 如何获取页面的 dom 对象
    1、直接获取
    //1.1 -- id 方式获取
    var varid = document.getElementById("unameid");
    //1.2 -- name 获取(获取的是数组对象)
    var varname = document.getElementsByName("sex");
    //1.3 -- 元素获取(获取的是数组对象)
    var varinput = document.getElementsByTagName("input");
    2、间接方式获取
    //2.1 父子关系 --childNodes
    var varchilds = document.getElementById("div01").childNodes;
    //2.2 子父关系--parentNode
    var varfather2 =
    document.getElementById("unameid").parentNode;
    //2.3 兄弟之间相互获取 nextSibling:下一个节点
    previousSibling:上一个节点
    351. Servlet API 中 forward() 与 redirect()的区别?
    答:
    为实现程序的模块化,就需要保证在不同的 Servlet 之间可以相互跳转,
    而 Servlet 中主要有两种实现跳转的方式:FORWARD 方式与 redirect 方
    式。
    Forward() : 是服务器内部的重定向,服务器直接访问目标地址的 URL,
    把那个 URL 的响应内容读取出来,而客户端并不知道,因此在客户端浏览
    器的地址栏里不会显示跳转后的地址,还是原来的地址。由于在整个定向的
    过程中用的是同一个 Request,因此 FORWARD 会将 Request 的信息带到
    被定向的JSP或 Servlet 中使用。
    Redirect():则是客户端的重定向,是完全的跳转,即客户端浏览器会获
    取跳转后的地址,然后重新发送请求,因此浏览器中会显示跳转后的地址。
    同时,由于这种方式比 FORWARD 方式多了一次网络请求,因此其效率低
    于 FORWARD 方式,需要注意到的是,客户端的重定向可以通过设置特定
    的 HTTP 头或写 JavaScript 脚本来实现。
    鉴于以上的区别,一般当 FORWARD 方式可以满足需求时,尽可能的
    使用 FORWARD 方式。但在有些情况下,例如,需要跳转到一个其他服务
    器上的资源时,则必须使用 redirect 方式。
    352. Session 域和 request 域什么区别?
    作用域:存放数据,获取数据(传递数据)
    有效的作用域:生命周期,作用范围
    httpServeltRequest:
    生命周期:一次请求之间
    作用范围:所有被请求转发过的 servlet 都能获取到
    httpSession:
    生命周期:一次会话
    作用范围:所有的 servlet 都可以获取到
    servletContex:
    生命周期:从项目开始运行到服务器关闭
    作用范围:所有的 servlet 都可以获取到
    作用域如何选用?
    httpServeltRequest:和当前请求有关的信息
    httpSession:和当前用户有关的信息
    servletContex:访问量比较大,不易更改
    353. 页面中有一个命名为 bankNo 的下拉列表,写 js 脚本获取当
    前选项的索引值,如果用 jquery 如何获取
    var a = document.getElementsByName("bankNo")[0].value;
    var b = $("select[name=bankNo]").val();
    354. 写出要求 11 位数字的正则表达式
    ^[1-9]\d{10}$
    355. 分别获取指定 name、Id 的 javascript 对象,如果用 jquey
    如何获取
    js:
    id--document.getElementById("id");
    name--document.getElementsByName("name");
    jquery
    id--$("#id");
    name--$("元素名称[name="name 值"]");
    356. 一个页面有两个 form,如何获取第一个 form
    用 id 方式获取;document.getElementById("id");
    357. 如何设置一个层的可见/隐藏
    可见 : document.getElementById("divid").style.display = "block";
    隐藏 : document.getElementById("divid").style.display = "none";
    358. 描述 JSP 中动态 INCLUDE 与静态 INCLUDE 的区别?
    动态导入
    1、会将多个 jsp 页面分别再编写成 java 文件,编译成 class 文件
    2、jsp 文件中允许有相同的变量名,每个页面互不影响
    3、当 java 代码比较多优先选用动态导入
    4、效率相对较低,耦合性低
    静态导入
    1、会将多个 jsp 页面合成一个 jsp 页面,再编写成 java 文件,编译成
    class 文件
    2、jsp 文件中不允许有相同的变量名
    3、当 java 代码比较少或者没有 java 代码是优先选用静态导入
    4、效率相对较高,耦合性高
    359. 列举 JSP 的内置对象及方法
    request 表示 HttpServletRequest 对象。它包含了有关浏览器请求的信息,
    并且提供了几个用于获取 cookie, header, 和 session 数据的有用的方法。
    response表示HttpServletResponse对象,并提供了几个用于设置送回 浏
    览器的响应的方法(如 cookies,头信息等)
    out 对象是 javax.jsp.JspWriter 的一个实例,提供了几个方法使你能用于向
    浏览器回送输出结果
    pageContext 表示一个 javax.servlejt.sp.PageContext 对象。它是用于方
    便存取各种范围的名字空间、servlet 相关的对象的 API,并且包装了通用的
    servlet 相关功能的方法。
    session 表示一个请求的 javax.servlet.http.HttpSession 对象。Session
    可以存贮用户的状态信息
    applicaton 表示一个 javax.servle.ServletContext 对象。这有助于查找有
    关 servlet 引擎和 servlet 环境的信息
    config表示一个javax.servlet.ServletConfig对象。该对象用于存取servlet
    实例的初始化参数。
    page 表示从该页面产生的一个 servlet 实例
    Exception 异常
    360. 列举 jsp 的四大作用域
    page、request、session、application
    361. html 和 xhtml 的区别是什么?
    HTML 与 XHTML 之间的差别,粗略可以分为两大类比较:一个是功能上的
    差别,另外是书写习惯的差别。关于功能上的差别,主要是 XHTML 可兼容
    各大浏览器、手机以及 PDA,并且浏览器也能快速正确地编译网页。
    因为 XHTML 的语法较为严谨, 所以如果你是习惯松散结构的 HTML 编写
    者,那需要特别注意 XHTML 的规则。但也不必太过担心,因为 XHTML 的
    规则并不太难。下面列出了几条容易犯的错误,供大家引用。
    1:所有标签都必须小写
    在 XHTML 中,所有的标签都必须小写,不能大小写穿插其中,也不能全部
    都是大写。看一个例子。
    错误:

    正确:
    2:标签必须成双成对
    像是

    ...

    ...

    ...

    标签等,当出现一个标签
    时,必须要有对应的结束标签,缺一不可,就像在任何程序语言中的括号一
    样。
    错误:大家好

    我是 muki
    正确:

    大家好

    我是 muki

    3:标签顺序必须正确
    标签由外到内,一层层包覆着,所以假设你先写 div 后写 h1,结尾就要先
    写 h1 后写 div。只要记住一个原则“先进后出”,先弹出的标签要后结尾。
    错误:

    大家好

    正确:

    大家好

    4:所有属性都必须使用双引号
    在 XHTML 1.0 中规定连单引号也不能使用,所以全程都得用双引号。
    错误:

    hello

    正确:

    hello

    MUKI
    space
    正确:MUKI
    space

    362. 你做的页面用哪些浏览器测试过?这些测试的内核分别是什
    么?
    1、Trident 内核代表产品 Internet Explorer,又称其为 IE 内核。
    Trident(又称为 MSHTML),是微软开发的一种排版引擎。使用 Trident
    渲染引擎的浏览器包括:IE、傲游、世界之窗浏览器、Avant、腾讯 TT、
    Netscape 8、NetCaptor、Sleipnir、GOSURF、GreenBrowser 和 KKman
    等。
    2、Gecko 内核代表作品 Mozilla
    FirefoxGecko 是一套开放源代码的、以 C++编写的网页排版引擎。Gecko
    是最流行的排版引擎之一,仅次于Trident。使用它的最著名浏览器有Firefox、
    Netscape6 至 9。 3、WebKit 内核代表作品 Safari、Chromewebkit
    是一个开源项目,包含了来自 KDE 项目和苹果公司的一些组件,主要用于
    Mac OS 系统,它的特点在于源码结构清晰、渲染速度极快。缺点是对网页
    代码的兼容性不高,导致一些编写不标准的网页无法正常显示。主要代表作
    品有 Safari 和 Google 的浏览器 Chrome。 4、Presto 内核代表作品 OperaPresto
    是由 Opera Software 开发的浏览器排版引擎,供 Opera 7.0 及以上使用。
    它取代了旧版 Opera 4 至 6 版本使用的 Elektra 排版引擎,包括加入动态功
    能,例如网页或其部分可随着 DOM 及 Script 语法的事件而重新排版。
    363. 你遇到了哪些浏览器的兼容性问题?怎么解决的?
    答:因为不同的浏览器对同一段代码有不同的解析,造成页面显示效果不统
    一的情况;这是我们常见的兼容性问题。
    解决方法:
    1、针对不同的浏览器写不同的代码
    2、使用 jquery 屏蔽浏览器差异
    遇到不同的兼容问题,需要针对前端进行兼容适配;
    364. 你知道的常用的 js 库有哪些?
    1.moment.js
    举个例子:
    用 js 转换时间戳为日期
    let date = new Date(1437925575663);
    let year = date.getFullYear() + ‘-‘;
    let month = ( date.getMonth() + 1

    • 张三:123
    • 李四:456
    • 王五:789
    • 赵六:147
      • function test(){
        var varli = document.getElementsByTagName("li");
        for (var i=0;i0){
        for (int i = 0; i
        若是 html 页面,在网页头部()中添加下面这段代码

        2)将 form 表单提交方式变为 post 方式,即添加 method="post";)在 Servlet 类中
        编写代码 request.setCharacterEncoding("UTF-8"),而且必须写在第一行。
        3)如果是 get 请求,在 Servlet 类中编写代码
        byte [] bytes = str.getBytes("iso-8859-1");
        String cstr = new String(bytes,"utf-8");
        或者直接修改 Tomcat 服务器配置文件 server.xml 增加内容:
        URIEncoding="utf-8"
        384. 绝对路径、根路径、相对路径的含义及其区别
        绝对路径指对站点的根目录而言某文件的位置,相对路径指以当前文件所处目录而
        言某文件的位置,相对路径-以引用文件之网页所在位置为参考基础,而建立出的目录路
        径。绝对路径-以 Web 站点根目录为参考基础的目录路径。
        先给出一个网站结构图做实例加深理解,A 网站(域名为 http://www.a.com):
        /include/a-test.html,/img/a-next.jpg;B 网站(域名为 http://www.b.com):
        /include/b-test.html,/img/b-next.jpg。
        相对路径是从引用的网页文件本身开始构建的,如果在 A 网站中的 a-test.html 中要
        插入图片 a-next.jpg,可以这样做:,重点是 img 前
        面的../,表示从 html 处于的 include 开始起步,输入一个../表示回到上面一级父文件夹
        下,然后再接着 img/表示又从父级文件夹下的 img 文件开始了,最后定位 img 下面的
        next.jpg。
        根路径是从网站的最底层开始起,一般的网站的根目录就是域名下对应的文件夹,就
        如 D 盘是一个网站,双击 D 盘进入到 D 盘看到的就是网站的根目录,这种路径的链接
        样式是这样的:如果在 A 网站中的 a-test.html 中要插入图片 a-next.jpg,可以这样
        做:,以/开头表示从网站根目录算起,找到根目录下面
        的 img 文件夹下的 next.jpg。
        绝对路径就很好理解了,这种路径一般带有网站的域名,如果在 A 网站中的
        a-test.html 中要插入图片 a-next.jpg,需要这样这样写:,将图片路径上带有了域名信息,再打个
        比方:如果在 A 网站中的 a-test.html 中要插入 B 网站的图片 b-next.jpg,就需要这样
        写:,这种方法适用与在不同网站
        之间插入外部网站的图片。
        385. 如实现 servlet 的单线程模式
        实现 servlet 的单线程的 jsp 命令是: 。
        默认 isThreadSafe 值为 true。
        属性isThreadSafe=false模式表示它是以Singleton模式运行,该模式implements
        了接口 SingleThreadMode, 该模式同一时刻只有一个实例,不会出现信息同步与否的
        概念。若多个用户同时访问一个这种模式的页面,那么先访问者完全执行完该页面后,
        后访问者才开始执行。
        属性 isThreadSafe=true 模式表示它以多线程方式运行。该模式的信息同步,需访
        问同步方法(用 synchronized 标记的)来实现。 一般格式如下:
        public synchronized void syncmethod(...){
        while(...) {
        this.wait();
        }
        this.notifyAll();
        }
        386. Servlet 的生命周期
        1、加载:在下列时刻加载 Servlet:(1)如果已配置自动加载选项,则在启动服务器时
        自动 2、加载 (web.xml 中设置);(2)在服务器启动后,客户机首次
        向 Servlet 发出请求时;(3)重新加载 Servlet 时(只执行一次)
        3、实例化:加载 Servlet 后,服务器创建一个 Servlet 实例。(只执行一次)
        4、初始化:调用 Servlet 的 init() 方法。在初始化阶段,Servlet 初始化参数被传递给
        Servlet 配置对象 ServletConfig。 (只执行一次)
        5、请求处理:对于到达服务器的客户机请求,服务器创建针对此次请求的一个“请求”
        对象和一个“响应”对象。服务器调用 Servlet 的 service() 方法,该方法用于传递“请
        求”和“响应”对象。service() 方法从“请求”对象获得请求信息、处理该请求并用“响
        应”对象的方法以将响应传回客户机。service() 方法可以调用其它方法来处理请求,例
        如 doGet()、doPost() 或其它的方法。(每次请求都执行该步骤)
        6、销毁:当服务器不再需要 Servlet, 或重新装入 Servlet 的新实例时,服务器会调用
        Servlet 的 destroy() 方法。(只执行一次)
        387. 转发和重定向的区别
        转发是在服务端直接做的事情,是对客户端的同一个 request 进行传递,浏览器并不知
        道。重定向是由浏览器来做的事情。重定向时,服务端返回一个 response,里面包含了
        跳转的地址,由浏览器获得后,自动发送一个新 request。转发像呼叫转移或者 110 报
        警中心,重定向似 114 查号台。
        a) 区别 1:跳转效率的不同
        转发效率相对高;重定向效率相对低
        b) 区别 2:实现语句不同
        转发 request.getRequestDispatcher("xxxx").forward(request,response) ;
        重定向 response.sendRedirect("xxxx")
        c) 区别 3:是否共有同一个 request 的数据
        转发源组件与目标组件共有同一个 request 数据
        重定向源组件与目标组件不共有同一个 request 数据(可使用 session 共有数据)
        d) 区别 4:浏览器 URL 地址的不同
        转发后浏览器 URL 地址保持不变(源组件地址)
        重定向后浏览器 URL 地址改变为重定向后的地址(目标组件地址)
        e) 区别 5:"/"路径的含义不同
        转发时"/"代表当前项目的根路径 ;重定向时"/"代表当前服务器的根路径
        f) 区别 6:跳转范围的不同
        只能转发到同一应用中的 URL(默认) ;可以重定向任何服务器、任何应用的 URL
        g) 区别 7:刷新是否导致重复提交
        转发会导致重复提交(可以通过同步令牌解决);重定向不会导致重复提交
        h) 区别 8:是否经过过滤器
        转发不经过过滤器(默认情况);重定向经过过滤器
        388. JSP 的执行过程
        在 JSP 运行过程中,首先由客户端发出请求,Web 服务器接收到请求后,如果是第一次
        访问某个 jsp 页面,Web 服务器对它进行以下 3 个操作。
        1) 翻译:由.jsp 变为.java,由 JSP 引擎实现。
        2) 编译:由.java 变为.class,由 Java 编译器实现。
        3) 执行:由.class 变为.html,用 Java 虚拟机执行编译文件,然后将执行结果返回给 Web
        服务器,并最终返回给客户端
        如果不是第一次访问某个 JSP 页面,则只执行第三步。所以第一次访问 JSP 较慢。
        389. JSP 动作有哪些,简述作用?
        jsp:include:在页面被请求的时候引入一个文件。
        jsp:useBean:寻找或者实例化一个 JavaBean。 jsp:setProperty:设置 JavaBean 的属
        性。
        jsp:getProperty:输出某个 JavaBean 的属性。
        jsp:forward:把请求转到一个新的页面。 jsp:plugin:根据浏览器类型为 Java 插件生
        成 OBJECT 或 EMBED 标记。
        390. page/request/session/application 作用域区别
        page:当前页面范围
        request:当前页面范围+转发页面(forward)+包含页面(include)
        session:当前会话:session 在以下几种情况下失效
        1) 销毁 session:Session.invalidate();
        2) 超过最大非活动间隔时间
        3) 手动关闭浏览器(session 并没有立刻失效,因为服务器端 session 仍旧存在,超过
        最大非活动间隔时间后真正失效)
        application:当前应用;服务器重新启动前一直有效
        391. JSP 和 Servlet 的区别和联系
        区别:
        1) JSP 是在 HTML 代码里写 JAVA 代码,框架是 HTML;而 Servlet 是在 JAVA 代码中写
        HTML 代码,本身是个 JAVA 类。
        2) JSP 使人们把显示和逻辑分隔成为可能,这意味着两者的开发可并行进行;而 Servlet
        并没有把两者分开。
        3) Servlet 独立地处理静态表示逻辑与动态业务逻辑.这样,任何文件的变动都需要对此
        服务程序重新编译;JSP 允许用特殊标签直接嵌入到 HTML 页面, HTML 内容与 JAVA
        内容也可放在单独文件中,HTML 内容的任何变动会自动编译装入到服务程序.
        4) Servlet 需要在 web.xml 中配置,而 JSP 无需配置。
        5) 目前 JSP 主要用在视图层,负责显示,而 Servlet 主要用在控制层,负责调度
        联系:
        1) 都是 Sun 公司推出的动态网页技术。
        2) 先有 Servlet,针对 Servlet 缺点推出 JSP。JSP 是 Servlet 的一种特殊形式,每个 JSP
        页面就是一个 Servlet 实例——JSP 页面由系统翻译成 Servlet,Servlet 再负责响应
        用户请求。
        392. 谈谈过滤器原理及其作用?
        原理: l 过滤器是运行在服务器端的一个拦截作用的 web 组件,一个请求来到时,web 容器
        会判断是否有过滤器与该信息资源相关联,如果有则交给过滤器处理,然后再交给目
        标资源,响应的时候则以相反的顺序交给过滤器处理,最后再返回给用户浏览器
        l 一般用于日志记录、性能、安全、权限管理等公共模块。
        过滤器开发: l 过滤器是一个实现了 javax.servlet.Filter 接口的 java 类 l 主要业务代码放在 doFilter 方法中
        l 业务代码完成后要将请求向后传递,即调用 FilterChain 对象的 doFilter 方法
        配置: 在web.xml中增加如下代码

        MyFilter
        Filter完整类名

        MyFilter
        /*(要过虑的url,此处*表示过虑所有的
        url)

        谈谈监听器作用及其分类?
        监听器也叫 Listener,是一个实现特定接口的 java 类,使用时需要在 web.xml 中配置,
        它是 web 服务器端的一个组件,它们用于监听的事件源分别为
        SerlvetConext,HttpSession 和 ServletRequest 这三个域对象
        主要有以下三种操作: – 监听三个域对象创建和销毁的事件监听器
        – 监听域对象中属性的增加和删除的事件监听器
        – 监听绑定到 HttpSession 域中的某个对象的状态的时间监听器
        接口分类: – ServletContextListener
        – HttpSessionListener
        – ServletRequestListener
        – ServletContextAttributeListener
        – HttpSessionAttributeListener
        – ServletRequestAttributeListener
        – HttpSessionBindingListener(不需要配置)
        – HttpSessionActivationListener(不需要配置)
        配置:
        实现以上任意接口的 java 类全名

        393. jQuery 相比 JavaScript 的优势在哪里
        jQuery 的语法更加简单。
        jQuery 消除了 JavaScript 跨平台兼容问题。
        相比其他 JavaScript 和 JavaScript 库,jQuery 更容易使用。
        jQuery 有一个庞大的库/函数。
        jQuery 有良好的文档和帮助手册。
        jQuery 支持 AJAX
        394. DOM 对象和 jQuery 对象的区别及其转换
        DOM 对象,是我们用传统的方法(javascript)获得的对象,jQuery 对象即是用 jQuery
        类库的选择器获得的对象,它是对 DOM 对象的一种封装,jQuery 对象不能使用 DOM
        对象的方法,只能使用 jQuery 对象自己的方法。
        普通的 dom 对象一般可以通过$()转换成 jquery 对象
        如:var cr=document.getElementById("cr"); //dom 对象
        var $cr = $(cr); //转换成 jquery 对象
        由于 jquery 对象本身是一个集合。所以如果 jquery 对象要转换为 dom 对象则必须取出
        其中的某一项,一般可通过索引取出
        如:$("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5]这几种语法在 jQuery
        中都是合法的
        395. jQuery 中$的作用主要有哪些
        1) $用作选择器
        例如:根据 id 获得页面元素$("#元素 ID")
        2) $相当于 window.onload 和 $(document).ready(...)
        例如:$(function(){...}); function(){...}会在 DOM 树加载完毕之后执行。
        3) $用作 JQuery 的工具函数的前缀
        例如: var str = ‘ Welcome to shanghai.com ‘;
        str = $.trim(str);去掉空格
        4) $(element):把 DOM 节点转化成 jQuery 节点
        例如:var cr=document.getElementById("cr"); //dom 对象
        var $cr = $(cr); //转换成 jquery 对象
        5)$(html):使用 HTML 字符串创建 jQuery 节点
        例如:var obj = $("

        尚学堂,实战化教学第一品牌

        ")
        396. Ajax 含义及其主要技术
        Ajax (Asynchronous JavaScript and XML 阿贾克斯)不是一个新的技术,事实上,它
        是一些旧有的成熟的技术以一种全新的更加强大的方式整合在一起。
        Ajax 的关键技术:
        1) 使用 CSS 构建用户界面样式,负责页面排版和美工
        2) 使用 DOM 进行动态显示和交互,对页面进行局部修改
        3) 使用 XMLHttpRequest 异步获取数据
        4) 使用 JavaScript 将所有元素绑定在一起
        397. Ajax 的工作原理
        Ajax 的原理简单来说通过 XmlHttpRequest 对象来向服务器发异步请求,从服务器获得
        数据,然后用 javascript 来操作 DOM 而更新页面。这其中最关键的一步就是从服务器
        获得请求数据。要清楚这个过程和原理,我们必须对 XMLHttpRequest 有所了解。
        XMLHttpRequest 是 ajax 的核心机制,它是在 IE5 中首先引入的,是一种支持异步请求
        的技术。简单的说,也就是 javascript 可以及时向服务器提出请求和处理响应,而不阻
        塞用户。达到无刷新的效果。
        398. JSON 及其作用
        JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语
        言的文本格式,是理想的数据交换格式。同时,JSON 是 JavaScript 原生格式,这意味
        着在 JavaScript 中处理 JSON 数据不须要任何特殊的 API 或工具包。
        在 JSON 中,有两种结构:对象和数组。
        ? {} 对象
        ? [] 数组
        ? , 分隔属性
        ? : 左边为属性名,右边为属性值
        属性名可用可不用引号括起,属性值为字符串一定要用引号括起
        举例:
        varo={
        "xlid": "cxh",
        "xldigitid": 123456,
        "topscore": 2000,
        "topplaytime": "2009-08-20"
        };
        jsonranklist=[
        {
        "xlid": "cxh",
        "xldigitid": 123456,
        "topscore": 2000,
        "topplaytime": "2009-08-20"
        },
        {
        "xlid": "zd",
        "xldigitid": 123456,
        "topscore": 1500,
        "topplaytime": "2009-11-20"
        }
        ];
        399. 文件上传组件 Common-fileUpload 的常用类及其作用?
        DiskFileItemFactory:磁盘文件工厂类,设置上传文件保存的磁盘目录,缓冲区大小。
        ServletFileUpload:上传处理类,此类真正读取客户上传的文件,同时可以设置最大接
        收大小。
        FileItem:上传的文件对象,可以是多个文件,每个上传的文件都是一个单独的 FileItem
        对象。
        400. 说出 Servlet 的生命周期,并说出 Servlet 和 CGI 的区别?
        答:Web 容器加载 Servlet 并将其实例化后,Servlet 生命周期开始,容器运行其 init()
        方法进行 Servlet 的初始化;请求到达时调用 Servlet 的 service 方法,service 方法会
        调用与请求对应的 doGet 或 doPost 等方法;当服务器关闭会项目被卸载时服务器会将
        Servlet 实例销毁,此时会调用 Servlet 的 destroy 方法。Servlet 与 CGI 的区别在于
        Servlet 处于服务器进程中,它通过多线程方式运行其 service 方法,一个实例可以服务
        于多个请求,并且其实例一般不会销毁,而 CGI 对每个请求都产生新的进程,服务完成
        后就销毁,所以效率上低于 Servlet。
        【补充 1】SUN 公司在 1996 年发布 Servlet 技术就是为了和 CGI 进行竞争,Servlet
        是一个特殊的 Java 程序,一个基于 Java 的 Web 应用通常包含一个或多个 Servlet 类。
        Servlet 不能够自行创建并执行,它是在 Servlet 容器中运行的,容器将用户的请求传递
        给 Servlet 程序,此外将 Servlet 的响应回传给用户。通常一个 Servlet 会关联一个或多
        个 JSP 页面。以前 CGI 经常因为性能开销上的问题被诟病,然而 Fast CGI 早就已经解决
        了 CGI 效率上的问题,所以面试的时候大可不必诟病 CGI,腾讯的网站就使用了 CGI 技
        术,相信你也没感觉它哪里不好。
        【补充 2】Servlet 接口定义了 5 个方法,其中前三个方法与 Servlet 生命周期相关:
        void init(ServletConfig config) throws ServletException
        void service(ServletRequest req, ServletResponse resp) throws ServletException,
        java.io.IOException
        void destory()
        java.lang.String getServletInfo()
        ServletConfig getServletConfig()
        401. JSP 和 Servlet 有有什么关系?
        答:其实这个问题在上面已经阐述过了,Servlet 是一个特殊的 Java 程序,它运行于服
        务器的 JVM 中,能够依靠服务器的支持向浏览器提供显示内容。JSP 本质上是 Servlet
        的一种简易形式, JSP 会被服务器处理成一个类似于 Servlet 的 Java 程序,可以简化页
        面内容的生成。Servlet 和 JSP 最主要的不同点在于,Servlet 的应用逻辑是在 Java 文
        件中,并且完全从表示层中的 HTML 分离开来。而 JSP 的情况是 Java 和 HTML 可以组
        合成一个扩展名为.jsp 的文件(有人说,Servlet 就是在 Java 中写 HTML,而 JSP 就是
        在 HTML 中写 Java 代码,当然,这个说法还是很片面的)。JSP 侧重于视图,Servlet
        更侧重于控制逻辑,在 MVC 架构模式中,JSP 适合充当视图(view)而 Servlet 适合充
        当控制器(controller)。
        402. JSP 中的四种作用域?
        答:page、request、session 和 application,具体如下:
        ①page 代表与一个页面相关的对象和属性。
        ②request 代表与 Web 客户机发出的一个请求相关的对象和属性。一个请求可能跨越
        多个页面,涉及多个 Web 组件;需要在页面显示的临时数据可以置于此作用域
        ③session 代表与某个用户与服务器建立的一次会话相关的对象和属性。跟某个用户相关
        的数据应该放在用户自己的 session 中 ④application 代表与整个 Web 应用程序相关的对象和属性,它实质上是跨越整个 Web
        应用程序,包括多个页面、请求和会话的一个全局作用域。
        403. 如何实现 JSP 或 Servlet 的单线程模式?

        【补充】Servlet 默认的工作模式是单实例多线程,如果 Servlet 实现了标识接口
        SingleThreadModel 又或是 JSP 页面通过 page 指令设置 isThreadSafe 属性为 false,
        那么它们生成的 Java 代码会以单线程多实例方式工作。显然,这样做会导致每个请求创
        建一个 Servlet 实例,这种实践将导致严重的性能问题。
        404. 实现会话跟踪的技术有哪些?
        答:由于 HTTP 协议本身是无状态的,服务器为了区分不同的用户,就需要对用户会话
        进行跟踪,简单的说就是为用户进行登记,为用户分配唯一的 ID,下一次用户在请求中
        包含此 ID,服务器据此判断到底是哪一个用户。
        ①URL 重写:在 URL 中添加用户会话的信息作为请求的参数,或者将唯一的会话 ID 添
        加到 URL 结尾以标识一个会话。
        ②设置表单隐藏域:将和会话跟踪相关的字段添加到隐式表单域中,这些信息不会在浏
        览器中显示但是提交表单时会提交给服务器。
        这两种方式很难处理跨越多个页面的信息传递,因为如果每次都要修改 URL 或在页面中
        添加隐式表单域来存储用户会话相关信息,事情将变得非常麻烦。
        ③cookie:cookie 有两种,一种是基于窗口的,浏览器窗口关闭后,cookie 就没有了;
        另一种是将信息存储在一个临时文件中,并设置存在的时间。当用户通过浏览器和服务
        器建立一次会话后,会话 ID 就会随响应信息返回存储在基于窗口的 cookie 中,那就意
        味着只要浏览器没有关闭,会话没有超时,下一次请求时这个会话 ID 又会提交给服务器
        让服务器识别用户身份。会话中可以为用户保存信息。会话对象是在服务器内存中的,
        而基于窗口的 cookie 是在客户端内存中的。如果浏览器禁用了 cookie,那么就需要通
        过下面两种方式进行会话跟踪。当然,在使用 cookie 时要注意几点:首先不要在 cookie
        中存放敏感信息;其次 cookie 存储的数据量有限(4k),不能将过多的内容存储 cookie
        中;再者浏览器通常只允许一个站点最多存放 20 个 cookie。当然,和用户会话相关的
        其他信息(除了会话 ID)也可以存在 cookie 方便进行会话跟踪。
        ④HttpSession:在所有会话跟踪技术中,HttpSession 对象是最强大也是功能最多的。
        当一个用户第一次访问某个网站时会自动创建 HttpSession,每个用户可以访问他自己
        的 HttpSession。可以通过 HttpServletRequest 对象的 getSession 方法获得
        HttpSession,通过 HttpSession 的 setAttribute 方法可以将一个值放在 HttpSession
        中,通过调用 HttpSession 对象的 getAttribute 方法,同时传入属性名就可以获取保存
        在 HttpSession 中的对象。与上面三种方式不同的是,HttpSession 放在服务器的内存
        中,因此不要将过大的对象放在里面,即使目前的 Servlet 容器可以在内存将满时将
        HttpSession 中的对象移到其他存储设备中,但是这样势必影响性能。添加到
        HttpSession 中的值可以是任意 Java 对象,这个对象最好实现了 Serializable 接口,这
        样 Servlet 容器在必要的时候可以将其序列化到文件中,否则在序列化时就会出现异常。
        405. 过滤器有哪些作用和用法?
        答: Java Web 开发中的过滤器(filter)是从 Servlet 2.3 规范开始增加的功能,并在
        Servlet 2.4 规范中得到增强。对 Web 应用来说,过滤器是一个驻留在服务器端的 Web
        组件,它可以截取客户端和服务器之间的请求与响应信息,并对这些信息进行过滤。当
        Web 容器接受到一个对资源的请求时,它将判断是否有过滤器与这个资源相关联。如果
        有,那么容器将把请求交给过滤器进行处理。在过滤器中,你可以改变请求的内容,或
        者重新设置请求的报头信息,然后再将请求发送给目标资源。当目标资源对请求作出响
        应时候,容器同样会将响应先转发给过滤器,再过滤器中,你可以对响应的内容进行转
        换,然后再将响应发送到客户端。
        常见的过滤器用途主要包括:对用户请求进行统一认证、对用户的访问请求进行记录和
        审核、对用户发送的数据进行过滤或替换、转换图象格式、对响应内容进行压缩以减少
        传输量、对请求或响应进行加解密处理、触发资源访问事件、对 XML 的输出应用 XSLT
        等。
        和过滤器相关的接口主要有:Filter、FilterConfig、FilterChain
        406. 监听器有哪些作用和用法?
        答:Java Web 开发中的监听器(listener)就是 application、session、request 三个
        对象创建、销毁或者往其中添加修改删除属性时自动执行代码的功能组件,如下所示:
        ①ServletContextListener:对 Servlet 上下文的创建和销毁进行监听。
        ②ServletContextAttributeListener:监听 Servlet 上下文属性的添加、删除和替换。
        ③HttpSessionListener:对 Session 的创建和销毁进行监听。
        补充:session 的销毁有两种情况:1session 超时(可以在 web.xml 中通过
        /标签配置超时时间);2 通过调用 session 对象
        的 invalidate()方法使 session 失效。
        ④HttpSessionAttributeListener:对 Session 对象中属性的添加、删除和替换进行监
        听。
        ⑤ServletRequestListener:对请求对象的初始化和销毁进行监听。
        ⑥ServletRequestAttributeListener:对请求对象属性的添加、删除和替换进行监听。
        407. 你的项目中使用过哪些 JSTL 标签?
        答:项目中主要使用了 JSTL 的核心标签库,包括、、、
        、等,主要用于构造循环和分支结构以控制显示逻辑。
        【说明】虽然 JSTL 标签库提供了 core、sql、fmt、xml 等标签库,但是实际开发中建议
        只使用核心标签库(core),而且最好只使用分支和循环标签并辅以表达式语言(EL),
        这样才能真正做到数据显示和业务逻辑的分离,这才是最佳实践。
        408. 使用标签库有什么好处?如何自定义 JSP 标签?
        答:使用标签库的好处包括以下几个方面:
        分离 JSP 页面的内容和逻辑,简化了 Web 开发;
        开发者可以创建自定义标签来封装业务逻辑和显示逻辑;
        标签具有很好的可移植性、可维护性和可重用性;
        避免了对 Scriptlet(小脚本)的使用(很多公司的项目开发都不允许在 JSP 中书写小脚
        本)
        自定义 JSP 标签包括以下几个步骤:
        编写一个 Java 类实现实现 Tag/BodyTag/IterationTag 接口(通常不直接实现这些接口而
        是继承 TagSupport/BodyTagSupport/SimpleTagSupport 类,这是对适配器模式中缺
        省适配模式的应用)
        重写 doStartTag()、doEndTag()等方法,定义标签要完成的功能
        编写扩展名为 tld 的标签描述文件对自定义标签进行部署,tld 文件通常放在 WEB-INF
        文件夹或其子目录
        在 JSP 页面中使用 taglib 指令引用该标签库
        标签库描述文件(该文件通常放在 WEB-INF 目录或其子目录下)

        定义标签库

        1.0

        MyTag

        time

        com.lovo.tags.TimeTag

        empty

        format

        false

        foreColor

        backColor

        JSP 页面

        ">
        首页

        * { font-family: "Arial"; font-size:72px; }

        运行结果
        【注意】如果要将自定义的标签库发布成 JAR 文件,需要将标签库描述文件(tld 文件)
        放在 JAR 文件的 META-INF 目录下,可以 JDK 自带的 jar 工具完成 JAR 文件的生成。
        409. 表达式语言(EL)的隐式对象及其作用?
        答:pageContext、initParam(访问上下文参数)、param(访问请求参数)、paramValues、
        header(访问请求头)、headerValues、cookie(访问 cookie)、applicationScope(访
        问 application 作用域)、sessionScope(访问 session 作用域)、requestScope(访问
        request 作用域)、pageScope(访问 page 作用域)。用法如下所示:
        ${pageContext.request.method}
        ${pageContext["request"]["method"]}
        ${pageContext.request["method"]}
        ${pageContext["request"].method}
        ${initParam.defaultEncoding}
        ${header["accept-language"]}
        ${headerValues["accept-language"][0]}
        ${cookie.jsessionid.value}
        ${sessionScope.loginUser.username}
        【补充】表达式语言的.和[]运算作用是一致的,唯一的差别在于如果访问的属性名不符合
        Java 标识符命名规则,例如上面的 accept-language 就不是一个有效的 Java 标识符,
        那么这时候就只能用[]运算符而不能使用.获取它的值
        410. 表达式语言(EL)支持哪些运算符?
        答:除了.和[]运算符,EL 还提供了:
        算术运算符:+、-、*、/或 div、%或 mod
        关系运算符:==或 eq、!=或 ne、>或 gt、>=或 ge、

        1. 1-9 ??

        原文地址:https://www.cnblogs.com/linanana/p/12546058.html

        时间: 2024-10-09 11:44:39

    WEB方面面试题详解的相关文章

    好程序员web前端学习路线大厂面试题详解

    好程序员web前端学习路线大厂面试题详解,依赖注入原理 手动实现依赖注入实现方式 - var _global={ - ajax:function(){//申明服务,也可以说是内部类 - this.get=function(){ - //todo:get方式请求数据 - console.log(“get is success”); - }; - This.post=function(){ - //todo:post方式请求数据 - console.log(“post is success”); -

    Tomcat5的web应用启动顺序详解

    Tomcat5的web应用启动顺序详解 [收藏此页] [打印] 作者:佚名  2007-07-17 内容导航: 第1页 [IT168技术文档]摘要: 应用Tomcat对于我们来讲实在是司空见惯了,但是对于每个使用者来讲,应该了解其运转的机制也是必不可少的,本人在维护"apache开源项目"论坛时遇到此问题,并略作研究,望与大家共讨.分享. 一.配置自动部署时的web应用加载顺序: 当tomcat的server.xml中对虚拟主机(Host)配置中autoDeploy=true和unpa

    Mysql面试题详解

    参考文章: 史上最详细的一线大厂Mysql面试题详解 https://juejin.im/post/5cb6c4ef51882532b70e6ff0 MySQL 面试之必会知识点 https://www.jianshu.com/p/5052f6a454ef 企业面试题|最常问的MySQL面试题集合 https://juejin.im/entry/5b57ec015188251aa8292a69 MySQL常见问题总结 https://blog.csdn.net/derrantcm/article

    Web容器中DefaultServlet详解

    Web容器中DefaultServlet详解 https://blog.csdn.net/qq_30920821/article/details/78328608 Web容器中DefaultServlet详解一.什么是defaultServlet 我们以最熟悉的Tomcat服务器为例.我们都知道Jsp和servlet都需要web容器才能运行.但是实际上呢我们的web应用中可以没有任何servlet或者jsp(至少表面上是这样的)只需要一个web.xml,设置在servlet 3.0中,这个也可以

    不止面试02-JVM内存模型面试题详解

    第一部分:面试题 本篇文章我们将尝试回答以下问题: 描述一下jvm的内存结构 描述一下jvm的内存模型 谈一下你对常量池的理解 什么情况下会发生栈内存溢出?和内存溢出有什么不同? String str = new String("abc")创建了多少个实例? 第二部分:深入原理 ok,开始.怎们还是先讲原理,再说答案.如果时间不足,也可以直接跳到最后看答案. 本次分享我们主要围绕jvm内存结构展开,这也是java面试必考知识点之一.所以我们先来看看jvm内存结构到底是啥样子. 1. j

    史上最全web.xml配置文件元素详解

    一.web.xml配置文件常用元素及其意义预览 1 <web-app> 2 3 <!--定义了WEB应用的名字--> 4 <display-name></display-name> 5 6 <!--声明WEB应用的描述信息--> 7 <description></description> 8 9 <!--context-param元素声明应用范围内的初始化参数--> 10 <context-param&g

    web.xml配置文件元素详解

    一.web.xml配置文件常用元素及其意义 1 <web-app> 2 3 <!--定义了WEB应用的名字--> 4 <display-name></display-name> 5 6 <!--声明WEB应用的描述信息--> 7 <description></description> 8 9 <!--context-param元素声明应用范围内的初始化参数--> 10 <context-param>

    web.xml文件配置详解以及实例说明

    1.web.xml学名叫部署描述符文件,是在Servlet规范中定义的,是web应用的配置文件. 2.部署描述符文件就像所有XML文件一样,必须以一个XML头开始.这个头声明可以使用的XML版本并给出文件的字符编码.DOCYTPE声明必须立即出现在此头之后.这个声明告诉服务器适用的servlet规范的版本(如2.2或2.3)并指定管理此文件其余部分内容的语法的DTD(Document Type Definition,文档类型定义).所有部署描述符文件的顶层(根)元素为web-app.请注意,XM

    web.xml配置文件元素详解(转载)

    今天看到一篇关于web.xml配置文件元素的博文,觉得很全面,这里引用过来,方便学习和查询. http://www.cnblogs.com/hafiz/p/5715523.html 一.web.xml配置文件常用元素及其意义预览 1 <web-app> 2 3 <!--定义了WEB应用的名字--> 4 <display-name></display-name> 5 6 <!--声明WEB应用的描述信息--> 7 <description&g