SpringMVC-03 RestFul和控制器 SpringMVC-04 数据处理及跳转SpringMVC-05 Json交互处理SpringMVC-06 Ajax
个人博客
SpringMVC-04 数据处理及跳转
结果跳转方式
1.ModelAndView
设置ModelAndView对象 , 根据view的名称 , 和视图解析器跳到指定的页面 .
页面 : {视图解析器前缀} + viewName +{视图解析器后缀}
一、对应的controller类(接口版)
二、对应的controller类(注解版)
上面的: mv.setViewName("test"); 和 return "test";
访问的网址为:/WEB-INF/jsp/test.jsp
重定向和转发
1.ServletAPI
**通过设置ServletAPI , 不需要视图解析器 **
1、通过HttpServletResponse进行输出
2、通过HttpServletResponse实现重定向
3、通过HttpServletResponse实现转发
2.SpringMVC
通过SpringMVC来实现转发和重定向 - 无需视图解析器;
通过SpringMVC来实现转发和重定向 - 有视图解析器;
重定向 , 不需要视图解析器 , 本质就是重新请求一个新地方嘛 , 所以注意路径问题.
可以重定向到另外一个请求实现 .
数据处理
1.处理提交数据
- 提交的域名称和处理方法的参数名一致
提交数据 : http://localhost:8080/hello?name=zc
处理方法 :
因为提交数据中,网址中的name和定义的name参数名相同,所以后台输出 : zc
- 提交的域名称和处理方法的参数名不一致
提交数据 : http://localhost:8080/hello?username=zc
处理方法 :
因为提交的域名称和处理方法的参数名不一致,可以使用@RequestParam,所以后台依然输出 : zc
- 提交的是一个对象
要求提交的表单域和对象的属性名一致 , 参数使用对象即可
1、实体类
2、提交数据 : http://localhost:8080/user?id=1&name=zc&age=20
3、处理方法 :
id
、name
、age
和对象User
中定义属性名相同,所以后台输出 : User { id=1, name='zc', age=20 }
说明:如果使用对象的话,前端传递的参数名和对象名必须一致,否则就是null。
例如:提交数据 : http://localhost:8080/user?id=1&username=zc&age=20
则:后台输出 : User { id=1, name=null, age=20 }
2.数据显示到前端
前端调用方式:${xxx}
第一种 : 通过ModelAndView
前面一直都是如此 . 就不过多解释
第二种 : 通过ModelMap
ModelMap
第三种 : 通过Model
3.对比
使用区别就是:
当然更多的以后开发考虑的更多的是性能和优化,就不能单单仅限于此的了解。
乱码问题
测试步骤:
1、我们可以在首页编写一个提交的表单
2、后台编写对应的处理类
3、输入中文测试,发现乱码
以前乱码问题通过过滤器解决 , 而SpringMVC给我们提供了一个过滤器 , 可以在web.xml
中配置,修改了xml文件需要重启服务器。
但是发现 , 有些极端情况下.这个过滤器对get的支持不好 .
处理方法 :
修改tomcat配置文件 :
文件位置:tomcat文件夹---conf---server.xml
加入:URIEncoding="utf-8"
一般情况下,SpringMVC默认的乱码处理就已经能够很好的解决了!
然后在web.xml中配置这个过滤器即可!
乱码问题,需要平时多注意,在尽可能能设置编码的地方,都设置为统一编码 UTF-8。
个人博客
SpringMVC-05 Json交互处理
Json
1.什么是JSON?
- JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。
- 采用完全独立于编程语言的文本格式来存储和表示数据。
- 简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。
- 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。看看他的要求和语法格式:
- 对象表示为键值对,数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
JSON 键值对是用来保存 JavaScript 对象的一种方式,和 JavaScript 对象的写法也大同小异,键/值对组合中的键名写在前面并用双引号 "" 包裹,使用冒号 : 分隔,然后紧接着值:
很多人搞不清楚 JSON 和 JavaScript 对象的关系,甚至连谁是谁都不清楚。其实,可以这么理解:
JSON 是 JavaScript 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串。
JSON 和 JavaScript 对象互转
要实现从JSON字符串转换为JavaScript 对象,使用 JSON.parse() 方法:
要实现从JavaScript 对象转换为JSON字符串,使用 JSON.stringify() 方法:
2.案例测试
2.1 新建一个module ,springmvc-04-json , 添加web的支持
2.2 在web目录下新建一个 json-1.html , 编写测试内容
Controller返回JSON数据
Jackson
应该是目前比较好的json解析工具了
当然工具不止这一个,比如还有阿里巴巴的 fastjson 等等。
我们这里使用Jackson,使用它需要导入依赖
:
配置文件web.xml:
springmvc.xml:
User实体类:
这里我们需要两个新东西,一个是@ResponseBody
,一个是ObjectMapper对象
,具体的用法如下:
控制类Controller:
可以看到,中文 换成了 ? ,出现了中文乱码
发现出现了乱码问题,我们需要设置一下他的编码格式为utf-8,以及它返回的类型;
通过@RequestMaping的produces属性来实现,修改下代码
再次测试 , 乱码问题OK!
代码优化
1. 乱码统一解决
上一种方法比较麻烦,如果项目中有许多请求则每一个都要添加,可以通过Spring配置统一指定,这样就不用每次都去处理了。
我们可以在springmvc的配置文件上添加一段消息StringHttpMessageConverter转换配置。
2.返回json字符串统一解决
在类上直接使用 @RestController ,这样子,里面所有的方法都只会返回 json 字符串了,不用再每一个都添加@ResponseBody ,我们在前后端分离开发中,一般都使用 @RestController ,十分便捷。
启动tomcat测试,结果都正常输出。
3.输出时间对象
输出时间对象,输出结果为一串数字
- 默认日期格式会变成一个数字,是1970年1月1日到当前日期的毫秒数
- Jackson 默认是会把时间转成timestamps形式
解决方案:取消timestamps形式 , 自定义时间格式
FastJson
fastjson.jar是阿里开发的一款专门用于Java开发的包,可以方便的实现json对象与JavaBean对象的转换,实现JavaBean对象与json字符串的转换,实现json对象与json字符串的转换。实现json的转换方法很多,最后的实现结果都是一样的。
fastjson 的 pom依赖!
fastjson 三个主要的类:
JSONObject 代表 json 对象
- JSONObject实现了Map接口, 猜想 JSONObject底层操作是由Map实现的。
- JSONObject对应json对象,通过各种形式的get()方法可以获取json对象中的数据,也可利用诸如size(),isEmpty()等方法获取"键:值"对的个数和判断是否为空。其本质是通过实现Map接口并调用接口中的方法完成的。
JSONArray 代表 json 对象数组
- 内部是有List接口中的方法来完成操作的。
JSON代表 JSONObject和JSONArray的转化
- JSON类源码分析与使用
- 仔细观察这些方法,主要是实现json对象,json对象数组,javabean对象,json字符串之间的相互转化。
代码测试,我们新建一个FastJsonDemo 类
这种工具类,我们只需要掌握使用就好了,在使用的时候在根据具体的业务去找对应的实现。
SpringMVC-06 Ajax
Ajax
1.简介
-
AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。
-
AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
-
Ajax 不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。
-
在 2005 年,Google 通过其 Google Suggest 使 AJAX 变得流行起来。Google Suggest能够自动帮你完成搜索单词。
-
Google Suggest 使用 AJAX 创造出动态性极强的 web 界面:当您在谷歌的搜索框输入关键字时,JavaScript 会把这些字符发送到服务器,然后服务器会返回一个搜索建议的列表。
-
就和国内百度的搜索框一样!
-
传统的网页(即不用ajax技术的网页),想要更新内容或者提交一个表单,都需要重新加载整个网页。
-
使用ajax技术的网页,通过在后台服务器进行少量的数据交换,就可以实现异步局部更新。
-
使用Ajax,用户可以创建接近本地桌面应用的直接、高可用、更丰富、更动态的Web用户界面。
2.伪造Ajax
我们可以使用前端的一个标签来伪造一个ajax的样子,iframe标签
1、新建一个module :springmvc05-Ajax , 导入web支持!
2、编写一个 ajax-frame.html 使用 iframe 测试,感受下效果
3、使用IDEA开浏览器测试一下!
利用AJAX可以做:
- 注册时,输入用户名自动检测用户是否已经存在。
- 登陆时,提示用户名密码错误
- 删除数据行时,将行ID发送到后台,后台在数据库中删除,数据库删除成功后,在页面DOM中将数据行也删除。
3.jQuery.ajax
Ajax的核心是XMLHttpRequest对象(XHR)。XHR为向服务器发送请求和解析服务器响应提供了接口。能够以异步方式从服务器获取新数据,jQuery 提供多个与 AJAX 有关的方法。
通过 jQuery AJAX 方法,您能够使用 HTTP Get 和 HTTP Post 从远程服务器上请求文本、HTML、XML 或 JSON – 同时您能够把这些外部数据直接载入网页的被选元素中。
jQuery Ajax本质就是 XMLHttpRequest,对他进行了封装,方便调用。
jQuery.ajax(...)
部分参数:
url:请求地址
type:请求方式,GET、POST(1.9.0之后用method)
headers:请求头
data:要发送的数据
contentType:即将发送信息至服务器的内容编码类型(默认: "application/x-www-form-urlencoded; charset=UTF-8")
async:是否异步
timeout:设置请求超时时间(毫秒)
beforeSend:发送请求前执行的函数(全局)
complete:完成之后执行的回调函数(全局)
success:成功之后执行的回调函数(全局)
error:失败之后执行的回调函数(全局)
accepts:通过请求头发送给服务器,告诉服务器当前客户端可接受的数据类型
dataType:将服务器端返回的数据转换成指定类型
"xml": 将服务器端返回的内容转换成xml格式
"text": 将服务器端返回的内容转换成普通文本格式
"html": 将服务器端返回的内容转换成普通文本格式,在插入DOM中时,如果包含JavaScript标签,则会尝试去执行。
"script": 尝试将返回值当作JavaScript去执行,然后再将服务器端返回的内容转换成普通文本格式
"json": 将服务器端返回的内容转换成相应的JavaScript对象
"jsonp": JSONP 格式使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数
3.1 配置web.xml
3.2 配置springmvc.xml
3.3 控制类Controller
3.4 导入jquery
可以使用在线的CDN , 也可以下载导入
3.5 编写index.jsp测试
当我们鼠标离开输入框的时候,可以看到发出了一个ajax的请求,是后台返回给我们的结果
Springmvc实现Ajax
实体类User
Controller类
添加了@RestController注解,将list转成json格式返回
前端页面
注册提示效果
Controller类
添加了@RestController注解,将list转成json格式返回
前端页面
个人博客为:
MoYu's Github Blog
MoYu's Gitee BlogSpringMVC-07 拦截器+文件上传下载
拦截器
1.概述
SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。
过滤器与拦截器的区别:拦截器是AOP思想的具体应用。
过滤器
- servlet规范中的一部分,任何java web工程都可以使用
- 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截
拦截器
- 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
- 拦截器只会拦截访问的控制器方法, 如果访问的是jsp/html/css/image/js是不会进行拦截的
2.自定义拦截器
1、新建一个Moudule , springmvc06-Interceptor , 添加web支持
2、配置web.xml 和 springmvc.xml 文件
3、编写一个拦截器
4、在springmvc的配置文件中配置拦截器
5、编写一个Controller,接收请求
6、前端 index.jsp
7.部署Tomcat,测试
3.验证用户是否登录 (认证用户)
实现思路
1、有一个登陆页面,需要写一个
controller
访问页面。2、登陆页面有一提交表单的动作。需要在
controller
中处理。判断用户名密码是否正确。如果正确,向session中写入用户信息。返回登陆成功。3、拦截用户请求,判断用户是否登陆。如果用户已经登陆。放行, 如果用户未登陆,跳转到登陆页面
测试:
1、编写一个登陆页面 login.jsp
2、编写一个Controller类
3、编写一个登陆成功的页面 success.jsp
4、在 index 页面上测试跳转
这时候测试,不用先登录也可以进入成功页面
5、编写用户登录拦截器
6.在springmvc配置文件中部署拦截器
7、Tomcat测试
OK,测试登录拦截功能无误,不登录不可以进入success.jsp
文件上传和下载
1.准备工作
文件上传是项目开发中最常见的功能之一 ,springMVC 可以很好的支持文件上传,但是SpringMVC上下文中默认没有装配MultipartResolver,因此默认情况下其不能处理文件上传工作。如果想使用Spring的文件上传功能,则需要在上下文中配置MultipartResolver。
前端表单要求:为了能上传文件,必须将表单的method设置为POST,并将enctype设置为multipart/form-data。只有在这样的情况下,浏览器才会把用户选择的文件以二进制数据发送给服务器;
对表单中的 enctype 属性做个详细的说明:
- application/x-www=form-urlencoded:默认方式,只处理表单域中的 value 属性值,采用这种编码方式的表单会将表单域中的值处理成 URL 编码方式。
- multipart/form-data:这种编码方式会以二进制流的方式来处理表单数据,这种编码方式会把文件域指定文件的内容也封装到请求参数中,不会对字符编码。
- text/plain:除了把空格转换为 "+" 号外,其他字符都不做编码处理,这种方式适用直接通过表单发送邮件。
一旦设置了enctype为multipart/form-data,浏览器即会采用二进制流的方式来处理表单数据,而对于文件上传的处理则涉及在服务器端解析原始的HTTP响应。在2003年,Apache Software Foundation发布了开源的Commons FileUpload组件,其很快成为Servlet/JSP程序员上传文件的最佳选择。
- Servlet3.0规范已经提供方法来处理文件上传,但这种上传需要在Servlet中完成。
- 而Spring MVC则提供了更简单的封装。
- Spring MVC为文件上传提供了直接的支持,这种支持是用即插即用的MultipartResolver实现的。
- Spring MVC使用Apache Commons FileUpload技术实现了一个MultipartResolver实现类:
- CommonsMultipartResolver。因此,SpringMVC的文件上传还需要依赖Apache Commons FileUpload的组件。
2.文件上传
1.导入文件上传的jar包,commons-fileupload
2、配置bean:multipartResolver
注意:这个bena的id必须为:multipartResolver , 否则上传文件会报400的错误。
CommonsMultipartFile 的 常用方法:
- String getOriginalFilename():获取上传文件的原名
- InputStream getInputStream():获取文件流
- void transferTo(File dest):将上传文件保存到一个目录文件中
3、编写前端页面
4、Controller
采用file.Transto 来保存上传的文件
1、编写Controller
测试成功
3.文件下载
文件下载步骤:
1、设置 response 响应头
2、读取文件 -- InputStream
3、写出文件 -- OutputStream
4、执行操作
5、关闭流 (先开后关)
代码
前端
正常下载,与web原生相比 方便了太多了