本篇接上一篇《Tomcat详细用法学习(一)》,主要讲解服务器的虚拟目录映射的几种方式。
先来看几个概念:
web应用的概念:一个web应用包含了许多我们做好的web资源,里面或许包括了多个静态web资源和动态web资源,如html、css、js文件,jsp文件,Java程序,jar包和配置文件等等,如我在Tomcat的【webapps】目录下的自定义目录【fjdingsdapp】中包含了一个“1.html”文件,那么这个在【fjdingsdapp】整个可以运行文件中的所有资源可以称为是我开发的一个“web应用程序”,简称“web应用”,而单单【fjdingsdapp】这个包含所有我开发的web资源称为我的“web应用所在目录”。
而我们将web应用开发好之后,若想供外界访问,那么久需要把 “web应用所在目录” 交给服务器管理,这个过程称为“虚拟目录的映射”。
服务器的虚拟目录映射有三种方式:
第一种(不推荐):
虽然这种方式不推荐,但是可以用来设置自己开发的web应用的首页,无需再键入虚拟目录名和资源名作为URL路径。
在server.xml文件中找到<Host>标签元素,在其下使用<Context>标签,注意这是在操作XML文件,XML文件是区分大小写的,一个<Context>标签就代表一个web应用。
假设我的Tomcat服务器在【F】盘,其【webapps】目录中没有我的web应用,而我的web应用放在【D】盘的【myWebApp】目录中,该目录下有一个“1.html文件”,要想在浏览器中能访问到我的这个web应用,我在Tomcat的server.xml文件中找到<Host>标签,添加<Context>标签并配置属性(注意这是无结束标签,要注意结束方式 “/>”),如下示例:
<Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true"> <Context path="" docBase="D:myWebApp" /> </Host>
path属性:虚拟目录的名称,也就是对外访问路径,本地硬盘中不一定有这个目录,但是如果path属性有值,在浏览器地址栏必须输入。这里为缺省值。
docBase属性:web应用所在目录,这个是硬盘中必须存在的,在这个目录中放的是我们的web资源。
每次配置server.xml文件后,必须重启Tomcat服务器。
由于我们设置了<Context>的“path”属性为缺省值,因此在地址和端口之后只需要输入资源名即可:
如果path属性有值,比如path=“123” (随便写的)
<Context path="123" docBase="D:myWebApp" />
那么浏览器在输入时必须有这个路径才能访问到对应的文件:
结尾:一个<Context>标签即代表一个web应用,因此在<Host>标签下可以有多个web应用,但是这些<Context>中的path属性只能有一个是缺省值。<Context>元素在配置文件中除用于映射虚拟目录之外,还可以用于为web应用配置一些资源,例如配置web应用使用的数据库连接池,javamail session等(这些配置以后会介绍到)。
之所以不推荐这种方法,这是因为在Tomcat服务器的说明上已经表明这种方法需要经常性的修改server.xml文件,而每次修改都需要重启服务器
看到如下的说明:
================================================
第二种:
同样在Tomcat对于<Context>标签的说明中,有这么一种方式:
这是另一种定义<Context>标签的方式,无需在<Host>标签下定义,这种方式的好处是不需要每次都要重启Tomcat,那么这种方式应该怎么做呢?
首先,我们需要自定义一个XML文件,而这个XML文件的文件名(除去".xml"的部分)将会作为今后浏览器输入的路径名,类似于这个文件名是虚拟目录名称(即对外访问路径),我们需要在这个自定义的XML文件中添加<Context>元素,这种方式就不需要添加“path”属性了,因为文件名已经代替了。
其次,在上图中有这么一段路径:$CATALINA_BASE/conf/[enginename]/[hostname]/
directory ,这段路径中的“CATALINA_BASE”在《Tomcat免安装版的环境变量配置以及Eclipse下的Tomcat配置和测试》一文中我已经提及,我设的正是Tomcat的主目录,而“conf”正好也是Tomcat下的配置文件目录名,那么 “[enginename]” 和 “[hostname]” 对应的目录是什么呢?我们打开 server.xml 文件,看到里面有的<Engine>和<Host>这两个标签(<Host>就是第一种方式中所说的那个)
<Engine defaultHost="localhost" name="Catalina"> ...(此处省略其他内容) <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true"> </Host> </Engine>
可以看到这两个标签中正好都有name属性,<Engine>元素的name属性值为“Catalina”,<Host>元素的name属性值为“localhost”,正好是【conf】目录下的【Catalina】目录,和【Catalina】目录下的【localhost】目录:
在【localhost】目录中,就是我们要放置的自定义XML文件。
现在,我的web应用所在目录为【D】盘中的【myWebApp】目录中,而这回不需要去server.xml文件中配置路径,我在Tomcat目录下的【conf】-->【Catalina】-->【localhost】下创建一个“rr.xml”文件:
在D盘下放置我的web应用
在指定的Tomcat路径中放置我的XML配置文件,将会映射到我的web应用
在“rr.xml”文件中的代码就一行:
<Context docBase="D:myWebApp" />
之前说过,自定义的XML文件名是作为对外访问路径,所以要想在浏览器中访问我的web应用,就该这么输入,能看到:
当然这还没完,继续开着服务器不要关,我们在在Tomcat目录下的【conf】-->【Catalina】-->【localhost】下再创建一个"dsd.xml"文件,内容同“rr.xml”文件,将浏览器的路径修改,可以看到:
是的,这种方式能避免经常重启Tomcat服务器。
由自定义的XML文件可以通过文件名来增加多级访问路径,以“#”相隔,例如:
那么浏览器地址栏应该这么输入:
当然,第一种方式还有缺省的类型,那么第二种方式是否也能这样呢,那就需要定义一个“ROOT.xml”文件了,对,文件名就叫“ROOT”,必须全部大写,在“ROOT.xml”中的内容依然还是为
<Context docBase="D:myWebApp" />
那么浏览器就可以省略虚拟目录名(对外访问路径),如下:
<Context>的最后:
<Context>标签有一个“reloadable”属性,能运行Tomcat自动加载更新后的web应用,尤其是在web应用中有新的Java程序更新时,但是这个属性是要避免使用的,通常web应用都是比较大的,如果设置了这个属性,Tomcat服务器容易卡死,因此不建议使用。
=============================================================
第三种:
让Tomcat自动映射,Tomcat会自动管理其【webapps】目录下的所有web应用,并把这些web应用所在目录映射成虚拟目录。因此我们只要讲自己开发好的web应用放置在Tomcat的【webapps】目录下即可。而对外访问的路径名称就是“web应用所在目录”的名称。
如我在【webapps】目录下创建一个自定义目录【mywebapp】,里面含有一个“3.html”文件,
---->
那么在浏览器中输入地址:
通过这种方式,也无需重启服务器。
那么通过这种方式可以指定web应用所在目录的默认页面,在 目录【mywebapp】 下定义一个“index.html”。文件名一定是“index”才行,其他文件名会查找不到,这时在浏览器中只需要键入地址和web应用所在目录(已作为虚拟目录)即可,无需键入对应资源名(不需要再多加“index.html”):
这种配置首页的方式原理其实是和Tomcat的【conf】目录中的“web.xml”文件中配置有关,至于原理将在下一篇Tomcat的学习中指出说明。