图上的知识点都可以在我其他的文章内找到相应内容。

Tomcat常见面试题

Tomcat的缺省端口是多少,怎么修正

Tomcat的缺省端口是多少,怎么修正

jsp提交表单面试TomcatServlet面试题都在这里修订版 Angular

找到Tomcat目录下的conf文件夹进入conf文件夹里面找到server.xml文件打开server.xml文件在server.xml文件里面找到下列信息

把port=”8080″改成port=”8888″,并且保存启动Tomcat,并且在IE浏览器里面的地址栏输入http://127.0.0.1:8888/

到tomcat主目录下的conf/server.xml文件中修正,把8080端口改成是8088或者是其他的

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开始支持,同步壅塞或同步非壅塞IOaio(nio.2): JDK7开始支持,异步非壅塞IOapr: Tomcat将以JNI的形式调用Apache HTTP做事器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能

下面是配置Tomcat运行模式改成是NIO模式,并配置连接池干系参数来进行优化:

apr模式启动起来是比较繁芜的,详情可参考:http://blog.csdn.net/wanglei_storage/article/details/50225779

对付bio,nio,nio.2的理解可参考:http://blog.csdn.net/itismelzp/article/details/50886009

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\"大众/>

访问配置好的web站点

支配办法第三点:

进入到conf\Catalina\localhost文件下,创建一个xml文件,该文件的名字便是站点的名字。

xml文件的代码如下,docBase是你web站点的绝对路径

访问web站点下的html资源

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办法要快,详情可看:https://www.cnblogs.com/strayling/p/3580048.html缘故原由:

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\"大众); - 重定向时\"大众/\公众代表的是webapps目录能够去往的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()定义.这样不会存在线程安全问题

原文地址:https://dwz.cn/BodwLMYa作者:Java3y