Servlet/JSP面试题目

1、Servlet和GCI的区别?

答:Servlet是基于Java编写的,处于服务器进程中,它能够通过多线程方式运行service()方法,一个实例可以服务于多个请求,而且一般不会销毁;而CGI对每个请求都生产新的进程,服务完成后销毁,所以从效率上低于Servlet。

2、JSP与Servlet区别

JSP是Servlet技术的扩展,更加强调表现层的处理。Servlet和JSP最主要的不同点在于:服务器端有一个JSP容器,主要处理JSP页面请求,容器首先把JSP转成一Servlet,所有的JSP元素都会被转换为Java代码,然后编译这个Servlet类。JSP侧重于视图,Servlet主要用于控制业务逻辑。

3、JSP有那些内置对象?作用分别是什么

HttpServletRequest类的request对象:代表请求对象,主要用于接收客户端通过HTTP协议连接传输到服务端的数据

HttpServletResponse类的response对象:代表响应对象,主要用于向客户端回应发送数据。

ServletContext类的application对象:主要用于保存所有应用系统中的共有数据,它是一个共享的内置对象,即是一个容器中的多个用户共享一个application对象,只要没有关闭服务器,application一直存在。

HttpSessoin类的session对象:主要用来区分每个用户信息和会话状态。

Pagecontext类的pageContext对象:主要用来管理页面属性,代表了一个页面的上下文,pageContext对象的创建和初始化都是有容器自动完成的。

Object类的page对象:代表正在运行的JSP页面,也就是说page对象代表了JSP被编译后的Servlet。page对象只能用在当前的JSP范围之内。

ServletConfig类的config对象:代码片段配置对象,用于初始化Servlet的配置参数。

JspWriter类的out对象:主要用于向客户端输出数据。

exception对象:处理JSP文件执行时发生的错误和异常,只要在错误页面里才能使用。

4、说出JSP的6个动作指令和作用?

·jsp:include:在页面被请求的时候引入一个静态或动态的文件。
·jsp:useBean:寻求或者实例化一个JavaBean。
·jsp:setProperty:设置JavaBean的属性。
·jsp:getProperty:获取某个JavaBean的属性。
·jsp:forward:把请求转到一个新的页面(html文件、jsp文件或者一个程序段)。
·jsp:plugin:根据浏览器类型为Java插件生成object或embed标记。

5、J2EE是什么?

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

6、get和post的请求区别

1、get是从服务器上获取数据,post是向服务器传送数据。  
2、在客户端,Get方式在通过URL提交数据,数据在URL中可以看到;
      POST方式,数据放置在HTML HEADER内提交。 
3 、对于get方式,服务器端用Request.QueryString获取变量的值,
       对于post方式,服务器端用Request.Form获取提交的数据。 
4、GET方式提交的数据最多只能有1024字节,而POST则没有此限制。 	
5、安全性问题。正如在(1)中提到,使用 Get 的时候,参数会显示在地址栏上,而 Post 不会。所以,如果这些数据是中文数据而且是非敏感数据,那么使用 get;如果用户输入的数据不是中文字符而且包含敏感数据,那么还是使用 post为好。

7、session的特点有哪些?

1,不是线程安全 
2,session是轻量级, 
3,每个数据库操作都在事务中进行。 

8、session缓存的作用。

1,减少数据库的访问频率。 
2,保证缓存中的对象和数据库中的相关记录保持同步。

9、什么是servlet

是运行在web容器中的服务器端小程序。在mvc架构中控制部分。 

10、什么是servlet容器

用来管理servlet生命周期的应用程序(tomcat) 

11、如何现实servlet的单线程模式

<%@page isThreadSafe=”false”%>

12、应用服务器有哪些

BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i Application Server,jBoss,Tomcat 

13、描述Cookie和Session的作用,区别和各自的应用范围,Session工作原理

1.Cookie和Session的作用如下:   
	Cookie是网站保存在浏览器客户端的信息,也就是说保存在访客的机器里的变量,一般随着HTTP头发送到客户端.在Cookie生效之后及失效之前,客户每次发送页面请求的时候,都会把Cookie一块发送到服务器,只要我们针对它进行相应的处理,就可以改变它的值.   
    Session的中文译名叫做”会话”,其本来的含义是指有始有终的一系列动作/消息,比如用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间.  

2.Cookie和Session的区别和各自的应用范围如下:   
    1)cookie数据存放在客户的浏览器上,session数据放在服务器上.   
    2)cookie不是很安全,别人可以分析存放在本地的cookie并进行	cookie欺骗,考虑到安全应当使用session.   
    3)session会在一定时间内保存在服务器上.当访问增多,会比较占用服务器的资源,考虑到提高服务器的性能,应道使用cookie.   
    4)单个cookie保存的数据不能超过4k,很多浏览器cookie有数量限制. 
    5)将登录信息等重要信息存放为session;其他信息如果需要保留,可以放在cookie中. 

3.Session的工作原理如下:   
	session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息.当程序需要为某个客户端的请求创建一个session时,服务器首先检查这个客户端的请求里是否已包含了一个session表示(成为session id),如果已包含则说明以前已经为此客户端创建过session,服务器就按照session id把这个session检索出来使用(检索步伐哦,会新建一个),如果客户端请求不包含session id,则为此客户端创建一个session并且生成一个与此session相关联的session id,session id的值应该是一个既不会重复,又不容易被找到规律以仿造的字符串,这个session id将被在本次响应中返回给客户端保存.保存这个session id的方式可以采用cookie,这样在交互过程中浏览器可以自动的按照规则把这个标识发送给服务器.一般这个cookie的名字都是类似于session id.但cookie可以被人为的禁止,则必须有其他机制以便在cookie被禁止时仍然能够把session id传递回服务器.

14、四种会话跟踪技术。

Cookie Session Hidden url 重写

15、什么是Web应用程序?

Web应用程序是对Web或者是应用服务器的动态扩展。
有两种类型的Web应用:面向表现的和面向服务的。
面向表现的Web应用程序会产生包含了很多种标记语言和动态内容的交互的web页面作为对请求的响应。
而面向服务的Web应用实现了Web服务的端点(endpoint)。一般来说,一个Web应用可以看成是一组安装在服务器URL名称空间的特定子集下面的Servlet的集合。

16、什么是服务端包含(Server Side Include)?

服务端包含(SSI)是一种简单的解释型服务端脚本语言,大多数时候仅用在Web上,用servlet标签嵌入进来。SSI最常用的场景把一个或多个文件包含到Web服务器的一个Web页面中。当浏览器访问Web页面的时候,Web服务器会用对应的servlet产生的文本来替换Web页面中的servlet标签。

17、什么是Servlet链(Servlet Chaining)?

Servlet链是把一个Servlet的输出发送给另一个Servlet的方法。第二个Servlet的输出可以发送给第三个Servlet,依次类推。链条上最后一个Servlet负责把响应发送给客户端。

18、servlet的生命周期:

1.加载和实例化
      
	Servlet容器负责加载和实例化Servlet。当Servlet容器启动时,或者在容器检测到需要这个Servlet来响应第一个请求时,创建Servlet实例。当Servlet容器启动后,它必须要知道所需的Servlet类在什么位置,Servlet容器可以从本地文件系统、远程文件系统或者其他的网络服务中通过类加载器加载Servlet类,成功加载后,容器创建Servlet的实例。因为容器是通过Java的反射API来创建Servlet实例,调用的是Servlet的默认构造方法(即不带参数的构造方法),所以我们在编写Servlet类的时候,不应该提供带参数的构造方法。 

    
2.初始化
     	 
	在Servlet实例化之后,容器将调用Servlet的init()方法初始化这个对象。初始化的目的是为了让Servlet对象在处理客户端请求前完成一些初始化的工作,如建立数据库的连接,获取配置信息等。对于每一个Servlet实例,init()方法只被调用一次。在初始化期间,Servlet实例可以使用容器为它准备的ServletConfig对象从Web应用程序的配置信息(在web.xml中配置)中获取初始化的参数信息。在初始化期间,如果发生错误,Servlet实例可以抛出ServletException异常或者UnavailableException异常来通知容器。ServletException异常用于指明一般的初始化失败,例如没有找到初始化参数;而UnavailableException异常用于通知容器该Servlet实例不可用。例如,数据库服务器没有启动,数据库连接无法建立,Servlet就可以抛出UnavailableException异常向容器指出它暂时或永久不可用。
 	
    
3.请求处理
     	  
	Servlet容器调用Servlet的service()方法对请求进行处理。要注意的是,在service()方法调用之前,init()方法必须成功执行。在service()方法中,Servlet实例通过ServletRequest对象得到客户端的相关信息和请求信息,在对请求进行处理后,调用ServletResponse对象的方法设置响应信息。在service()方法执行期间,如果发生错误,Servlet实例可以抛出ServletException异常或者UnavailableException异常。如果UnavailableException异常指示了该实例永久不可用,Servlet容器将调用实例的destroy()方法,释放该实例。此后对该实例的任何请求,都将收到容器发送的HTTP 404(请求的资源不可用)响应。如果UnavailableException异常指示了该实例暂时不可用,那么在暂时不可用的时间段内,对该实例的任何请求,都将收到容器发送的HTTP 503(服务器暂时忙,不能处理请求)响应。
     	
4.服务终止
     	  
	当容器检测到一个Servlet实例应该从服务中被移除的时候,容器就会调用实例的destroy()方法,以便让该实例可以释放它所使用的资源,保存数据到持久存储设备中。当需要释放内存或者容器关闭时,容器就会调用Servlet实例的destroy()方法。在destroy()方法调用之后,容器会释放这个Servlet实例,该实例随后会被Java的垃圾收集器所回收。如果再次需要这个Servlet处理请求,Servlet容器会创建一个新的Servlet实例。在整个Servlet的生命周期过程中,创建Servlet实例、调用实例的init()和destroy()方法都只进行一次,当初始化完成后,Servlet容器会将该实例保存在内存中,通过调用它的service()方法,为接收到的请求服务。

19、Servlet体系结构图
体系结构图在这里插入图片描述

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值