2.2.1 讲一下http get和post请求的区别
get和post请求都是http的请求方式,用户通过不同的http请求方式完成对资源(url)的不同操作,具体点来讲get一般用于获取/查询资源信息,而post一般用于更新资源信息。
http定义了与服务器交互的不同方法,最基本的方法有4种,分别是get,post,put,delete,url全称是资源描述符,我们可以这样认为:一个URL地址,它用于描述一个网络上的资源,而http中的get,post,put,delete就是对应着这个资源的查,改,增,删4个操作,具体点get一般用于获取/查询资源信息,而post一般用于更新资源信息。
1)get请求提交的数据会在地址栏显示出来,而post请求不会在地址栏显示出来。
get提交请求的数据会附在URL之后(就是把数据放置在http协议头中)以?分割url和传输数据,多个参数用&连接;post提交:把提交的数据放置的是在http包的包体中,因此,get提交的数据会在地址栏中显示出来,而post提交,地址栏不会改变。
2)传输数据的大小
http get请求由于浏览器对地址长度的限制而导致传输的数据有限制,而post请求不会因为地址长度限制而导致传输数据限制。
3)安全性,post的安全性要比get的安全性高,由于数据是会在地址中呈现,所以安全性可以历史记录找到密码相关等信息。
2.2.2 讲一下你对servlet的理解?或者servlet是什么?
servlet(servlet applet),全称java servlet,是用java编写的服务端程序,而这些Servlet都要实现Servlet这个接口,其主要功能在于交互式地浏览和修改数据,生成动态web内容,servlet运行于支持java的应用服务器中。
httpservlet重写doGet和doPost方法或者你也可以重写service方法完成对get和post请求的响应。
2.2.3 简单说一下servlet的生命周期?
servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束,这个生存期由java servlet Servlet接口的init,service,destory方法表达。
Servlet启动时,开始加载Servlet生命周期开始,servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对其的doxxx方法(doGet,doPost)等,当服务器决定将实例化销毁的时候(服务器关闭)调用其destory方法
加载Servlet的class-->实例化Servlet的init完成初始化-->响应请求(Servlet的service方法)-->Servlet容器关闭时(Servlet的destory方法)
init只运行一次
2.2.4 Servlet API中forward()与redirect()的区别?
前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;
后者则是完全的链接,浏览器(客户端)将会得到跳转的链接,并重新发送请求链接。
forward还是原来的请求而rediect是重新发起请求。这样,从浏览器的地址栏中可以看出跳转后的链接地址,所以前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且这样有助于隐藏实际的链接,在有些情况下,比如,需要跳转到一个其他服务器上的资源则必须使用sendRedirect()方法。
1)forward是服务器请求的转向而rediect是客户端的跳转。
2)使用forward浏览器的地址不会发生改变,而redrect会发生改变。
3)forward是一次请求中完成,而redrect是重新发起请求。
3)forward是在服务器端完成,而不用客户端重新发起请求,效率高。
2.2.5 JSP和Servlet有哪些相同点和不同点,它们之间的联系是什么?
JSP是Servlet的扩展。所有的jsp文件都会被翻译为一个继承httpServlet的类,也就是说jsp最终也是一个Servlet,这个servlet对外提供服务。
Servlet和JSP最主要的不同点在于,Servlet如果要实现html的功能,必须使用Writer输出对应的html比较麻烦,Servlet的应用逻辑是在java文件,并完全从表示层中的html分离出来,而jsp的情况是Java和HTML可以组合成一个扩展名为.jsp文件比较方便而嵌入逻辑比较复杂,jsp侧重视图,Servlet主要用于控制逻辑。
2.2.6 jsp有哪些内置对象?作用分别是什么?
9个内置的对象:
request 用户请求,此请求会包含来自get/post请求的参数
response 网页传回用户端的回应
pageContext 网页的属性是在这里管理
session 与请求有关的会话棋
application servlet正在执行的内容
out 用来传送回应的输出
config servlet 的构架部件
page jsp网页本身
exception 针对错误网页,未捕抓的例外
四大作用域:pageContext,request,session,application可以通过jstl从四大作用域中取值
jsp传递值request,session,application,cookie也能传值
2.2.7 说一下session和cookie的区别?你在项目中都有哪些地方使用了
Session和cookie都是会话跟踪技术,cookie通过客户端记录信息确定用户身份,session通过在服务端确定用户身份,但是session的实现依赖于cookie,sessionId(session的唯一标识需要存放在客户端)
cokike和session的区别
1)cookie数据存放在客户的浏览器上,session数据存放在服务器上。
2)cookie不是很安全,别人可以分析存放本地的cookie并进行cookie欺骗,考虑到安全性应当使用session
3)session会在一定时间内保存在服务器上,当访问增多,会比较占用你服务器的性能考虑到减轻服务器性能方面,应当使用cookie
4)单个cookie保存的数据不能超过4k,很多浏览器都限制一个站点最多保存20cookie
5)所以个人建议:
将登录等重要信息存放为session,其他信息如果需要保留,可以存放cookie中,比如购物车。
购物车最好使用cookie,但是cookie是可以在用户端禁用的,这时候我们要使用cookie+数据库的方式实现,当从cookie中不能取出数据时,就从数据库获取
2.2.8 mvc的各部分都有哪些技术来实现
M(Model)模型 javaBean,hibernate,mybatis
V(View)代码视图 jsp,html,freemaker,velocity
C(Controller)控制器 Servlet,Action,struts
Jsp+Servlet+javaBean 最经典mvc模式。实际上就是model2的实现方式,就是把视图和逻辑隔离开来
model1的方式 jsp+service+dao
model2的方式 jsp+servlet+service+dao
使用struts2和springMVC这样的mvc结构后,jsp+核心控制器+action+javaBean