关于java:SpringMVC的请求与响应

7次阅读

共计 9827 个字符,预计需要花费 25 分钟才能阅读完成。

SpringMVC 的申请与响应

SpringMVC 的申请和响应 SpringMVC 的数据响应 springMVC 的数据响应 - 数据响应形式 SpringMVC 的数据响应 - 页面跳转 - 返回字符串类型 springMVC 的数据响应 - 页面跳转 - 返回 ModelAndView 模式 springMVC 的数据响应 - 页面跳转 - 返回 ModelAndVIew 模式 SpringMVC 的数据响应 - 页面跳转 - 返回 ModelAndView 回写数据 - 间接回写字符串回写数据 - 间接回写 json 格局字符串回写数据 - 返回对象或者汇合回写数据 - 返回汇合或者对象回写数据 - 知识点小结 SpringMVC 的申请 11 取得申请参数 - 申请参数类型 12 取得申请参数 - 取得基本参数类型 13 取得申请参数 - 取得 POJO 类型参数 14 取得申请参数 - 取得数组类型参数 15 取得汇合类型参数 16 动态拜访资源的开启 17 配置全局乱码过滤器 18 参数绑定注解 @RequestParam19 Restful 格调的参数的获取 20 自定义类型的转换器 21 取得 Servlet 相干 API22 取得申请头参数 SpringMVC 的数据响应 01-SpringMVC 的数据响应 - 数据响应形式(了解)1) 页面跳转间接返回字符串通过 ModelAndView 对象返回 2)回写数据间接返回字符串返回对象或汇合 02-SpringMVC 的数据响应 - 页面跳转 - 返回字符串模式(利用)

03-SpringMVC 的数据响应 - 页面跳转 - 返回 ModelAndView 模式 1(利用)在 Controller 中办法返回 ModelAndView 对象,并且设置视图名称 @RequestMapping(value=”/quick2″)

public ModelAndView save2(){
    /*
        Model: 模型 作用封装数据
        View:视图 作用展现数据
     */
    ModelAndView modelAndView = new ModelAndView();
    // 设置模型数据
    modelAndView.addObject("username","itcast");
    // 设置视图名称
    modelAndView.setViewName("success");

    return modelAndView;
}04-SpringMVC 的数据响应 - 页面跳转 - 返回 ModelAndView 模式 2(利用)n 在 Controller 中办法形参上间接申明 ModelAndView,无需在办法中本人创立,在办法中间接应用该对象设置视图,同样能够跳转页面 @RequestMapping(value="/quick3")
public ModelAndView save3(ModelAndView modelAndView){modelAndView.addObject("username","itheima");
    modelAndView.setViewName("success");
    return modelAndView;
}

@RequestMapping(value=”/quick4″)

public String save4(Model model){model.addAttribute("username","博学谷");
    return "success";
}05-SpringMVC 的数据响应 - 页面跳转 - 返回 ModelAndView3(利用)在 Controller 办法的形参上能够间接应用原生的 HttpServeltRequest 对象,只需申明即可 @RequestMapping(value="/quick5")
public String save5(HttpServletRequest request){request.setAttribute("username","酷丁鱼");
    return "success";
}06-SpringMVC 的数据响应 - 回写数据 - 间接回写字符串 (利用) 通过 SpringMVC 框架注入的 response 对象,应用 response.getWriter().print(“hello world”) 回写数据,此时不须要视图跳转,业务办法返回值为 void 将须要回写的字符串间接返回,但此时须要通过 @ResponseBody 注解告知 SpringMVC 框架,办法返回的字符串不是跳转是间接在 http 响应体中返回 @RequestMapping(value="/quick7")
@ResponseBody  // 告知 SpringMVC 框架 不进行视图跳转 间接进行数据响应
public String save7() throws IOException {return "hello itheima";}

@RequestMapping(value="/quick6")
public void save6(HttpServletResponse response) throws IOException {response.getWriter().print("hello itcast");
}07-SpringMVC 的数据响应 - 回写数据 - 间接回写 json 格局字符串(利用)@RequestMapping(value="/quick8")
@ResponseBody
public String save8() throws IOException {return "{\"username\":\"zhangsan\",\"age\":18}";
}手动拼接 json 格局字符串的形式很麻烦,开发中往往要将简单的 java 对象转换成 json 格局的字符串,咱们能够应用 web 阶段学习过的 json 转换工具 jackson 进行转换, 通过 jackson 转换 json 格局字符串,回写字符串 @RequestMapping(value="/quick9")
@ResponseBody
public String save9() throws IOException {User user = new User();
    user.setUsername("lisi");
    user.setAge(30);
    // 应用 json 的转换工具将对象转换成 json 格局字符串在返回
    ObjectMapper objectMapper = new ObjectMapper();
    String json = objectMapper.writeValueAsString(user);

    return json;
}08-SpringMVC 的数据响应 - 回写数据 - 返回对象或汇合 (利用) 通过 SpringMVC 帮忙咱们对对象或汇合进行 json 字符串的转换并回写,为处理器适配器配置音讯转换参数,指定应用 jackson 进行对象或汇合的转换,因而须要在 spring-mvc.xml 中进行如下配置:<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
    <property name="messageConverters">
        <list>
            <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/>
        </list>
    </property>
</bean>@RequestMapping(value="/quick10")
@ResponseBody
// 冀望 SpringMVC 主动将 User 转换成 json 格局的字符串
public User save10() throws IOException {User user = new User();
    user.setUsername("lisi2");
    user.setAge(32);
    return user;
}09-SpringMVC 的数据响应 - 回写数据 - 返回对象或汇合 2(利用)在办法上增加 @ResponseBody 就能够返回 json 格局的字符串,然而这样配置比拟麻烦,配置的代码比拟多,因而,咱们能够应用 mvc 的注解驱动代替上述配置 <mvc:annotation-driven/> 在 SpringMVC 的各个组件中,处理器映射器、处理器适配器、视图解析器称为 SpringMVC 的三大组件。应用 <mvc:annotation-driven /> 主动加载 RequestMappingHandlerMapping(解决映射器)和 RequestMappingHandlerAdapter(处 理 适 配 器),可用在 Spring-xml.xml 配置文件中应用 <mvc:annotation-driven /> 代替注解处理器和适配器的配置。同时应用 <mvc:annotation-driven /> 默认底层就会集成 jackson 进行对象或汇合的 json 格局字符串的转换 10-SpringMVC 的数据响应 - 常识要点小结 (了解,记忆)1)页面跳转间接返回字符串通过 ModelAndView 对象返回 2)回写数据间接返回字符串 HttpServletResponse 对象间接写回数据,HttpServletRequest 对象带回数据,Model 对象带回数据或者 @ResponseBody 将字符串数据写回返回对象或汇合 @ResponseBody+<mvc:annotation-driven/>SpringMVC 的申请 11-SpringMVC 的申请 - 取得申请参数 - 申请参数类型(了解) 客户端申请参数的格局是:name=value&name=value……服务器端要取得申请的参数,有时还须要进行数据的封装,SpringMVC 能够接管如下类型的参数根本类型参数 POJO 类型参数数组类型参数汇合类型参数 12-SpringMVC 的申请 - 取得申请参数 - 取得根本类型参数 (利用)Controller 中的业务办法的参数名称要与申请参数的 name 统一,参数值会主动映射匹配。并且能主动做类型转换;主动的类型转换是指从 String 向其余类型的转换 http://localhost:8080/itheima_springmvc1/quick9?username=zhangsan&age=12@RequestMapping(value="/quick11")    @ResponseBody    public void save11(String username,int age) throws IOException {System.out.println(username);        System.out.println(age);    }13-SpringMVC 的申请 - 取得申请参数 - 取得 POJO 类型参数(利用)Controller 中的业务办法的 POJO 参数的属性名与申请参数的 name 统一,参数值会主动映射匹配。package com.itheima.domain;public class User {private String username;    private int age;    public String getUsername() {return username;}    public void setUsername(String username) {this.username = username;}    public int getAge() {        return age;}    public void setAge(int age) {this.age = age;}    @Override    public String toString() {        return "User{" +                "username='" + username + '\'' +                ", age=" + age +                '}';    }}@RequestMapping(value="/quick12")    @ResponseBody    public void save12(User user) throws IOException {System.out.println(user);    }14-SpringMVC 的申请 - 取得申请参数 - 取得数组类型参数(利用)Controller 中的业务办法数组名称与申请参数的 name 统一,参数值会主动映射匹配。@RequestMapping(value="/quick13")    @ResponseBody    public void save13(String[] strs) throws IOException {System.out.println(Arrays.asList(strs));    }15-SpringMVC 的申请 - 取得申请参数 - 取得汇合类型参数 1(利用) 取得汇合参数时,要将汇合参数包装到一个 POJO 中才能够。<form action="${pageContext.request.contextPath}/user/quick14" method="post">        <%-- 表明是第一个 User 对象的 username age--%>        <input type="text" name="userList[0].username"><br/>        <input type="text" name="userList[0].age"><br/>        <input type="text" name="userList[1].username"><br/>        <input type="text" name="userList[1].age"><br/>        <input type="submit" value="提交">    </form>package com.itheima.domain;import java.util.List;public class VO {private List<User> userList;    public List<User> getUserList() {return userList;}    public void setUserList(List<User> userList) {this.userList = userList;}    @Override    public String toString() {        return "VO{" +                "userList=" + userList +                '}';    }}@RequestMapping(value="/quick14")    @ResponseBody    public void save14(VO vo) throws IOException {System.out.println(vo);    }16-SpringMVC 的申请 - 取得申请参数 - 取得汇合类型参数 2(利用)当应用 ajax 提交时,能够指定 contentType 为 json 模式,那么在办法参数地位应用 @RequestBody 能够间接接管汇合数据而无需应用 POJO 进行包装 <script src="${pageContext.request.contextPath}/js/jquery-3.3.1.js"></script>    <script>        var userList = new Array();        userList.push({username:"zhangsan",age:18});        userList.push({username:"lisi",age:28});        $.ajax({type:"POST",            url:"${pageContext.request.contextPath}/user/quick15",            data:JSON.stringify(userList),            contentType:"application/json;charset=utf-8"        });    </script>@RequestMapping(value="/quick15")    @ResponseBody    public void save15(@RequestBody List<User> userList) throws IOException {System.out.println(userList);    }17-SpringMVC 的申请 - 取得申请参数 - 动态资源拜访的开启 (利用) 当有动态资源须要加载时,比方 jquery 文件,通过谷歌开发者工具抓包发现,没有加载到 jquery 文件,起因是 SpringMVC 的前端控制器 DispatcherServlet 的 url-pattern 配置的是 /, 代表对所有的资源都进行过滤操作,咱们能够通过以下两种形式指定放行动态资源:•在 spring-mvc.xml 配置文件中指定放行的资源​ <mvc:resources mapping="/js/**"location="/js/"/>•应用 <mvc:default-servlet-handler/> 标签 <!-- 开发资源的拜访 -->    <!--<mvc:resources mapping="/js/**" location="/js/"/>    <mvc:resources mapping="/img/**" location="/img/"/>-->    <mvc:default-servlet-handler/>18-SpringMVC 的申请 - 取得申请参数 - 配置全局乱码过滤器 (利用) 当 post 申请时,数据会呈现乱码,咱们能够设置一个过滤器来进行编码的过滤。<!-- 配置全局过滤的 filter-->    <filter>        <filter-name>CharacterEncodingFilter</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>    </filter>    <filter-mapping>        <filter-name>CharacterEncodingFilter</filter-name>        <url-pattern>/*</url-pattern>    </filter-mapping>19-SpringMVC 的申请 - 取得申请参数 - 参数绑定注解 @RequestParam(利用)当申请的参数名称与 Controller 的业务办法参数名称不统一时,就须要通过 @RequestParam 注解显示的绑定 <form action="${pageContext.request.contextPath}/quick16" method="post">    <input type="text" name="name"><br>    <input type="submit" value="提交"><br></form>@RequestMapping(value="/quick16")    @ResponseBody    public void save16(@RequestParam(value="name",required = false,defaultValue = "itcast") String username) throws IOException {System.out.println(username);    }20-SpringMVC 的申请 - 取得申请参数 -Restful 格调的参数的获取 (利用)Restful 是一种软件架构格调、设计格调,而不是规范,只是提供了一组设计准则和约束条件。次要用于客户端和服务器交互类的软件,基于这个格调设计的软件能够更简洁,更有档次,更易于实现缓存机制等。Restful 格调的申请是应用“url+ 申请形式”示意一次申请目标的,HTTP 协定外面四个示意操作形式的动词如下:GET:用于获取资源 POST:用于新建资源 PUT:用于更新资源 DELETE:用于删除资源例如:/user/1 GET:失去 id = 1 的 user/user/1 DELETE:删除 id = 1 的 user/user/1 PUT:更新 id = 1 的 user/user POST:新增 user 上述 url 地址 /user/ 1 中的 1 就是要取得的申请参数,在 SpringMVC 中能够应用占位符进行参数绑定。地址 /user/ 1 能够写成 /user/{id},占位符{id} 对应的就是 1 的值。在业务办法中咱们能够应用 @PathVariable 注解进行占位符的匹配获取工作。http://localhost:8080/itheima_springmvc1/quick17/zhangsan@RequestMapping(value="/quick17/{name}")@ResponseBody public void save17(@PathVariable(value="name") String username) throws IOException {System.out.println(username); }21-SpringMVC 的申请 - 取得申请参数 - 自定义类型转换器 (利用)SpringMVC 默认曾经提供了一些罕用的类型转换器,例如客户端提交的字符串转换成 int 型进行参数设置。然而不是所有的数据类型都提供了转换器,没有提供的就须要自定义转换器,例如:日期类型的数据就须要自定义转换器。public class DateConverter implements Converter<String, Date> {public Date convert(String dateStr) {// 将日期字符串转换成日期对象 返回        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");        Date date = null;        try {date = format.parse(dateStr);        } catch (ParseException e) {e.printStackTrace();        }        return date;    }}@RequestMapping(value="/quick18")    @ResponseBody    public void save18(Date date) throws IOException {System.out.println(date);    }22-SpringMVC 的申请 - 取得申请参数 - 取得 Servlet 相干 API(利用)SpringMVC 反对应用原始 ServletAPI 对象作为控制器办法的参数进行注入,罕用的对象如下:HttpServletRequestHttpServletResponseHttpSession@RequestMapping(value="/quick19")    @ResponseBody    public void save19(HttpServletRequest request, HttpServletResponse response, HttpSession session) throws IOException {System.out.println(request);        System.out.println(response);        System.out.println(session);    }23-SpringMVC 的申请 - 取得申请参数 - 取得申请头信息(利用) 应用 @RequestHeader 能够取得申请头信息,相当于 web 阶段学习的 request.getHeader(name)@RequestHeader 注解的属性如下:value:申请头的名称 required:是否必须携带此申请头 @RequestMapping(value="/quick20")    @ResponseBody    public void save20(@RequestHeader(value = "User-Agent",required = false) String user_agent) throws IOException {System.out.println(user_agent);    }应用 @CookieValue 能够取得指定 Cookie 的值 @CookieValue 注解的属性如下:value:指定 cookie 的名称 required:是否必须携带此 cookie @RequestMapping(value="/quick21")    @ResponseBody    public void save21(@CookieValue(value = "JSESS

正文完
 0