SpringMVC之Controller

一个简单HelloController实现,请求URL:localhost:8080/hello

@Controller  
public class HelloController {  
  
    @RequestMapping(value = "/hello")  
    @ResponseBody  
    public String hello(){  
        return "hello world";  
    }  
}

@Controller

表明了被注解类的服务角色是控制器,还有服务层,组件等角色。这两个使用的是:@Service和@Component。其实它们并没有

实际意义,只是被Spring扫描到后自动创建这些类的对象。要让Spring能扫描到,需要在beans中添加:

<context:component-scan base-package=""/> base-package指定包名,表示扫那个包下所有类,包括子包下。

@RequestMapping

表示映射的URL,作用于类上或方法上。作用于类上,那个该Cotroller类的handler方法映射的URL,都是相对于它。这个test方法映射的URL就是/mapping/test
@Controller
@RequestMapping(value = "/mapping")
public class MappingController {

    @RequestMapping(value = "/test")
    @ResponseBody
    public String test(){
        return "test";
    }

}
method:指定匹配的请求方式
consumes:当 Content-Type 请求头匹配可消费的媒体类型,才认为这个请求是可映射的 ——(验证没起作用)
produces:当 Accept 请求头匹配可消费的媒体类型,才认为这个请求是可映射的。 并且响应内容按这个媒体类型生成
params:使用 "myParam", "!myParam", 或 "myParam=myValue"。前两种情况表示 存在/不存在,第三种指定了参数值
headers:使用 "myHeader", "!myHeader", 或 "myHeader=myValue"。前两种情况表示 存在/不存在,第三种指定了参数值

@RequestMapping(value = "/test2", method = RequestMethod.GET,
            consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE,
            params = "myParam=myValue", headers = "myHeader=myValue")
    @ResponseBody
    public String test2(){
        return "test2";
    }

解决@ResponseBody乱码,就是produces那个红色字体应用

@RequestMapping(value = "/user/{id}", produces = "application/json; charset=utf-8")
    @ResponseBody
    public String getUserById(@PathVariable("id") User user){
        return "你好 user";
    }

@RequestParam

将请求参数绑定到方法参数
@RequestMapping(value = "/user/id")
    @ResponseBody
    public String getUser(@RequestParam(value = "id") int id){
        return "user is " + id;
    }
value:指定请求中参数名称
required:是否必须的,默认是true。如果是必须的,而请求中没有这个参数,则handler方法处理不了映射的URL
defaultValue:指定默认值
请求URL:localhost:8080/user/id?id=1

@ResponseBody

将返回数据写到 HTTP 响应体里,Spring 使用 HttpMessageConverter 将返回对象转换为响应体。

Handler方法支持的参数类型

Request 或 response 对象: 选择任意指定的 request 或 response 类型

Session 对象:需要是 HttpSession 类型
java.util.Locale  :当前请求本地化,取决与是 Servlet 环境配置的 LocaleResolver

java.io.InputStream / java.io.Reader访问请求的内容

java.io.OutputStream / java.io.Writer产生 response 的内容

org.springframework.http.HttpMethod访问 HTTP 请求方法

java.security.Principal包含了当前授权用户

@PathVariable 访问 URI 模版变量

@MatrixVariable 访问矩阵变量

@RequestHeader 访问指定 Servlet request 的 HTTP 头字段

@RequestBody 访问 HTTP 请求体

@RequestPart 访问 "multipart/form-data" 请求的内容

HttpEntity<?> 访问 Servlet request 的HTTP 头和内容 

java.util.Map / org.springframework.ui.Model / org.springframework.ui.ModelMap 暴露key-value值给 web 视图使用

org.springframework.web.servlet.mvc.support.RedirectAttributes 保持key-value值可以被重定向后还能使用(redirect)

org.springframework.validation.Errors / org.springframework.validation.BindingResult 验证数据或者绑定数据出现错误

org.springframework.web.util.UriComponentsBuilder 访问URL

Handler方法支持的返回类型

ModelAndView :返回视图和model,model可以在视图被使用

Model :和ModelAndView一样,只是视图名字由RequestToViewNameTranslator决定

Map :和Model一样,视图名字由RequestToViewNameTranslator决定。保存数据以key-value方式

View :和ModelAndView一样,只是它的Model放在handler方法中。

String :返回视图逻辑名,保存数据用@ModelAttribute或者Model参数

void :请求响应自己处理或者返回视图由RequestToViewNameTranslator决定

HttpEntity<?> 或 ResponseEntity<?> :entity body作为请求响应体

HttpHeaders :无响应体

Callable<?> :SpringMVC管理异步返回结果

DeferredResult<?> 自己管理异步返回结果

ListenableFuture<?> 和DeferredResult一样


源代码https://github.com/duansiman/SpringMVC

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值