springmvc 开涛 生产者/消费者

媒体类型:

text/html, text/plain, text/xml
image/gif, image/jpg, image/png
application/x-www-form-urlencodeed, application/json, application/xml  有q参数,q参数为媒体类型的质量因子,越大则优先权越高(从0到1)
multipart/form-data

内容类型:Content-Type:MIME  有charset参数

服务器端有header, 客户端有Accept,扩展名,参数-ContentNegotiatingViewResolver(简单方法)

spring3.1通过consume和product来限定

窄化时是覆盖而非继承,其他(header,param)是继承

服务器端header详解

1、form get

@RequestMapping("/content")
public ModelAndView showForm(@ModelAttribute("user") User user){
	ModelAndView mv = new ModelAndView();
	mv.setViewName("hello");
	return mv;
}

2、form post x

@RequestMapping(value="/content", method=RequestMethod.POST, headers="Content-Type=application/x-www-form-urlencoded")
public ModelAndView request1(HttpServletRequest request){
	//System.out.println("/content post");

	String contentType=request.getContentType();
	System.out.println("contentType:"+contentType);

	String characterEncoding=request.getCharacterEncoding();
	System.out.println("characterEncoding:"+characterEncoding);		

	System.out.println(request.getParameter("c"));

	ModelAndView mv = new ModelAndView();
	mv.setViewName("success");
	return mv;
}

3、form post json

@RequestMapping(value="/content", method=RequestMethod.POST, headers="Content-Type=application/json")
public void request2(HttpServletRequest request, HttpServletResponse response) throws IOException{
	System.out.println("/json content post");
	System.out.println("charset:"+request.getCharacterEncoding());

	InputStream is = request.getInputStream();
	byte bytes[] = new byte[request.getContentLength()];
	is.read(bytes);		

	String jsonStr = new String(bytes, request.getCharacterEncoding());
	System.out.println("json data:"+jsonStr);		

	ModelAndView mv = new ModelAndView();
	mv.setViewName("success");
	return mv;	

}

4、form post x ClientHttpRequest

@RequestMapping(value="/content", method=RequestMethod.POST, headers="Content-Type=application/x-www-form-urlencoded")
public void request(HttpServletResponse response) throws IOException, URISyntaxException{
	System.out.println("/x content post");

	String url = "http://localhost:8080/springmvc/content";
	ClientHttpRequest request = new SimpleClientHttpRequestFactory().createRequest(new URI(url), HttpMethod.POST);
	request.getHeaders().set("Content-Type", "application/json;charset=gbk");
	String jsonData = "{\"username\":\"zhang\"}";
	request.getBody().write(jsonData.getBytes("gbk"));
	request.execute();
	System.out.println("status:"+response.getStatus());	

	response.setContentType("text/html;charset=utf-8");
	response.getWriter().write("json response");	

}

1-2正常情况

1-3没法设置json,所以1-4-3-4

2注释掉,因为get想直接到post x

ClientHttpRequest与真正的HttpServletResponse不同,有些方法不太一样。

客户端Accept

不太了解,client的方法

private static void jsonRequest() throws IOException, URISyntaxException {
    //请求的地址
    String url = "http://localhost:9080/springmvc-chapter6/response/ContentType";
    //①创建Http Request(内部使用HttpURLConnection)
    ClientHttpRequest request =
        new SimpleClientHttpRequestFactory().
            createRequest(new URI(url), HttpMethod.POST);
    //②设置客户端可接受的媒体类型(即需要什么类型的响应体数据)
    request.getHeaders().set("Accept", "application/json");
    //③发送请求并得到响应
    ClientHttpResponse response = request.execute();
    //④得到响应体的编码方式
    Charset charset = response.getHeaders().getContentType().getCharSet();
    //⑤得到响应体的内容
    InputStream is = response.getBody();
    byte bytes[] = new byte[(int)response.getHeaders().getContentLength()];
    is.read(bytes);
    String jsonData = new String(bytes, charset);
    System.out.println("charset : " + charset + ", json data : " + jsonData);
}

spring3.1

需要添加的bean

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
consumes = {application/json};
produces = {application/json}

  

时间: 2024-12-29 10:33:30

springmvc 开涛 生产者/消费者的相关文章

springmvc 开涛 拦截器

拦截器有三个方法:preHandle, postHandle, afterCompletion ***-servlet.xml <bean name="/test" class="cn.javass.chapter5.web.controller.TestController"/> <bean id="handlerInterceptor1" class="cn.javass.chapter5.web.intercep

spring--处理器拦截器详解——跟着开涛学SpringMVC

5.1.处理器拦截器简介 Spring Web MVC的处理器拦截器(如无特殊说明,下文所说的拦截器即处理器拦截器) 类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理.   5.1.1.常见应用场景 1.日志记录:记录请求信息的日志,以便进行信息监控.信息统计.计算PV(Page View)等. 2.权限检查:如登录检测,进入处理器检测检测是否登录,如果没有直接返回到登录页面: 3.性能监控:有时候系统在某段时间莫名其妙的慢,可以通过拦截器在进入处理器之前记录开始时

生产者消费者模式(转)

本文转载自博文系列架构设计:生产者/消费者模式.文中对原文格式进行了稍加整理. 概述 今天打算来介绍一下“生产者/消费者模式”,这玩意儿在很多开发领域都能派上用场.由于该模式很重要,打算分几个帖子来介绍.今天这个帖子先来扫盲一把.如果你对这个模式已经比较了解,请跳过本扫盲帖,直接看下一个帖子(关于该模式的具体应用) . 看到这里,可能有同学心中犯嘀咕了:在四人帮(GOF)的23种模式里面似乎没听说过这种嘛!其实GOF那经典的23种模式主要是基于OO的(从书名<Design Patterns: E

生产者/消费者模型

http://www.cnblogs.com/xrq730/p/4855663.html 什么是生产者/消费者模型 一种重要的模型,基于等待/通知机制.生产者/消费者模型描述的是有一块缓冲区作为仓库,生产者可将产品放入仓库,消费者可以从仓库中取出产品,生产者/消费者模型关注的是以下几个点: 1.生产者生产的时候消费者不能消费 2.消费者消费的时候生产者不能生产 3.缓冲区空时消费者不能消费 4.缓冲区空时生产者不能生产 生产者/模型作为一种重要的模型,它的优点在于: 1.解耦.因为多了一个缓冲区

多线程:生产者/消费者模式

生产者/消费者模式 实际上,很多后台服务程序并发控制的基本原理都可以归纳为生产者/消费者模式. 生产者消费问题是研究多线程程序时绕不开的经典问题之一,它描述是有一块缓冲区作为仓库,消费者则可以从仓库中取走产品.解决生产者/消费者问题的方法可以分为两类: 采用某种机制保护生产者和消费者之间的同步: 生产者和消费者之间建立一个管道. 第一种方式有较高的效率,并且易于实现,代码的可控制性较好,属于常用的模式. 第二种管道缓冲不易控制,被传输数据对象不易于封装,实用性不强. 同步问题的核心在于:如何保证

环形缓冲区的设计及其在生产者消费者模式下的使用(并发有锁环形队列)

1.环形缓冲区 缓冲区的好处,就是空间换时间和协调快慢线程.缓冲区可以用很多设计法,这里说一下环形缓冲区的几种设计方案,可以看成是几种环形缓冲区的模式.设计环形缓冲区涉及到几个点,一是超出缓冲区大小的的索引如何处理,二是如何表示缓冲区满和缓冲区空,三是如何入队.出队,四是缓冲区中数据长度如何计算. ps.规定以下所有方案,在缓冲区满时不可再写入数据,缓冲区空时不能读数据 1.1.常规数组环形缓冲区 设缓冲区大小为N,队头out,队尾in,out.in均是下标表示: 初始时,in=out=0 队头

转: 【Java并发编程】之十三:生产者—消费者模型(含代码)

转载请注明出处:http://blog.csdn.net/ns_code/article/details/17249321 生产者消费者问题是线程模型中的经典问题:生产者和消费者在同一时间段内共用同一存储空间,生产者向空间里生产数据,而消费者取走数据. 这里实现如下情况的生产--消费模型: 生产者不断交替地生产两组数据"姓名--1 --> 内容--1","姓名--2--> 内容--2",消费者不断交替地取得这两组数据,这里的"姓名--1&quo

13 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件  queue队列 生产者消费者模型 Queue队列 开发一个线程池

本节内容 操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者消费者模型 Queue队列 开发一个线程池 进程 语法 进程间通讯 进程池 操作系统发展史 手工操作(无操作系统) 1946年第一台计算机诞生--20世纪50年代中期,还未出现操作系统,计算机工作采用手工操作方式. 手工操作程序员将对应于程序和数据的已穿孔的纸带(或卡片)装入输入机,然后启动输入机把

生产者/消费者问题的多种Java实现方式--转

实质上,很多后台服务程序并发控制的基本原理都可以归纳为生产者/消费者模式,而这是恰恰是在本科操作系统课堂上老师反复讲解,而我们却视而不见不以为然的.在博文<一种面向作业流(工作流)的轻量级可复用的异步流水开发框架的设计与实现>中将介绍一种生产者/消费者模式的具体应用. 生产者消费者问题是研究多线程程序时绕不开的经典问题之一,它描述是有一块缓冲区作为仓库,生产者可以将产品放入仓库,消费者则可以从仓库中取走产品.解决生产者/消费者问题的方法可分为两类:(1)采用某种机制保护生产者和消费者之间的同步