Servlet面试核心知识点

servlet名

/url

| | |

| — | — |

| Web请求有哪三种方式? | 地址栏、超链接、表单 |

| 如何获取表单提交的数据? | request.getParameter(“表单name属性的值”); |

如何处理get请求的乱码?

修改apache-tomcat-6.0.37\conf\server.xml文件:

为标签添加URIEncoding属性。

在这里插入图片描述

| 如何处理post请求的乱码? | request.setCharacterEncoding(“utf-8”); // 建议添加在Servlet起始的第一行 |

| — | — |

| 如何处理响应乱码? | response.setContentType(“text/html ; charset=UTF-8”); |

| Servlet的生命周期有多长? | 1.Servlet的创建:首次访问时,创建对象(单例模式)。

2.Servlet的初始化:伴随对象的创建,执行且仅执行一次Servlet对象的init()方法。

3.Servlet的销毁:服务器停止时,会调用Servlet对象的destroy()方法进行销毁。 |

| 有哪些资源访问形式? | 1.URL:在整个网络中定位一个资源,资源在网络中路径 资源访问定位符(protocol://ip:port/app/source)

http://localhost:8080/MyServlet/loginServlet —>(Servlet)

http://localhost:8080/MyServlet/login.html —>(html)

2.URI:在一台服务器中定位一个资源,资源在web项目中的路径(/app/source)

/MyServlet/loginServlet —>(Servlet)//应以/开头,否则默认添加项目名称前缀

/MyServlet/login.html —>(html)

3.url-pattern:在一个web项目中定位一个资源(/source)

loginServlet —>(Servlet)//不应以/开头

login.html —>(html) |

如何完成页面跳转?

1.转发(forward)

request.getRequestDispatcher(“url-pattern 目标资源”).forward(request,response);

一次请求,在服务器内部进行跳转,一个Action跳转到另外一个Action中去,能request作用域数据

2.重定向(redirect):

response.sendRedirect(“项目名/url-pattern 目标资源”);

两次请求,服务器内部跳转到页面,地址栏改变,只能通过地址栏传递少量(4kb)数据

| Questions | Answers |

| — | — |

| 转发和重定向各自的跳转原理是什么? | 1.转发:服务器内部完成跳转,地址栏中的访问目标不变,同属一次请求。

2.重定向:客户端中完成跳转,地址栏中的访问目标改变,分属两次请求。 |

| 如何选取跳转方式? | 1.两个Servlet之间如需传递数据时使用,选用“转发“。

2.两个Servlet之间无需传递数据时使用,选用“重定向”。 |

| 什么是Request作用域? | 1.拥有存储数据的空间(键值对的Map),作用范围是一次请求有效

(一次请求可以经过多次转发,一旦响应,则结束)。

2. 可以将数据存入request后,在一次请求过程中的任何位置进行获取。

3.可传递任何数据(基本数据类型、对象、集合、数组)。 |

| Request如何存取数据? | 1.存储:request.setAttribute(“key” , value); //key:String,value:Object

2.获取:request.getAttribute(“key”); |

| Response如何存取数据? | response没有作用域,仅能通过get请求的形式传递本文数据:

1.传数据:通过uri的拼接进行数据传递。(“/ServletPro/myServlet?username=jack”)

2.取数据:request.getParameter(“jack”); |

| 什么是Cookie? | 由服务器向客户端发送、并储存在用户本地的文本数据,可用于辨别用户身份或进行会话跟踪。 |

| Cookie的实现原理是什么? | 1.客户端首次访问服务器时,服务器会将Cookie以响应的形式发送给客户端。

2.客户端接受Cookie之后存储在本地。

3.客户端再次访问服务器时,会将曾经存储在客户端中的Cookie在请求时发回服务器。 |

| 如何创建Cookie? | Cookie ck = new Cookie(“key” , “value”); |

| 如何发送Cookie到客户端? | response.addCookie(); |

| 如何获得客户端发回的Cookie? | Cookie[] cks = request.getCookies();//获取本站发出的所有Cookie

for(Cookie ck : cks){//遍历出需要的Cookie} |

| | |

| — | — |

| 什么是Session? | 又称会话, 同一客户端与服务器建立起连接后的多次请求和响应过程。 |

| Session的实现原理是什么? | 1.当客户端首次访问服务器时,会在服务器端创建HttpSession对象,并将Session对象的ID属性值保存在Cookie中;

2.伴随响应的产生,将Cookie发送到客户端本地存储;

3.再次访问时,将带有ID的Cookie再次发给服务器,由服务器通过SessionID辨别用户。 |

| Session的生命周期多长? | 开始:第一次使用到Session的请求产生,则创建Session。 |

| | 结束:

1.浏览器关闭。

2.Session超时。session.setMaxInactiveInterval( seconds ); //设置最大存活时间

3.手工销毁,则失效。session.invalidate(); |

| 什么是Session作用域? | 1.拥有存储数据的空间(键值对的Map),作用范围是一次会话有效

(使用同一浏览器发出的多次请求,均为一次会话,一旦关闭浏览器,则结束)。

2. 可以将数据存入session后,在一次会话过程中的任何位置进行获取。

3.可传递任何数据(基本数据类型、对象、集合、数组)。 |

| Session如何存取数据? | 1.存储:session.setAttribute(“key” , value); //key:String,value:Object

2.获取:session.getAttribute(“key”); |

| URL重写解决的什么问题? | Cookie被禁用的话,无法保存JSESSIONID,也就无法找到原有的Session对象。

因此,需要使用response.encodeURL(“url”); 完成重写,默认拼接jsessionid字符串。 |

| 什么是ServletContext? | 全局对象,拥有作用域,对应一个Tomcat中的Web应用,伴随Web启动而创建,Web停止而销毁。 |

| Request、Session、ServletConext作用域的区别? | 1.HttpServletRequest:一次请求开始,响应之前有效。

2.ServletSession:一次会话开始,浏览器不关(不超时)之前有效。

3.ServletContext:服务器启动开始,服务器停止之前有效。 |

什么是Filter?

与Servlet类似,执行地位在Servlet之前。

请求时,会先经过Filter再经过Servlet中;

响应时,会根据执行流程再次反向执行Filter,再到达客户端

如何定义Filter?

public UrlFilter implements Filter{

//doFilter核心拦截方法

public void doFilter (ServletRequest request,ServletResponse response,FilterChain chain){

//允许调用链继续

chain.doFilter(request,response);

}

}

如何在web.xml中书写Filter对应的标签结构?


自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

虽然面试套路众多,但对于技术面试来说,主要还是考察一个人的技术能力和沟通能力。不同类型的面试官根据自身的理解问的问题也不尽相同,没有规律可循。

上面提到的关于这些JAVA基础、三大框架、项目经验、并发编程、JVM及调优、网络、设计模式、spring+mybatis源码解读、Mysql调优、分布式监控、消息队列、分布式存储等等面试题笔记及资料

有些面试官喜欢问自己擅长的问题,比如在实际编程中遇到的或者他自己一直在琢磨的这方面的问题,还有些面试官,尤其是大厂的比如 BAT 的面试官喜欢问面试者认为自己擅长的,然后通过提问的方式深挖细节,刨根到底。
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
、项目经验、并发编程、JVM及调优、网络、设计模式、spring+mybatis源码解读、Mysql调优、分布式监控、消息队列、分布式存储等等面试题笔记及资料**

有些面试官喜欢问自己擅长的问题,比如在实际编程中遇到的或者他自己一直在琢磨的这方面的问题,还有些面试官,尤其是大厂的比如 BAT 的面试官喜欢问面试者认为自己擅长的,然后通过提问的方式深挖细节,刨根到底。
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

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

余额充值