今日知识

1. 文件上传
2. ResponseBody和RequestBody
3. SpringMVC多视图
4. 静态资源的处理

文件上传

1. 导包,(commom.io , commons-fileupload)
2. xml配置
* <!--id必须写为multipartResolver-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!--文件大小限定-->
<property name="maxUploadSize" value="5120000"/>
</bean>
3. 处理的请求的路径方法
@Controller
public class FileController {
@RequestMapping("upload")
public String upload(MultipartFile file,User user) throws IOException {
//上传路径,文件名
File receive=new File("F://file",file.getOriginalFilename());
//io上传
file.transferTo(receive);
System.out.println(user);
return "success";
}
}
4. jsp页面
* <form action="/upload" enctype="multipart/form-data" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="text" name="password"><br>
头像:<input type="file" name="file"><br>
<input type="submit" value="上传">
</form>
5. 多文件上传
将处理方法的接收参数改成数组即可:MultipartFile[] file

静态资源的处理

1. 方法一:
<!--静态资源处理器
web目录下
classpath
文件路径-->
<mvc:default-servlet-handler/>
2. 方法二
<!-- web目录下-->
<!--mapping;访问的url-->
<!--location:代表静态资源访问的路径-->
<mvc:resources mapping="/pic/**" location="/WEB-INF/pic/"/>
<!-- classpath下-->
<mvc:resources mapping="/pic1/**" location="classpath:/pic1/"/>
<!--访问本地文件路径-->
<mvc:resources mapping="/pic2/**" location="file:F://file/"/>

Spring MVC对json数据的处理

1. ResponseBody
* 把后台pojo转换json对象
1.导包:jackson-core,jackson-mapper
2. RequestBody
* 接受前台json数据,把json数据自动封装javaBean
3. 案例
* @RequestBody:json装换为对象
* @ResponseBody:将对象封装为json返回
*
@RequestMapping("/save")
public @ResponseBody Student list(@RequestBody Student student){
System.out.println(student);
return student;
}
* js代码:
* function register(){
var name=document.getElementById("name").value;
var sex=document.getElementById("sex").value; var url="${pageContext.request.contextPath}/stu/save";
var prmts={"name":name,"sex":sex};
var jsonObj=JSON.stringify(prmts);//转换为json数据提交到后台
$.get(url,prmts,function (data) {
alert(data.name+"------"+data.sex);
},"json");
}
4. @RestController注解代表:该类的所有的方法都返回一个json数据

SpringMVC多视图

1. 概念:多视图是一个方法可以返回json/xml等格式的数据
2. 使用
1. 导包 :spring-oxm.jar
2. <bean
class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
<!-- 配置支持媒体类型 -->
<property name="contentNegotiationManager">
<bean
class="org.springframework.web.accept.ContentNegotiationManagerFactoryBean">
<property name="mediaTypes">
<map>
<entry key="json" value="application/json"></entry>
<entry key="xml" value="application/xml"></entry>
</map>
</property>
</bean>
</property> <!-- 指定默认视图 -->
<property name="defaultViews">
<!-- 支持多个视图 -->
<list>
<!-- 对josn格式视图支持 -->
<bean class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"/> <!-- xml格式视图支持 -->
<bean class="org.springframework.web.servlet.view.xml.MarshallingView">
<constructor-arg>
<bean class="org.springframework.oxm.jaxb.Jaxb2Marshaller">
<property name="classesToBeBound">
<list>
<value>com.gyf.backoffice.domain.Student</value>
</list>
</property>
</bean>
</constructor-arg>
</bean>
</list>
</property>
</bean>
3.pojo需要声明 @XmlRootElement
public class Student {
private String name;
private String sex;
4. 访问路径:localhost/stu/save.json(加个后缀即可)
localhost/stu/save.xml

08-SpringMVC02的更多相关文章

  1. iOS系列 基础篇 08 文本与键盘

    iOS系列 基础篇 08 文本与键盘 目录: 1. 扯扯犊子 2. TextField 3. TextView 4. 键盘的打开和关闭 5. 打开/关闭键盘的通知 6. 键盘的种类 7. 最后再扯两句 ...

  2. javaEE基础08

    javaEE基础08 一.继承 特点:继承父类的属性和方法,单继承(多继承) 特性:方法的复写(重写) 比如:人可以养狗 人------>狗:整体和部分(拥有)关系 关键字:extends 结构 ...

  3. 【玩转单片机系列001】 08接口双色LED显示屏驱动方式探索

    前些日子,从淘宝上购得一块08接口的双色LED显示屏(打算做个音乐频谱显示器),捣鼓了好几天,终于搞清楚了其控制原理,在这里做个总结,算是备忘吧. 1.LED显示屏的扫描方式 LED显示屏的扫描方式有 ...

  4. 《HelloGitHub月刊》第08期

    <HelloGitHub>第08期 兴趣是最好的老师,<HelloGitHub>就是帮你找到兴趣! 简介 最开始我只是想把自己在浏览GitHub过程中,发现的有意思.高质量.容 ...

  5. Spring Security(08)——intercept-url配置

    http://elim.iteye.com/blog/2161056 Spring Security(08)--intercept-url配置 博客分类: spring Security Spring ...

  6. [DFNews] EnCase v7.08发布

    EnCase v7.08 近日正式发布,7.08增加了Evidence Processor Manager以及Evidence Processor,不仅可以在本地实现证据处理队列,也支持了通过网络进行 ...

  7. 【博客美化】08.添加"扩大/缩小浏览区域大小" 按钮

    博客园美化相关文章目录: [博客美化]01.推荐和反对炫酷样式 [博客美化]02.公告栏显示个性化时间 [博客美化]03.分享按钮 [博客美化]04.自定义地址栏logo [博客美化]05.添加Git ...

  8. JavaScript学习08 Cookie对象

    JavaScript学习08 Cookie对象 JavaScript Cookie Cookie对象: Cookie是一种以文件的形式保存在客户端硬盘的Cookies文件夹中的用户数据信息(Cooki ...

  9. AC日记——石头剪刀布 openjudge 1.6 08

    08:石头剪刀布 总时间限制:  1000ms 内存限制:  65536kB 描述 石头剪刀布是常见的猜拳游戏.石头胜剪刀,剪刀胜布,布胜石头.如果两个人出拳一样,则不分胜负. 一天,小A和小B正好在 ...

  10. AC日记——字符替换 openjudge 1.7 08

    08:字符替换 总时间限制:  1000ms 内存限制:  65536kB 描述 把一个字符串中特定的字符全部用给定的字符替换,得到一个新的字符串. 输入 只有一行,由一个字符串和两个字符组成,中间用 ...

随机推荐

  1. echarts设置柱状图颜色渐变及柱状图粗细大小

    series: [ { name: '值', type: 'bar', stack: '总量', //设置柱状图大小 barWidth : 20, //设置柱状图渐变颜色 itemStyle: { n ...

  2. 【Java编程思想阅读笔记】Java数据存储位置

    Java数据存储位置 P46页有感 一.前置知识 栈是由系统自动分配的,Java程序员对栈没有直接的操作权限, 堆是所有线程共享的内存区域,栈 是每个线程独享的. 堆是由程序员自己申请的,在使用new ...

  3. 【LC_Lesson2】---整数反转练习

    题目描述: 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 1 ...

  4. Django 导入配置文件

    from django.conf import settings

  5. Vue 组件复用性和slot

    1.组件可复用 2.slot元素作为组件模板之中的内容分发插槽,元素自身可以被替换 <!DOCTYPE html> <html lang="en"> < ...

  6. python练习-8.12

    注:本代码是<python核心编程(第二版)>的第八章8-12的练习题的代码实现. 完成的功能:用户给出起始和结束的数字后给出一个下面的表格,分别显示出两个数字间所有整型的十进制.二进制. ...

  7. GP工作室—Alpha版本发布1

    目录 GP工作室-Alpha版本发布1 一.简介 1.1作业要求 1.2团队成员 二.软件下载安装说明 五.项目总结 @(Gold Point团队の项目计划) GP工作室-Alpha版本发布1 一.简 ...

  8. laravel脚手架搭建项目问题之生产环境element-ui组件字体图标显示错误问题

    问题描述: 1.element-ui组件使用的是npm安装 2.npm scripe模式开发 3.使用git命令行工具开发 3.开发环境下图标正常显示 4.生产环境下图标显示不正常 分析原因: 图标文 ...

  9. iperf安装使用教程

    https://linoxide.com/monitoring-2/install-iperf-test-network-speed-bandwidth/

  10. ReactNative---android系统中Image组件无默认图片问题

    react native的Image组件通过网络地址加载图片的时候,若加载失败iOS有默认图片等属性,但安卓没有:但可以通过其他方式来实现: {Platform.OS == 'android'?< ...