@RestController
public class myController
{
@RequestMapping(“/hello”)
public Map<String,Object> hello(
//带key,拿一个,否则拿所有
@RequestHeader(“user-agent”) String header,
@RequestHeader Map<String,String> map
)
{
Map<String,Object> m=new HashMap<>();
m.put(“header”,header);
m.put(“map”,map);
return m;
}
}
@RestController
public class myController
{
@RequestMapping(“/hello”)
public Map<String,Object> hello(@RequestParam(“age”)Integer age,
@RequestParam(“hobby”) List list,
@RequestParam Map<String,String> map)
{
Map<String,Object> m=new HashMap<>();
m.put(“age”,age);
m.put(“hobby”,list);
m.put(“map”,map);
return m;
}
}
获取指定cookie的值
@RestController
public class myController
{
@RequestMapping(“/hello”)
public Map<String,Object> hello(@CookieValue(“Idea-60bbb23f”)String value)
{
Map<String,Object> m=new HashMap<>();
m.put(“value”,value);
return m;
}
}
如果参数被声明为一个cookie类型,那么就可以获取到该cookie的所有信息:
@RestController
public class myController
{
@RequestMapping(“/hello”)
public Map<String,Object> hello(@CookieValue(“Idea-60bbb23f”) Cookie value)
{
Map<String,Object> m=new HashMap<>();
m.put(“value”,value);
return m;
}
}
获取到请求体中的数据封装到指定的对象中,只有Post方式才有请求体
@RestController
public class myController
{
@RequestMapping(“/hello”)
public Map<String,Object> hello(@RequestBody String info)
{
Map<String,Object> m=new HashMap<>();
m.put(“people”,info);
return m;
}
}
取出当前请求域中的值
@Controller
public class myController
{
@RequestMapping(“/hello”)
public String hello(HttpServletRequest request)
{
request.setAttribute(“name”,“大忽悠”);
request.setAttribute(“age”,“18”);
//这里没有模板引擎的话,无法完成页面跳转
return “forward:success”;//转发到 /success请求
}
@ResponseBody
@RequestMapping(“/success”)
public Map<String,Object> show(
@RequestAttribute(“name”)String name,
//这里是转发,因此是一次请求,所以request对象是同一个
HttpServletRequest request)
{
String rn= (String) request.getAttribute(“age”);
Map<String,Object> map=new HashMap<>();
map.put(“name”,name);
map.put(“age”,rn);
return map;
}
}
注意: 如果不引入模板引擎,那么就无法完成下面页面渲染,跳转到指定页面等功能
小应用: cookie禁用后,如何获取Jsessionid ?
session.get(a)<-----服务器按照jsessionid得到session对象<-----cookie中保存了session对象的唯一标识id<-----每次发请求携带该cookie
- url重写: /abc;jsessionid=xxxx 把cookie中保存的jsessionid的值通过矩阵变量的方式传递,和请求参数区分开来
手动开启矩阵变量的功能
我们可以使用@Configuration + WebMvcConfigurer 自定义配置,覆盖默认配置
对应配置类实现WebMvcConfigurer接口完成对springmvc默认配置的修改
**WebMvcConfigurer是一个接口。里面的方法都是default的方法,可以有选择的实现。方法的返回值都是webmvc需要配置的Bean。
所以可以实现这个接口,配合@Configuration注解自定义mvc组件。**
@Configuration//表明这是一个配置类
public class WebConfig implements WebMvcConfigurer
{
@Override
public void configurePathMatch(PathMatchConfigurer configurer) {
UrlPathHelper urlPathHelper=new UrlPathHelper();
//不移除分号后面的内容,矩阵变量功能就可以生效
urlPathHelper.setRemoveSemicolonContent(false);
configurer.setUrlPathHelper(urlPathHelper);
}
}
直接将对应组件注入容器中
@Configuration//表明这是一个配置类
public class WebConfig
{
@Bean
public WebMvcConfigurer webMvcConfigure()
{
return new WebMvcConfigurer() {
@Override
public void configurePathMatch(PathMatchConfigurer configurer) {
最后
看完上述知识点如果你深感Java基础不够扎实,或者刷题刷的不够、知识不全面
小编专门为你量身定制了一套<Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法>
针对知识面不够,也莫慌!还有一整套的<Java核心进阶手册>,可以瞬间查漏补缺
全都是一丢一丢的收集整理纯手打出来的
更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~
找小编(vip1024c)领取
不全面
小编专门为你量身定制了一套<Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法>
[外链图片转存中…(img-uAIDl1ZO-1721721035825)]
针对知识面不够,也莫慌!还有一整套的<Java核心进阶手册>,可以瞬间查漏补缺
[外链图片转存中…(img-fMTXOWJT-1721721035825)]
全都是一丢一丢的收集整理纯手打出来的
更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~
[外链图片转存中…(img-6ngmI4lr-1721721035826)]
[外链图片转存中…(img-yuAqTXTy-1721721035826)]
找小编(vip1024c)领取