javaWeb(2)

javaWeb(2)

(1)RequestParam

@RequestParam注解主要有哪些参数:

value:参数名字,即入参的请求参数名字,如username表示请求的参数区中的名字为username的参数的值将传入;

required:是否必须,默认是true,表示请求中一定要有相应的参数,否则将报404错误码;

defaultValue:默认值,表示如果请求中没有同名参数时的默认值,默认值可以是SpEL表达式,如“#{systemProperties[‘java.vm.version’]}”。

作用:在SpringMVC后台控制层获取参数的方式主要有两种,一种是request.getParameter(“name”),另外一种是用注解@RequestParam直接获取。

@RequestMapping("testRequestParam")    
   public String funtion(@RequestParam String inputStr, HttpServletRequest request) {    
    System.out.println(inputStr);  

    int inputInt = Integer.valueOf(request.getParameter("inputInt"));  
    System.out.println(inputInt);  

    // ......省略  
    return "index";  
   }     

需要特别注意的是:如果用@RequestParam注解的参数是int基本类型,但是required=false,这时如果不传参数值会报错,因为不传值,会赋值为null给int,这个不可以

solution: “Consider declaring it as object wrapper for the corresponding primitive type.”建议使用包装类型代替基本类型,如使用“Integer”代替“int”

(2)mvc:annotation-driven

会自动注册

RequestMappingHandlerAdapter

RequestMappingHandlerMapping

与ExceptionHandlerExceptionResolver三个bean

还将

–支持使用ConversionService实例对表单参数进行类型转换

–支持使用@NumberFormat,@DateTimeFormat注解完成数据类型的格式化

—支持使用@RequestBody和@ResponseBody注解

(3)数据绑定**

先占个坑

(4)处理JSON

大致步骤:

1.加入jar包;

2.编写目标方法,

3.在方法上添加@ResponseBody注解

@ResponseBody
@RequestMapping("/getUsers")
public List<User> testAjax(){
  List<User> ls=new ArrayList();
  ls.add(new User("pawn",21));
  ls.add(new User("xing",20));
  return ls;
}

(5)@RequestBody和@ResponseBody

这里有个举例形象的博客

@RequestBody使用
作用:
注解用于将Controller的方法参数,根据HTTP Request Header的content-Type的内容,通过适当的HttpMessageConverter转换为JAVA类

使用时机:
POST或者PUT的数据是JSON格式或者XML格式,而不是普通的键值对形式.

@RequestMapping(value = "/testRequestBody", method= RequestMethod.POST)
    @ResponseBody
    public Person testRequestBody(@RequestBody Person p) {
        System.out.println("creating a employee:" + p);
        return p;
    }   

Ajax代码如下:

 $.ajax({
    url: "testRequestBody",
    data: '{"name":"小红","age":12}', //要用双引号!!
    contentType: "application/json;charset=utf-8", // 因为上面是JSON数据
    type: "POST",
    headers: {
//                Accept: "application/xml",
        Accept: "application/json",
    },
    success: function(data, textStatus){
        console.log(data);
        alert(data);
    },
    error: function (data, textStatus, errorThrown) {
        console.log(data);
    },
});

@ResponseBody用法

作用:

  • 该注解用于将Controller的方法返回的对象,根据HTTP Request Header的Accept的内容,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。

Request_and_Response_body

(6)@Autowired

Spring会自动将我们标记为@Autowired的元素装配好

//==================================Controller  
@Controller  
public class SimpleController {  
    @Autowired  
    private SimpleService simpleService;  
}  
//==================================Service  
@Service("simpleService")  
public class SimpleServiceImpl implements SimpleService {  
    @Autowired  
    private SimpleDao simpleDao;  
}  
//===================================Repository  
@Repository("simpleDao")  
public class SimpleDaoImpl implements SimpleDao {  
}  

这里有个超好的博客

@Autowired注解
@Autowired默认是按类型装配对象的,默认情况下它要求依赖对象必须存在
如果允许null值,可以设置它的required属性为FALSE,如@Autowired(required=false)
若想要按名称装配,可以结合@Qualifier注解一起使用,如@Autowired(required=false) @Qualifier(“personDaoBean”)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值