jsp 和 servlet 相关面试题

1.servlet 生命周期描述?

    首先,Servlet运行在容器中,其生命周期由容器来管理。

    初始化:在服务器启动时,Web容器加载servlet,调用执行 一次 init()方法
    处理请求:当请求到达时,运行其service()方法。service()自动派遣运行与请求相对应的doGet或者doPost方法。

    销毁:在服务器端停止且卸载Servlet时,web容器会仅调用执行 一次 servlet的distroy()方法销毁servlet。

2.JSP与Servlet有什么区别?

    不同点:

    1.servlet更擅长于逻辑控制,jsp更擅长表现于页面显示。
    2.Servlet中没有内置对象,Jsp中的内置对象都是必须通过HttpServletRequest对象,HttpServletResponse对象以及HttpServlet对象得到

    3.jsp经编译后就变成了Servlet,jsp 本质 是 servlet。

3.forward() 与sendRedirect()的区别?

    都是servlet种的两种主要的跳转方式。forward又叫转发,redirect叫做重定向

    有以下不同:
a.数据共享: 
forward: 转发页面和 转发到的页面  可以共享request里面的数据
redirect:不能共享数据.
b.地址栏显示:
forward  是服务器内部完成,地址栏还是原来的地址,没有变化。
redirect 是服务端让浏览器重新去请求那个地址.地址栏显示的是真实的新URL
c.请求情况:
forward: 转发产生一次请求,转发只能在当前项目内部转发
redirect: 产生两次请求,可以转发到项目以外的任何网址
d.使用场景:
forward:主要用于用户登陆的时候,根据角色转发到相应的模块。

redirect:主要 用于用户注销登陆时返回主页面或者跳转到其它的网站等。

4.get 和post 请求区别:

    1.get 参数通过URL 传递,大小有限制,post 参数通过request body 的form 表单提交,数据量无限制。

    2.get 请求不安全,post相对安全点。

    3.get 只能是文本数据, post 可以文本数据,也可以二进制文件。

5.session与cookie的区别?

    1.Cookie和Session都是会话技术,cookie数据存放在客户的浏览器上,session数据放在服务器上。

    2.cookie不是很安全,基于安全考虑应当使用session

    3.Cookie有大小限制以及浏览器在存cookie的个数也有限制,Session是没有大小限制和服务器的内存大小有关。

6.四种会话跟踪技术

java中会话跟踪常用的方法:cookie,session,url重写,隐藏域。

page域  数据在一个页面范围内有效,通过pageContext对象访问

request域 数据在一个服务器请求范围内有效,通过request对象访问

session域 数据在一次会话范围内容有效,通过session对象访问

application域 数据在一个应用服务器范围内有效,通过application对象访问


7. Jsp的九大内置对象,三大指令,七大动作?

内置对象:

request         包含用户端请求的信息
response         包含服务器传回客户端的响应信息
session         与请求有关的会话期
pageContext 管理网页属性
application         服务器启动时创建,服务器关闭时停止,为多个应用程序保存信息
out                 向客户端输出数据
config         servlet的架构部件
page                 指网页本身

exception         针对错误页面才可使用

三大指令:
Page :        指令是针对当前页面的指令 
Include :    用于指定如何包含另一个页面 

Taglib :      用于定义和指定自定义标签

七大动作:

Forward,执行页面跳转,将请求的处理转发到另一个页面 
Param :用于传递参数 
Include :用于动态引入一个jsp页面 

Plugin :用于下载javaBean或applet到客户端执行 

useBean :使用javaBean 

setProperty :修改javaBean实例的属性值 

getProperty :获取javaBean实例的属性值

8.过滤器,拦截器,监听器 作用?

a.启动加载顺序:监听器>过滤器>拦截器

b.过滤器和拦截器差异:

过滤器Filter             依赖于Servlet容器,基于回调函数,过滤范围大。

拦截器Interceptor     依赖于框架容器,    基于反射机制,只过滤请求。

c.三者主要用途:

监听器:
用途:
1、统计在线人数和在线用户
2、系统启动时加载初始化信息
3、统计网站访问量
4、记录用户访问路径
5、跟Spring结合
过滤器:
用途:
1、过滤字符编码
2、业务逻辑判断
3、用户是否已经登陆
4、有没有权限访问该页面
拦截器:
在面向切面编程AOP 中应用的
用途:
1.用户权限验证



感觉 过滤器 和拦截器好像不是很明晰,似乎有些事过滤器和拦截器都可以做。

    




常考面试题 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、付费专栏及课程。

余额充值