博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SpringMVC之访问静态文件
阅读量:7054 次
发布时间:2019-06-28

本文共 3560 字,大约阅读时间需要 11 分钟。

我们在进行springMVC开发时,必定会在jsp页面引入js文件、img文件和css文件。大多数人会将这些分类存放在WebRoot文件下新建的文件夹下面。同时,会在web.xml文件中配置拦截所有请求。这样就造成了页面无法访问到js、img和css文件夹中的文件了。

        在SpringMVC中可以利用 <mvc:resources location="/img/" mapping="/img/**"/>来访问。从而解决了上述问题。

        下面是,我写的一个demo。

        先看看其它文件。

web.xml(这个文件写好后几乎不用再进行修改了):

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5" 
 xmlns="" 
 xmlns:xsi="" 
 xsi:schemaLocation=" 
 ">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
   <servlet-name>SpringMVC</servlet-name>
   <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
   <!-- 设置开启时的导入配置文件 。可以不是必须的文件名称,可自定义-->
   <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath*:config/*-servlet.xml</param-value>
   </init-param>
   <load-on-startup>1</load-on-startup> <!-- 启动tomcat时启动springMFC -->
  </servlet>
  <servlet-mapping>
   <servlet-name>SpringMVC</servlet-name>
   <url-pattern>/</url-pattern><!-- 拦截所有请求 -->
  </servlet-mapping>
</web-app>
先看显示图片的:img.jsp:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<%@ taglib prefix="c" uri="" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'hello.jsp' starting page</title>
    
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">    
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->

  </head>

  
  <body> 
    你好SpringMVC!!!<br/>
   <h4>显示一张图片</h4>
   <br/>
   <img alt="图片" src="img/we.jpg">
    </div>
  </body>
</html>

在java文件中:

package com.yx.controller;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.ModelAndView;

import org.springframework.web.servlet.mvc.multiaction.MultiActionController;

public class MultiController extends MultiActionController {

 public ModelAndView img(HttpServletRequest request,HttpServletResponse response){

  System.out.println("-----img-------");
  return new ModelAndView("/img");
  
 }
 public ModelAndView js(HttpServletRequest request,HttpServletResponse response){
  System.out.println("-----js-------");
  return new ModelAndView("/testJS");
  
 }
}

以上文件与前面讲的十分的相似,改动不大。

下面是spring的配置文件:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns=""  
 xmlns:context=""  
 xmlns:p=""  
 xmlns:mvc=""  
 xmlns:xsi=""  
 xsi:schemaLocation="  
        
        
        
        
      "> 

 <!-- 常规单class多方法bean -->

 <bean name="/test/multi" class="com.yx.controller.MultiController">
  <property name="methodNameResolver">
   <ref bean="paramMethodResolver"/>
  </property>
 </bean>
 <!-- 常规单class单方法bean -->
 <bean name="/test/hello" class="com.yx.controller.HelloSpringMVCController"></bean>
 
 
 <!-- 静态资源访问 -->
   <mvc:resources location="/img/" mapping="/img/**"/> 
   <mvc:resources location="/js/" mapping="/js/**"/>
   <!--以上两句就是设置spring的拦截器不对img文件夹与js文件夹的文件进行拦截-->
    
 <!-- 参数名称解析 -->
 <bean id="paramMethodResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
  <property name="paramName" value="action"></property>
 </bean>

 <!-- 视图解析器 -->

 <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  <property name="prefix" value="/jsp"></property> <!-- 前缀 -->
  <property name="suffix" value=".jsp"></property> <!-- 后缀 -->
 </bean>
     
</beans> 

这样子图片就可以显示出来了:

你可能感兴趣的文章
Beep使用
查看>>
关于php网络爬虫phpspider。
查看>>
OpenGL的glRotatef旋转变换函数详解
查看>>
c#中 ==与equals有什么区别
查看>>
Oracle Group By ROLLUP-SubTotal
查看>>
PHP 正则表达式
查看>>
Computer Graphics Research Software
查看>>
nodejs进阶(2)—函数模块调用
查看>>
java面向对象高级分层实例_BaseDao
查看>>
iOS 从相册中拿到 图片名 ,截取后缀,图片名
查看>>
linux+nginx+tomcat负载均衡,实现session同步
查看>>
初始JavaScript Promises之二
查看>>
.Net魔法堂:AssemblyInfo.cs文件详解
查看>>
(转)NGUI制作转圈的技能CD特效
查看>>
Spring JMX之三:通知的处理及监听
查看>>
Python 函数
查看>>
【剑指offer】合并两有序单链表
查看>>
HDU 4360 As long as Binbin loves Sangsang spfa
查看>>
IT痴汉的工作现状24-Just for fun
查看>>
10个必需的iOS开发工具和资源
查看>>