WEB-INF是Java的WEB应用的安全目录,所谓安全就是客户端无法访问,只有服务端可以访问的目录。
forward转发可以访问WEB-INF文件夹 (服务器端行为)
redirect重定向不可以访问WEB-INF文件夹(客户端行为)
WEB-INF是Java的WEB应用的安全目录,所谓安全就是客户端无法访问,只有服务端可以访问的目录。从而实现了代码的安全。
如果想在页面中直接访问其中的文件,必须通过web.xml文件对要访问的文件进行相应映射才能访问。 WEB-INF文件夹下除了web.xml外,还存一个classes文件夹,用以放置 .class文件,这些 .class文件是网站设计人员编写的类库,实现了jsp页面前台美工与后台服务的分离,使得网站的维护非常方便。web.xml文件为网站部署描述XML文件,对网站的部署非常重要。
Web-Inf文件夹中除了有classes文件夹和一个web.xml文件外、还有lib文件夹(用于存放需要的jar包)(用于配置,比如说用来配置过滤器等。)
下面我来演示如何访问WEB-INF目录
访问WEB-INF目录中的JSP文件
方法1: 本来WEB-INF中的jsp就是无法通过地址栏访问的.所以安全.如果说你要访问这个文件夹中的jsp文件需要在项目的web.xml文件中去配置servlet格式差不多的配置就ok了。如下:
<servlet>
<servlet-name>runtain</servlet-name>
<jsp-file>/WEB-INF/INF.jsp</jsp-file>
</servlet>
<servlet-mapping>
<servlet-name>runtain</servlet-name>
<url-pattern>/XXX</url-pattern>
</servlet-mapping>
访问地址:http://localhost:8080/runtain/xxx,就可以看见内容了!
方法2:
<jsp:forward page ="/WEB-INF/jsp/test/test.jsp" />
方法3: 转发
request.getRequestDispatcher("/WEB-INF/a.jsp").forward(request,response);
怎么样让servlet访问WEB-INF下的网页或jsp文件呢.因为WEB-INF下,应用服务器把它指为禁访目录,即直接在浏览器里是不能访问到的.
因此,可以让servlet进行访问,如WEB-INF下有a.jsp则可以用request.getRequestDispatcher(“/WEB-INF/a.jsp”).forward(request,response);进行派遣访问.
但如果WEB-INF下有a.htm,则用
request.getRequestDispatcher(“/WEB-INF/a.htm”).forward(request,response);就不能访问.
一开始想不通,觉得怪.后来想想,jsp其实也是servlet,会自动编译的,于是work目录下会有/WEB-INF/a\$jsp.class类型,于是有头绪了,让应用服务器能够编译.htm,如a$htm.class.抱有这个想法,开始动手
在tomcat下的conf/web,找到jsp的访问方式,
<servlet-mapping>
<servlet-name>jsp</servlet-name>
<url-pattern>*.jsp</url-pattern>
</servlet-mapping>
于是在下面添加
<servlet-mapping>
<servlet-name>jsp</servlet-name>
<url-pattern>*.htm</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>jsp</servlet-name>
<url-pattern>*.html</url-pattern>
</servlet-mapping>
结果:一切OK,访问a.htm,和a.html在work/web-inf/下者有a\$htm.class,a$html.class生成
评论前必须登录!
注册