jsp中访问WEB-INF目录下的文件

本文阐述了在JSP中将文件放置于WEB-INF目录内以保护源代码的方法,并详细解释了如何通过redirect和forward两种跳转方式访问资源。通过配置struts框架和XML文件,实现了对敏感页面的间接访问,确保源代码安全。

  在jsp中WEB-INF目录内的文件是不可以直接用url访问的,可以通过将需要保护的文件放入WEB-INF文件夹内,实现资源的保护.将源代码放入其中,更好的保护了源代码.

  而且需要保护的jsp放入其中,我们仍然可以使用WEB-INF目录下的JSP页面来提供视图给客户,客户却不能直接请求访问JSP.

  我们知道,实现页面的跳转有两种方式,一种是通过redirect的方式(属于客户端跳转),一种是通过forward的方式(服务器跳转)。redirect方式的跳转,系统会在一个新的页面打开要跳转的网页,也就是使用url进行跳转,其本质也就是客户端跳转;而forward方式跳转,系统会在原来的页面上打开一个要跳转的网页。而放到WEB-INF目录下的文件只允许服务器跳转来访问,如下

  例1:/test/test1.jsp文件

<html>

<body>

    <form name="testform" action="/WEB-INF/jsp/test/test2.jsp">

      <input type = "submit" value="test">

    </form>

</body>

</html>

    上面这段语句只有一个名为test的按钮,如果单击这个按钮是,系统就会跳转到/WEB-INF/jsp/test/test2.jsp.

  test2.jsp的代码如下:

  例2:/WEB-INF/jsp/test/test.jsp文件

<html>

<body>

跳转成功!

</body>

</html>

事实上,这个跳转是无法成功的,点击按钮后,IE会报“403 Forbidden”的错误。

而forward方式的跳转则可以成功,如下代码:

例3:/test/test3.jsp文件

<html>

<body>

<form name="testform">

<jsp:forward page = "/WEB-INF/jsp/test/test3.jsp" />

</form>

</body>

</html>

    请注意上面带下划线的语句,这段就是通过forward的形式来访问/WEB-INF/jsp/test/test.jsp文件,在IE输入地址http://localhost/test1/test2.jsp,网页上就显示“跳转成功!”的信息了.

  这表示放到了WEB-INF可以通过forward的方式来访问。

  因为很多页面上都有采用submit这样的方式来进行跳转,但这种方式却非常适合采用struts结构的系统。因为采用这个结果大多是先跳转到一个Action类,然后在Action类进行相关处理后(比如说获取相关的信息保存到session中,进行有效性的判断),然后再forward到另外一个页面,这样放到WEB-INF中的jsp代码可以被正常访问,也防止了对这些页面的直接访问,下面我来举例说明。

<------------以下部分内容来自网络------------>

    下面我们先对配置文件struts-config.xml进行配置,如下:

例4:WEB-INF/struts-config.xml文件

<?xml version="1.0" encoding="ISO-8859-1" ?>

<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">

<struts-config>

<!-- ========== Action Mapping Definitions ============================== -->

<action-mappings>

<action path="/test"

            type=" test.TestAction"

            scope="request">

            <forward name="test" path="/WEB-INF/jsp/test/test.jsp"/>

    </action>

</action-mappings>

</struts-config>

    上面这个配置非常简单,请看红色部分,这里定义了一个action类,它的路径为/test,所对应的类为test.TestAction.java,它都一个跳转页面,别名为test,对应的页面为/WEB-INF/jsp/test/test.jsp。

    下面我们对例1的内容进行修改,使其跳转到/test去。

例5:修改后的/test/test1.jsp文件

<html>

<body>

    <form name="testform" action="/test">

      <input type = "submit" value="test">

    </form>

</body>

</html>

    这样我们在IE中访问http://localhost/test/test1.jsp,然后点击test按钮,页面就会跳转到test.TestAction.java这个类来,下面是这个类的内容。

package test;

import javax.servlet.http.*;

import org.apache.struts.action.ActionMapping;

import org.apache.struts.action.Action;

import org.apache.struts.action.ActionForm;

import org.apache.struts.action.ActionForward;

public class TestAction extends Action

{

public ActionForward perform(ActionMapping mapping,

                                 ActionForm form, HttpServletRequest req,

                                 HttpServletResponse res)

    {

      return mapping.findForward("test");

    }

}

    可以看到,这个类是继承Action类的,所有的控制类都必须继承Action类,这个类里面有一个perform方法,跳转到这个类都是从这个方法进行访问的(新版本可以是execute方法),现在这个方法里面只有一条语句,这句话的意思就是跳转到一个别名为test的页面,也就是/WEB-INF/jsp/test/test.jsp页面,这样我们点击test按钮后,IE就会显示“跳转成功!”这条信息,这表示系统允许这样的跳转。

注意:CSS文件要存放在根目录,此时引用要用绝对路径!!!引用格式如:/项目名/css文件夹/*.css

来源:(http://blog.sina.com.cn/s/blog_4baadb1f01009fin.html) - 把JSP放到WEB-INF后以保护JSP源代码_雨露清晨_新浪博客

 

 

<think>好的,我现在需要帮助用户解决在Spring MVC中正确配置以访问WEB-INF目录下的JSP文件的问题。首先,我得回忆一下Spring MVC的基本配置流程。用户提到的是WEB-INF下的JSP文件,通常这些文件是不能直接通过URL访问的,因为WEB-INF是一个受保护的目录。所以,正确的做法应该是通过控制器来转发请求到这些JSP页面。 首先,用户可能需要配置视图解析器,也就是InternalResourceViewResolver。这个解析器会帮助Spring MVC找到位于WEB-INF目录下的JSP文件。我记得需要设置前缀和后缀,比如前缀是"/WEB-INF/views/",后缀是".jsp",这样控制器返回的视图名就会被解析到正确的路径。 然后,用户需要在Spring的配置文件中启用注解驱动,这样控制器中的@RequestMapping注解才能生效。可能还需要配置组件扫描,让Spring能够自动检测到控制器类。 接下来是控制器的编写。用户需要创建一个带有@Controller注解的类,然后在方法上使用@RequestMapping来映射URL路径。例如,当访问"/login"时,返回的视图名是"loginPage",这样视图解析器就会找到/WEB-INF/views/loginPage.jsp文件。 用户的问题中提到了引用[3],其中说明了@RequestMapping注解的作用,以及引用[5]中的配置示例。需要注意的是,web.xml的版本问题,比如使用4.0版本可能会导致部署问题,尤其是在IDEA中,可能需要调整项目结构或配置。引用[4]中的部署错误可能与输出目录配置有关,需要确保生成的war包或exploded目录正确包含WEB-INF及其子内容。 另外,用户提供的示例代码中的JspController类,返回的视图名是"success",对应的JSP文件应该放在WEB-INF目录下的适当位置,比如WEB-INF/views/success.jsp,这需要视图解析器的正确配置。 可能还需要检查Maven依赖是否正确引入了spring-web和spring-webmvc,如引用[2]所述。如果依赖缺失或版本不兼容,也会导致配置失败。 最后,用户可能需要一个完整的配置示例,包括Spring MVC的XML配置和控制器代码,以及JSP文件的存放位置。同时,提醒用户注意常见的部署错误,比如路径错误或缺少必要的依赖,确保项目结构符合Spring MVC的要求。</think>### 如何在Spring MVC中配置访问WEB-INF目录下的JSP文件? #### 1. **核心配置步骤** - **视图解析器配置** 在Spring MVC的配置文件(如`springmvc-servlet.xml`)中,添加`InternalResourceViewResolver`,指定JSP文件路径前缀和后缀: ```xml <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> ``` 此配置会将逻辑视图名(如`loginPage`)解析为物理路径`/WEB-INF/views/loginPage.jsp`[^3]。 - **启用注解驱动** 在配置文件中添加`<mvc:annotation-driven/>`以支持注解方式定义控制器: ```xml <mvc:annotation-driven/> ``` #### 2. **控制器实现** 编写控制器类,通过`@RequestMapping`映射请求路径,并返回逻辑视图名: ```java @Controller public class LoginController { @RequestMapping("/login") public String showLoginPage() { return "loginPage"; // 对应/WEB-INF/views/loginPage.jsp } } ``` #### 3. **JSP文件存放位置** 将JSP文件放置在`WEB-INF/views/`目录下(根据配置的`prefix`值调整路径),例如: ``` WEB-INF/ └── views/ └── loginPage.jsp ``` #### 4. **web.xml配置** 确保`web.xml`中正确配置`DispatcherServlet`并关联Spring配置文件: ```xml <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/springmvc-servlet.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> ``` 注意:需使用Servlet 3.0+版本的`web.xml`(如引用[5]中版本4.0的配置)以避免兼容性问题[^5]。 #### 5. **依赖配置** 在Maven项目中添加`spring-webmvc`依赖(引用[2]): ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.3.23</version> </dependency> ``` #### 6. **常见问题解决** - **部署报错“找不到out目录”** 检查IDEA的`Artifact`配置,确保输出路径包含`WEB-INF`(引用[4])[^4]。 - **404错误** 确认JSP路径与视图解析器的`prefix`和`suffix`匹配,且控制器返回的视图名无拼写错误。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值