下面是我整理下来的Servlet知识点:html
图上的知识点均可以在我其余的文章内找到相应内容。web
Tomcat常见面试题
Tomcat的缺省端口是多少,怎么修改
Tomcat的缺省端口是多少,怎么修改面试
- 找到Tomcat目录下的conf文件夹
- 进入conf文件夹里面找到server.xml文件
- 打开server.xml文件
- 在server.xml文件里面找到下列信息
<Service name="Catalina">
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
复制代码
- 把port=”8080″改为port=”8888″,而且保存
- 启动Tomcat,而且在IE浏览器里面的地址栏输入http://127.0.0.1:8888/
到tomcat主目录下的conf/server.xml文件中修改,把8080端口改为是8088或者是其余的 apache
Tomcat 有哪几种Connector 运行模式(优化)?
tomcat 有哪几种Connector 运行模式(优化)?跨域
- bio(blocking I/O)
- nio(non-blocking I/O)
- apr(Apache Portable Runtime/Apache可移植运行库)
相关解释:数组
- bio: 传统的Java I/O操做,同步且阻塞IO。
- nio: JDK1.4开始支持,同步阻塞或同步非阻塞IO
- aio(nio.2): JDK7开始支持,异步非阻塞IO
- apr: Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态连接库来处理文件读取或网络传输操做,从而大大地 提升Tomcat对静态文件的处理性能
下面是配置Tomcat运行模式改为是NIO模式,并配置链接池相关参数来进行优化:浏览器
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" connectionTimeout="20000" redirectPort="8443 maxThreads=“500” minSpareThreads=“100” maxSpareThreads=“200” acceptCount="200" enableLookups="false" />
复制代码
apr模式启动起来是比较复杂的,详情可参考:blog.csdn.net/wanglei_sto…tomcat
对于bio,nio,nio.2的理解可参考:blog.csdn.net/itismelzp/a…安全
Tomcat有几种部署方式
- 直接把Web项目放在webapps下,Tomcat会自动将其部署
- 在server.xml文件上配置
<Context>
节点,设置相关的属性便可
- 经过Catalina来进行配置:进入到conf\Catalina\localhost文件下,建立一个xml文件,该文件的名字就是站点的名字。编写XML的方式来进行设置。
部署方式第二点:
- 在其余盘符下建立一个web站点目录,并建立WEB-INF目录和一个html文件。
- 找到Tomcat目录下/conf/server.xml文件
- 在server.xml中的节点下添加以下代码。path表示的是访问时输入的web项目名,docBase表示的是站点目录的绝对路径
<Context path="/web1" docBase="D:\web1"/>
复制代码
部署方式第三点:
<?xml version="1.0" encoding="UTF-8"?>
<Context
docBase="D:\web1"
reloadable="true">
</Context>
复制代码
Servlet面试题
Servlet生命周期
Servlet生命周期?
- 第一次访问Servlet,咱们发现init()和service()都被调用了
- 第二次访问Servlet,service()被调用了
- 第三次访问Servlet,仍是service()被调用了
- 当咱们关闭Tomcat服务器的时候,destroy()被调用了!
Servlet生命周期可分为5个步骤
- 加载Servlet。当Tomcat第一次访问Servlet的时候,Tomcat会负责建立Servlet的实例
- 初始化。当Servlet被实例化后,Tomcat会调用init()方法初始化这个对象
- 处理服务。当浏览器访问Servlet的时候,Servlet 会调用service()方法处理请求
- 销毁。当Tomcat关闭时或者检测到Servlet要从Tomcat删除的时候会自动调用destroy()方法,让该实例释放掉所占的资源。一个Servlet若是长时间不被使用的话,也会被Tomcat自动销毁
- 卸载。当Servlet调用完destroy()方法后,等待垃圾回收。若是有须要再次使用这个Servlet,会从新调用init()方法进行初始化操做。
- 简单总结:只要访问Servlet,service()就会被调用。init()只有第一次访问Servlet的时候才会被调用。destroy()只有在Tomcat关闭的时候才会被调用。
get方式和post方式有何区别
get方式和post方式有何区别
数据携带上:
- GET方式:在URL地址后附带的参数是有限制的,其数据容量一般不能超过1K。
- POST方式:能够在请求的实体内容中向服务器发送数据,传送的数据量无限制。
请求参数的位置上:
- GET方式:请求参数放在URL地址后面,以?的方式来进行拼接
- POST方式:请求参数放在HTTP请求包中
用途上:
- GET方式通常用来获取数据
- POST方式通常用来提交数据
- 缘由:
- 首先是由于GET方式携带的数据量比较小,没法带过去很大的数量
- POST方式提交的参数后台更加容易解析(使用POST方式提交的中文数据,后台也更加容易解决)
- GET方式比POST方式要快 GET方式比POST方式要快,详情可看:www.cnblogs.com/strayling/p…
Servlet相关 API
doGet与doPost方法的两个参数是什么
- HttpServletRequest:封装了与请求相关的信息
- HttpServletResponse:封装了与响应相关的信息
获取页面的元素的值有几种方式,分别说一下
- request.getParameter() 返回客户端的请求参数的值
- request.getParameterNames() 返回全部可用属性名的枚举
- request.getParameterValues() 返回包含参数的全部值的数组
request.getAttribute()和request.getParameter()区别
用途上:
- request.getAttribute(), 通常用于获取request域对象的数据(在跳转以前把数据使用setAttribute来放到request对象上)
- request.getParameter(), 通常用于获取客户端提交的参数
存储数据上:
- request.getAttribute()能够获取Objcet对象
- request.getParameter()只能获取字符串(这也是为何它通常用于获取客户端提交的参数)
forward和redirect的区别
forward和redirect的区别
- 实际发生位置不一样,地址栏不一样
- 转发是发生在服务器的
- 转发是由服务器进行跳转的,细心的朋友会发现,在转发的时候,浏览器的地址栏是没有发生变化的,在我访问Servlet111的时候,即便跳转到了Servlet222的页面,浏览器的地址仍是Servlet111的。也就是说浏览器是不知道该跳转的动做,转发是对浏览器透明的。经过上面的转发时序图咱们也能够发现,实现转发只是一次的http请求,一次转发中request和response对象都是同一个。这也解释了,为何可使用request做为域对象进行Servlet之间的通信。
- 重定向是发生在浏览器的
- 重定向是由浏览器进行跳转的,进行重定向跳转的时候,浏览器的地址会发生变化的。曾经介绍过:实现重定向的原理是由response的状态码和Location头组合而实现的。这是由浏览器进行的页面跳转实现重定向会发出两个http请求,request域对象是无效的,由于它不是同一个request对象
- 用法不一样:
- 不少人都搞不清楚转发和重定向的时候,资源地址究竟怎么写。有的时候要把应用名写上,有的时候不用把应用名写上。很容易把人搞晕。记住一个原则: 给服务器用的直接从资源名开始写,给浏览器用的要把应用名写上
- request.getRequestDispatcher("/资源名 URI").forward(request,response)
- 转发时"/"表明的是本应用程序的根目录【zhongfucheng】
- response.send("/web应用/资源名 URI");
- 可以去往的URL的范围不同:
- 转发是服务器跳转只能去往当前web应用的资源
- 重定向是服务器跳转,能够去往任何的资源
- 传递数据的类型不一样
- 转发的request对象能够传递各类类型的数据,包括对象
- 重定向只能传递字符串
- 跳转的时间不一样
- 转发时:执行到跳转语句时就会马上跳转
- 重定向:整个页面执行完以后才执行跳转
那么转发(forward)和重定向(redirect)使用哪个?
- 根据上面说明了转发和重定向的区别也能够很容易归纳出来。转发是带着转发前的请求的参数的。重定向是新的请求。
典型的应用场景:
- 转发: 访问 Servlet 处理业务逻辑,而后 forward 到 jsp 显示处理结果,浏览器里 URL 不变
- 重定向: 提交表单,处理成功后 redirect 到另外一个 jsp,防止表单重复提交,浏览器里 URL 变了
tomcat容器是如何建立servlet类实例?用到了什么原理?
tomcat容器是如何建立servlet类实例?用到了什么原理
- 当容器启动时,会读取在webapps目录下全部的web应用中的web.xml文件,而后对 xml文件进行解析,并读取servlet注册信息。而后,将每一个应用中注册的servlet类都进行加载,并经过 反射的方式实例化。(有时候也是在第一次请求时实例化)
- 在servlet注册时加上1若是为正数,则在一开始就实例化,若是不写或为负数,则第一次请求实例化。
什么是cookie?Session和cookie有什么区别 ?
什么是cookie?
Cookie是由W3C组织提出,最先由netscape社区发展的一种机制
- 网页之间的交互是经过HTTP协议传输数据的,而Http协议是无状态的协议。无状态的协议是什么意思呢?一旦数据提交完后,浏览器和服务器的链接就会关闭,再次交互的时候须要从新创建新的链接。
- 服务器没法确认用户的信息,因而乎,W3C就提出了:给每个用户都发一个通行证,不管谁访问的时候都须要携带通行证,这样服务器就能够从通行证上确认用户的信息。通行证就是Cookie
Session和cookie有什么区别?
-
从存储方式上比较
- Cookie只能存储字符串,若是要存储非ASCII字符串还要对其编码。
- Session能够存储任何类型的数据,能够把Session当作是一个容器
-
从隐私安全上比较
- Cookie存储在浏览器中,对客户端是可见的。信息容易泄露出去。若是使用Cookie,最好将Cookie加密
- Session存储在服务器上,对客户端是透明的。不存在敏感信息泄露问题。
-
从有效期上比较
- Cookie保存在硬盘中,只须要设置maxAge属性为比较大的正整数,即便关闭浏览器,Cookie仍是存在的
- Session的保存在服务器中,设置maxInactiveInterval属性值来肯定Session的有效期。而且Session依赖于名为JSESSIONID的Cookie,该Cookie默认的maxAge属性为-1。若是关闭了浏览器,该Session虽然没有从服务器中消亡,但也就失效了。
-
从对服务器的负担比较
- Session是保存在服务器的,每一个用户都会产生一个Session,若是是并发访问的用户很是多,是不能使用Session的,Session会消耗大量的内存。
- Cookie是保存在客户端的。不占用服务器的资源。像baidu、Sina这样的大型网站,通常都是使用Cookie来进行会话跟踪。
-
从浏览器的支持上比较
- 若是浏览器禁用了Cookie,那么Cookie是无用的了!
- 若是浏览器禁用了Cookie,Session能够经过URL地址重写来进行会话跟踪。
-
从跨域名上比较
- Cookie能够设置domain属性来实现跨域名
- Session只在当前的域名内有效,不可夸域名
Servlet安全性问题
因为Servlet是单例的,当多个用户访问Servlet的时候,服务器会为每一个用户建立一个线程。当多个用户并发访问Servlet共享资源的时候就会出现线程安全问题。
原则:
- 若是一个变量须要多个用户共享,则应当在访问该变量的时候,加同步机制synchronized (对象){}
- 若是一个变量不须要共享,则直接在 doGet() 或者 doPost()定义.这样不会存在线程安全问题
若是文章有错的地方欢迎指正,你们互相交流。习惯在微信看技术文章的同窗,能够关注微信公众号:Java3y