Springmvc---解读<url-pattern/>

        (1) *.do:

         在没有特殊要求的情况下,SpringMVC 的中央调度器 DispatcherServlet 的<url-pattern/>常使用后辍匹配方式,如写为*.do 或者 *.action, *.mvc等。

        (2) / :

        Tomcat本身能处理静态资源的访问, 像html, 图片, js文件都是静态资源,因为在你的Tomcat启动后,这个servlet就会被创建: 在tomcat的安装目录下有一个DefaultServlet:在你的Tomcat启动后,这个DefaultServlet就会被创建:

                ​​​​​​​        

        DefaultServlet的作用:

        1.处理静态资源
        2.处理未映射到其它servlet的请求。 
        The default servlet for all web applications, that serves static  resources.  It processes all requests that are not mapped to other  servlets with servlet mappings (defined either here or in your own web.xml file).

         可以写为/,当你的项目中使用了 / ,它会替代 tomcat中的DefaultServlet(DefaultServlet用来处理各种静态资源访问请求),DispatcherServlet 将会向静态资源获取请求,例如.css、.js、.jpg、.png 等资源的获取请求,当作是一个普通的Controller请求中央调度器会调用处理器映射器为其查找相应的处理器。当然也是找不到的,所以在这种情况下,所有的静态资源获取请求均会报404错误你用了/后,你的动态资源可以成功访问,你的静态资源是不行的。

例如:

        需求:在index.jsp页面中存在一个访问图片的链接。该项目用于演示将写为*.do 可以访问到该图片,而写为/,则无法访问:

                              

使用/的话,如何才能访问得到静态资源呢?有两种解决方式:
第一种解决方式:
        第一步:在springmvc的配置文件中声明:<mvc:default-servlet-handler/>

        声明了<mvc:default-servlet-handler/>后,springmvc 框 架 会 在 容 器 中 创 建DefaultServletHttpRequestHandler 处理器对象。它会像一个检查员,对进入DispatcherServlet 的 URL 进行筛查,如果发现是静态资源的请求,就将该请求转由 Web 应用服务器默认的 Servlet 处理。一般的服务器都有默认的Servlet。 在 Tomcat 中,有一个专门用于处理静态资源访问的 Servlet 名叫 DefaultServlet,可以处理各种静态资源访问请求

        第二步骤:加入注解驱动解决问题<mvc:annotation-driven />:

       <mvc:default-servlet-handler/>和 @RequestMapping注解 有冲突,需要加入<mvc:annotation-driven />解决问题

第二种解决方式:推荐!使用<mvc:resources/>标签
第一步:在springmvc配置文件中声明<mvc:resources/>标签

        在 Spring3.0 版本后,Spring 定义了专门用于处理静态资源访问请求的处理器 ResourceHttpRequestHandler。并且添加了标签<mvc:resources/>标签,专门用于解决静态资源无法访问问题。需要在springmvc配置文件中添加如下形式的配置:

                        表示以images开头的就去images目录下去找静态资源:

         加了之后我们的框架也会在内存中去创建对象:ResourceHttpRequestHandler,然后由这个类处理静态资源,不依赖于服务器了,框架自己处理静态资源的访问,这种方式在项目中用得多,因为不依赖服务器,不管啥服务器

第二步:加入注解驱动解决问题<mvc:annotation-driven />:

 <mvc:resources/>标签和 @RequestMapping注解 有冲突,加入注解驱动解决问题<mvc:annotation-driven />

        你可以把静态资源全部放到一个文件夹中:

以后你直接这样写,不需要再带有后缀了:

  @RequestMapping("/single")
    @ResponseBody
    public Student doJsonObject(){
        //创建java对象,转为json
        Student student = new Student("李四",22,"lisi@qq.com");
        return student;
    }

    @RequestMapping("/list")
    @ResponseBody
    public List<Student> doJsonArray(){
        //创建List对象,转为jsonArray
        List<Student> students = new ArrayList<>();
        students.add(new Student("李四",22,"lisi@qq.com"));
        students.add(new Student("王五",23,"wangwu@qq.com"));
        return students;
    }

  • 23
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值