Spring MVC URI 通配


@RequestMapping(value={"url1","url2","url3"....}) 
//还可以配置通配符匹配多个请求

value的uri值为以下三类:

A) 
可以指定为普通的具体值;

B)  
可以指定为含有某变量的一类值(URI Template Patterns with Path Variables);

@RequestMapping(value="/owners/{ownerId}", method=RequestMethod.GET)   
public String findOwner(@PathVariable String ownerId, Model model) {   
  Owner owner = ownerService.findOwner(ownerId);     
  model.addAttribute("owner", owner);     
  return "displayOwner";    
}

C) 

可以指定为含正则表达式的一类值( URI Template Patterns with Regular Expressions);

@RequestMapping("/spring-web/{symbolicName:[a-z-]+}-{version:\d\.\d\.\d}.{extension:\.[a-z]}")   
  public void handle(@PathVariable String version, @PathVariable String extension) {       
    // ...   
  }   
}

普通URL提交参数

该格式url为:url.do?param1=mahc&param2=8888.00

需要在上文中的HelloController对象添加方法如下:

/**
     * Spring MVC URL提交参数
     * @param name
     * @return
     */
    @RequestMapping("/param")
    public ModelAndView getInfo(@RequestParam("name") String name){
         
        String str = name +  "Spring MVC示例";
        return new ModelAndView(message, str, str);
    }

访问该方法的url格式为:param?name=hoking(Get方式)。该方式是很普通的提交方式。用注解@RequestParam绑定请求参数a到变量a当请求参数a不存在时会有异常发生,可以通过设置属性required=false解决,例如: @RequestParam(value=a, required=false)。如上文中,通过name获取提交的参数。

RESTful风格的URL参数

接下来我们了解一下Restful风格。HTTP请求方法在RESTful Web 服务中的典型应用资源GET PUT POST DELETE一组资源的URI,比如http://example.com/resources/单个资源的URI,比如www.2cto.com。更多信息请阅读如下文章。

具体的实现需要在上文中的HelloController对象添加方法如下:

/**
     * Spring MVC 支持RESTful风格的URL参数
     * 
     * @return
     */
    @RequestMapping("/index/{username}")
    public String getMessage(@PathVariable("username") String username){
        System.out.println(username);
        return message;
    }

上文使用了@PathVariable。PathVariable与RequestParam的不同在于。

使用@RequestMapping URI template样式映射时,即 someUrl/{paramId}, 这时的paramId可通过@Pathvariable注解绑定它传过来的值到方法的参数上。

访问该方法的url格式为:index/mahoking。@PathVariable是用来获得请求url中的动态参数的,十分方便。mahoking即是username的动态值。

上文中的getMessage()方法,返回String对象,该值代表页面的跳转地址,不包含扩展名(后缀名)。本例中为message.jsp页面。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值