Spring MVC特点

  • 清晰地角色划分
  • 灵活的配置功能
  • 提供了大量的控制器接口和实现类
  • 真正的View层实现无关(JSP、Velocity、Xslt等)
  • 国际化支持
  • 面向接口编程
  • Spring提供了Web应用开发的一整套流程,不仅仅是MVC,他们之间可以很方便的结合一起

视图解析器

  • 将逻辑视图的名字与JSP等视图技术进行匹配
  • InternalResourceViewResolver
  • 在Web应用程序的WAR文件中查找视图模板,视图模板的路径根据加完前缀和后缀的逻辑视图名称来确定
  • prefix
  • suffix

REST风格

  • Representational State Transfer表述性状态转移
  • 传统的查、改、删的URL与REST风格的增删改URL对比
  1. /userview.action?id=12    VS    /user/12
  2. /userdelete.action?id=12   VS    /user/12/delete
  3. /userupdate.action?id=12  VS    /user/12/update
  • 请求方式
  1. GET
  2. POST
  3. DELETE
  4. PUT
  • 他强调的是一个资源可以对应多种视图

配置步骤:

  1.导入spring-web类库,

  2.配置web.xml:

  <servlet>

   <!--注意这里的名字会被spring.xml文件名引用(springMVC-servlet.xml)-->

  <servlet-name>springMVC</servlet-name>

  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

   </servlet>

  <servlet-mapping>

  <servlet-name>springMVC</servlet-name>

  <url-pattern>/</url-pattern>

  </servlet-mapping>

  乱码处理:

    <filter>

     <filter-name>encodingFilter</filter-name>

    <filter-class> org.springframework.web.filter.CharacterEncodingFilter </filter-class>

     <init-param>

      <param-name>encoding</param-name>

       <param-value>UTF-8</param-value>

     </init-param>

    <!-- 响应也设为相同的编码 -->

    <init-param>

      <param-name>forceEncoding</param-name>

      <param-value>true</param-value>

    </init-param>

   </filter>

    <filter-mapping>

    <filter-name>encodingFilter</filter-name>

    <url-pattern>/*</url-pattern>

   </filter-mapping>

  3.配置<springMVC>-servlet.xml,放在和web.xml同目录

方式一:BeanNameUrlHandlerMapping方式:

  <!-- 控制器bean,name为访问此控制器用的url,class为继承AbstractController的控制器类 -->

  <bean name="/index.html" class="com.zhp.controller.HelloController"></bean>

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

   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">

   <property name="prefix" value="/WEB-INF/jsp/"></property>

  <property name="suffix" value=".jsp"></property>

  </bean>

方式二:DefaultAnnotationHandlerMapping注解方式:

  <context:component-scan base-package="com.zhp.*"/>

   <mvc:annotation-driven/>

视图解析器如上相同

4.跳转:

方式一:ModelAndView mav = new ModelAndView("hello");//hello会结合试图解析器的前缀和后缀来确定url

方式二:注解时,直接return "hello";即可

5.接收参数:

login(String uname)可以直接通过uname=zhang来传参

reg(@ModelAttribute Usertbl user)通过注解也可自动封装对象

Rest风格:

@RequestMapping("/update/{username}")

public String update(@PathVariable String username)//注意注解@PathVariable

6.转发数据:

方式一:通过方法中参数Model:

public String login(Model model){

model.addAttribute("uname","zhang");//页面通过${requestScope.uname}取出

}

方式二:session对象的获取:自动注入session对象

public String login(@ModelAttribute Usertbl user,Model model,HttpSession session){}

注意:页面传递参数:

1.Model----model.addAttribute("upass",upass);

2.Map<String,Object>---------map.put("user", user);

3.HttpSession----session.setAttribute("name", uname);

注意:如果指定了提交方式method=RequestMethod.GET/method=RequestMethod.POST时,springMVC会根据页面的提交方式判断提交的;

7.数据校验

JSR-303 是Java EE 6 中的一项子规范,叫做Bean Validation,官方参考实现是Hibernate Validator。

此实现与Hibernate ORM 没有任何关系。JSR 303 用于对Java Bean 中的字段的值进行验证。

spring MVC 3.x之中也大力支持 JSR-303,可以在控制器中对表单提交的数据方便地验证。

8.异常处理

a.局部处理:

    //运行时异常处理

        @ExceptionHandler(value=RuntimeException.class)

    public String doException(RuntimeException e){

System.out.println("---RuntimeException---异常了-----"+e.getMessage());

return "error";

}

// 非运行时异常处理

@ExceptionHandler(value=Exception.class)

public String doException(Exception e){

System.out.println("---Exception---异常了-----"+e.getMessage());

return "error";

}

b.全局处理:

<!-- 异常解析器 -->

<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">

<property name="exceptionMappings">

<props>

<prop key="java.lang.Exception">error</prop>

</props>

</property>

</bean>

9.静态资源处理:

将静态文件指定到某个特殊的文件夹中统一处理

<mvc:resources mapping="/resources/**" location="/resources/" />

注意:mapping="/resources/**":表示映射路径,在页面应用resources映射名

location="/resources/":表示文件存放的真实路径

10.文件上传

a.导入文件上传夹包:commons-fileupload-1.2.2.jar、commons-io-2.4.jar

b.配置文件:<!-- 配置MultipartResolver,用于上传文件,使用spring的CommonsMultipartResolver -->

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">

<property name="maxUploadSize" value="5000000"/>

<property name="defaultEncoding" value="UTF-8"/>

</bean>

c.编写页面:<form action="upload" method="post" enctype="multipart/form-data">

<input type="submit" value="上传">

d.编写控制器类:

@Controller

public class ProductAction {

@RequestMapping("/upload")

public String upload(Product product,@RequestParam MultipartFile pic,HttpSession session){

System.out.println(pic.getOriginalFilename()+"------upload-----"+product);

//获取工程路径

String savePath=session.getServletContext().getRealPath("resources/upload");

//获取上传文件名称

String fileName=pic.getOriginalFilename();

File saveFile=new File(savePath, fileName);

//封装到对象

product.setImgSrc(fileName);

try {//实现上传,以拷贝输入流的方式实现

FileUtils.copyInputStreamToFile(pic.getInputStream(), saveFile);

} catch (IOException e) {  e.printStackTrace(); }

return "index";

}

// 多文件上传

@RequestMapping("/uploads")

public String uploads(Product product,@RequestParam MultipartFile[] pic,HttpSession session){

    //获取工程路径

    String savePath=session.getServletContext().getRealPath("resources/upload");

    for (int i = 0; i < pic.length; i++) {

      //获取上传文件名称

      String fileName=pic[i].getOriginalFilename();

      File saveFile=new File(savePath, fileName);

       try { //springMVC提供文件拷贝

      pic[i].transferTo(saveFile);

       } catch (IOException e) { e.printStackTrace();}

         }

         return "index";

   }

  }

11.SpringMVC中的JSON

@Controller

      public class ProductController {

    @Resource(name="service")

     private ProductService service;

    @RequestMapping(value="/query/{id}",method=RequestMethod.GET)

    @ResponseBody

    public Product query(@PathVariable int id){

    Product prod=service.getProductById(id);

         return prod;

       }

     }

     对应前台js:

      <script type="text/javascript" src="resources/js/jquery-1.9.1.js"></script>

      <script type="text/javascript">

     $(document).ready(function(){

     $(":button").click(function(){

    var id=$("[name=pid]").val();

    $.getJSON("query/"+id,"",function(data){

         if(data!=null && data!=""){

         $("#show").html("商品编号:"+data.pid+"<br>商品名称:"+data.pname+"<br>商品价格:"+data.price);

           }

       });

      });

      });

       </script>

 

SpringMVC的特性及应用的更多相关文章

  1. springMVC的详解

    一,springmvc注解特性 1.@Controller 控制器定义在 spring 3.0 中,通过@controller 标注即可将 class 定义为一个 controller 类.为使 sp ...

  2. ContextLoaderListener可以不写嘛?

    写了那么久的Spring,经常写这样的配置,这就是几行Spring.SpringMvc的基本配置, 但是最近也看到不写最前面的context-param以及listener的,好奇记录下. <c ...

  3. XSS攻击防御篇

    前言   上篇文章中提到了 XSS 攻击,而且,也从几个方面介绍了 XSS 攻击带来的严重影响.那么,这篇文章中,主要是针对 XSS 攻击做一个基本的防御,看看可以通过几种方式来修复这个特别常见的安全 ...

  4. Springboot注解使用总结

    使用Spring boot已经有段时间了,但是对很多注解的使用经常会遇到模糊甚至不解的地方,这次有时间便总结一下. 注解(Annotation)概念 注解是Java5开始对元数据的支持,注解与注释是有 ...

  5. Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC 配置校验器

    Spring4新特性——泛型限定式依赖注入 Spring4新特性——核心容器的其他改进 Spring4新特性——Web开发的增强 Spring4新特性——集成Bean Validation 1.1(J ...

  6. Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC

    在之前的<跟我学SpringMVC>中的<第七章 注解式控制器的数据验证.类型转换及格式化>中已经介绍过SpringMVC集成Bean Validation 1.0(JSR-3 ...

  7. springMVC第二天——高级参数绑定与其它特性

    大纲摘要: 1.高级参数绑定 a) 数组类型的参数绑定 b) List类型的绑定 2.@RequestMapping注解的使用 3.Controller方法返回值 4.Springmvc中异常处理 5 ...

  8. 转:SpringMVC 4.1 新特性(二)内容协商视图

    SpingMVC的内容协商支持三种方式: 使用后缀,如json.xml后缀和处理类型的关系可以自己定义 前面说的使用Accept头 在访问时request请求的参数,比如每次请求request都会加f ...

  9. SpringMVC视图解析器

    SpringMVC视图解析器 前言 在前一篇博客中讲了SpringMVC的Controller控制器,在这篇博客中将接着介绍一下SpringMVC视 图解析器.当我们对SpringMVC控制的资源发起 ...

  10. springmvc<一>一种资源返回多种形式【ContentNegotiatingViewResolver】

    restful服务中一个重要的特性就是一种资源可以有多种表现形式,在springmvc中可以使用ContentNegotiatingViewResolver这个视图解析器来实现这种方式. 描述资源的三 ...

随机推荐

  1. 安装Tensorflow-gpu版本

    下载cuda 链接:https://developer.nvidia.com/cuda-10.0-download-archive?target_os=Windows&target_arch= ...

  2. 解决URLEncoder.encode 编码空格变 + 号

    jdk自带的URL编码工具类 URLEncoder 在对字符串进行URI编码的时候,会把空格编码为 + 号. 空格的URI编码其实是:%20 解决办法:对编码后的字符串,进行 + 号替换为 %20.总 ...

  3. MySQL搭建主从集群详细步骤~

    一. Docker安装MySQL搭建主从 docker run [OPTIONS] IMAGE [COMMAND] [ARG...] docker run -p 3306:3306 很多 -d --n ...

  4. MinIO客户端之cat

    MinIO提供了一个命令行程序mc用于协助用户完成日常的维护.管理类工作. 官方资料 mc cat 使用cat命令输出本地硬盘上的文本文件的内容至控制台. ./mc cat ./local.json ...

  5. Python 实现 PDF 到 Word 文档的高效转换(DOC、DOCX)

    PDF(Portable Document Format)已成为一种广泛使用的电子文档格式.PDF的主要优势是跨平台,可以在不同设备上呈现一致的外观.然而,当我们需要对文件内容进行编辑或修改,直接编辑 ...

  6. DVWA Brute Force(暴力破解)全等级

    Brute Force(暴力破解) 目录: Brute Force(暴力破解) 1.Low 2.Medium 3.High 方法1--Burp爆破 方法2--Python脚本爆破 4.Impossib ...

  7. Spring源码学习笔记5——注册BeanPostProcessor,初始化事件多播器,注册事件监听器

    一丶前言 上篇Spring容器回调完所有的BeanFactoryPostPocessor,之后可以做到替换所有占位符,解析所有配置类等工作,这篇还会迎来一个Spring留给我们扩展的一个接口,涉及到A ...

  8. Llama2-Chinese项目:6-模型评测

      测试问题筛选自AtomBulb[1],共95个测试问题,包含:通用知识.语言理解.创作能力.逻辑推理.代码编程.工作技能.使用工具.人格特征八个大的类别. 1.测试中的Prompt   例如对于问 ...

  9. LeetCode DP篇-求子序列问题(1143、300、53、72)

    1143. 最长公共子序列 给定两个字符串 text1 和 text2,返回这两个字符串的最长公共子序列的长度. 一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情 ...

  10. 实战案例丨使用云连接CC和数据复制服务DRS实现跨区域RDS迁移和数据同步

    摘要:实践案例展示如何使用云连接CC和数据复制服务DRS实现跨区域RDS迁移和数据同步. [业务场景及诉求] 希望将不同区域"华北-北京四"的rds与"亚太-新加坡&qu ...