JAVA企业面试题精选 Servlet和JSP 1-10

2.Servlet和JSP

2.1.什么是B/S结构?什么是C/S结构?

参考答案:

  B/S是Browser/Server的缩写,客户机上只要安装一个浏览器(Browser),如Netscape Navigator或Internet Explorer,服务器安装Oracle,Sybase,Informix或SQL Server等数据库.在这种结构下,用户界面完全通过WWW浏览器实现,一部分事务逻辑在前端实现,但是主要事务逻辑在服务器端实现.浏览器通过Web Server同数据库进行数据交互.
  C/S是Client/Server的缩写.服务器通常采用高性能的PC,工作站或小型机,并采用大型数据库系统,如Oracle,Sybase,Informix或SQLServer.客户端需要安装专用的客户端软件.

2.2.J2EE是什么?

参考答案:

  J2EE是Sun公司提出的多层(multi-diered),分布式(distributed),基于组件(component-base)的企业级应用模型(enterprise application model).在这样的一个应用系统中,可按照功能划分为不同的组件,这些组件又可在不同计算机上,并且处于相应的层次(tier)中.所属层次包括客户层(client tier)组件,web层组件,business层组件以及企业信息系统(EIS)层.

2.3.J2EE是技术是平台还是框架?

参考答案:

  J2EE本身是一个标准,一个为企业分布式应用开发提供的标准平台;J2EE也是一个框架,包括JDBC,JNDI,RMI,JMS,EJB,JTA等技术.

2.4.请对以下在J2EE中常用的名词进行解释(或简单描述)

1)JNDI
2)JMS
3)JTA
4)JAF
5)RMI
参考答案:

  1)JNDI:(Java Naming & Directory Interface)Java命名目录服务.主要提供的功能是:提供一个目录系统,让其他各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能;
  2)JMS:(Java Message Service)Java消息服务.主要实现各个应用程序之间的通讯,包括点对点广播;
  3)JTA:(Java Transaction API)Java事务服务.提供各种分布式事务服务,应用程序只需调用其提供的接口即可;
  4)JAF:(Java Action Framework)Java安全认证框架.提供一些安全控制方面的框架,让开发者通过各种部署和自定义实现自己的个性安全控制策略;
  5)RMI:(Remote Method Invocation/Internet对象请求中介协议)他们主要用于通过远程调用服务.例如,远程有一台计算机上运行一个程序,它提供股票分析服务,我们可以在本地计算机上实现对其直接调用.当然这是要通过一定的规范才能在异构的系统之间进行通信.RMI是Java特有的.

2.5.在JavaEE中,数据连接池的工作机制是什么?

参考答案:

  JavaEE服务器启动时会建立一定数量的池连接,并一直维持不少于此数目的池连接.客户端程序需要连接时,池驱动程序会返回一个未使用的池连接并将其标记为忙.如果当前没有空闲连接,池驱动程序就新建一定数量的连接,新建连接的数量由配置参数决定.当使用的池连接调用完成后,池驱动程序将次连接标记为空闲,其他调用就可以使用这个连接.

2.6.什么是web容器,其作用是?尽可能写出你知道的容器名称

参考答案:

  web容器给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,是JSP,SERVLET直接跟容器中的环境变量接口交互,不必关注其它系统问题.例如:TOMCAT,WEBLOGIC,WEBSPHERE等都为web容器.

2.7.简述什么是HTTP协议

参考答案:

  HTTP协议是HyperText Transfer Protocol的简写,它是由W3C(万维网联盟)制定的一种应用层协议,用来定义浏览器与web服务器之间如何通信以及通信的数据格式.

2.8.Servlet是什么?谈谈你的理解

参考答案:

  Servlet是一种服务器端的Java应用程序,具有独立于平台和协议的特性,可以生成动态的Web页面.它担当客户请求(Web浏览器或其他HTTP客户程序)与服务器响应(HTTP服务器上的数据库或应用程序)的中间层.与传统的从命令行启动的Java应用程序不同,Servlet由Web服务器进行加载,该Web服务器必须包含支持Servlet的Java虚拟机.

2.9.请简述Servlet工作原理

参考答案:

  Servlet是运行在Servlet容器中的,由Servlet容器来负责Servlet实例的查找,创建以及整个生命周期的管理,Servlet整个生命周期可以分为四个阶段:类装载及实例创建阶段,实例化初始阶段,服务阶段以及实例销毁阶段.
  1)类装载及实例创建阶段:
  默认情况下,Servlet实例是在接受到第一个请求时进行创建并且以后的请求进行复用,如果有Servlet实例需要进行一些复杂的操作,需要在初始化时就完成,比如打开文件,初始化网络连接等,可以配置在服务器启动时就创建实例,具体配置方法为在生命Servlet标签中添加`1标签.
  2)初始化init(ServletConfig config);
  一旦Servlet实例被创建,将会调用Servlet的init方法,同时传入ServletConfig实例,传入Servlet的相关配置信息,init方法在整个Servlet生命周期中只会调用一次.
  3)服务service():
  为了提高效率,Servlet规范要求一个Servlet实例必须能够同时服务于多个客户端请求,即service()方法运行在多线程的环境下,Servlet开发者必须保证该方法的线程安全性.
  4)销毁destory():
  当Servlet容器将决定结束某个servlet时,将会调用destory()方法,在destory方法中进行资源释放,一旦destory方法被调用,Servlet容器将不会再发送任何请求给这个实例,若Servlet容器需再次使用该Servlet,需重新再实例化该Servlet实例.

2.10.简述如何处理表单提交的中文

参考答案:

  处理表单提交的中文,分为两种情况,一是post方式提交表单,一是get方式提交表单.
  1.处理post方式提交表单时的中文,步骤如下:
  step1:确保表单所在的页面按照指定的字符集打开,在HTML中设置如下:

<meta http-equiv="content-type" content="text/html; charset=UTF-8">

  另外,在HTML中,将表单form的提交方式设置为post.
  step2:在服务器端按照上述设置的编码格式进行解码,代码如下:

request.setCharacterEncoding("UTF-8");

  该行代码要在第一次使用request的时候进行设置.
  2.处理get方式提交表单时的中文,步骤如下:
  step1:使用meta确保表单所在页面按指定字符集打开,在HTML中设置如下:

<meta http-equiv="content-type" content="text/html; charset=UTF-8">

  另外,在HTML中,将表单form的提交方式设置为get.
  step2:将从表单中获取的信息使用上述设置的字符集UTF-8进行重新编码.
  例如:将从表单获取的username进行重新编码,代码如下:

String username = request.getParameter("username");
username = new String(username.getBytes("ISO-8859-1"),"UTF-8");
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
常考面试题 1.讲下servlet的执行流程。 Servlet的执行流程也就是servlet的生命周期,当服务器启动的时候生命周期开始,然后通过init()《启动顺序根据web.xml里的startup-on-load来确定加载顺序》 方法初始化servlet,再根据不同请求调用doGet或doPost方法,最后再通过destroy()方法进行销毁。 2.Get和Post的区别 在页面提交数据时,get的数据大小有限制4k,post没有限制,get请求提交的数据会在地址栏显示,post不显示,所以post比get安全. 3.有三台服务器,如果在一台服务器上登陆了这个用户,其他两台就不能再登陆这个用户,使用session共享,你是怎么做的。 把所有的session的数据保存到Mysql服务器上,所有Web服务器都来这台Mysql服务器来获取Session数据。 4.写一个自定义标签要继承什么类 SimpleTagSupport,一般调用doTag方法 或者实现SimpleTag接口 5.Jsp如何处理json 在 jsp 中处理 JSON,通常需要配套使用 JQuery 控件,并且导入一些 Common jar 包。 使用 JQuery 控件是因为它能有效的解析并且展示 JSON 数据, 导入Common 则是因为 Java 中的对象并不是纯粹的数据,需要通过这些 Jar 包的处理使之转化成真实数据。 6.如何处理Servlet的线程不安全问题 1.最简单的就是不使用字段变量, 2.使用final修饰变量, 3.线程安全就是多线程操作同一个对象不会有问题,线程同步一般来保护线程安全, 所以可以在Servlet的线程里面加上同步方法或同步块。 (Synchronized)可以保证在同一时间只有一个线程访问,(使用同步块会导致性能变差,最好不去使用实例变量) 7.Jsp的重定向和转发的流程有什么区别 重定向是客户端行为,转发是服务器端行为 重定向时服务器产生两次请求,转发产生一次请求,重定向时可以转发到项目以外的任何网址,转发只能在当前项目里转发 重定向会导致request对象信息丢失。转发则不会 转发的url不会变,request.getRequestDispatch().forward() 重定向的url会改变,response.getRedirect().sendRedirect();

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值