常用註解

1. RequestParam註解
	 作用:把請求中的指定名稱的參數傳遞給控制器中的形參賦值
	 屬性
	 value:請求參數中的名稱
	 required:請求參數中是否必須提供此參數,默認值是true,必須提供
	 代碼如下:
 /**
	* 接收請求
	* @return
	*/
	@RequestMapping(path="/hello")
	public String sayHello(@RequestParam(value="username",required=false)String name) {
	System.out.println("aaaa");
	System.out.println(name);
	return "success";
	}
	
2. RequestBody註解
	 作用:用於獲取請求體的內容(注意:get方法不可以)
	 屬性
	 required:是否必須有請求體,默認值是true
	 代碼如下:
	 /**
	* 接收請求
	* @return
	*/
	@RequestMapping(path="/hello")
	public String sayHello(@RequestBody String body) {
	System.out.println("aaaa");
	System.out.println(body);
	return "success";
	}
3.PathVariable註解
	 作用:擁有綁定url中的佔位符的。例如:url中有/delete/{id},{id}就是佔位符
	 屬性
	 value:指定url中的佔位符名稱
	 Restful風格的URL
	 請求路徑一樣,可以根據不同的請求方式去執行後臺的不同方法
	 restful風格的URL優點
		1. 結構清晰
		2. 符合標準
		3. 易於理解
		4. 擴展方便
		
	<a href="user/hello/1">入門案例</a>
	/**
	* 接收請求
	* @return
	*/
	@RequestMapping(path="/hello/{id}")
	public String sayHello(@PathVariable(value="id") String id) {
	System.out.println(id);
	return "success";
	}
4.RequestHeader註解
	 作用:獲取指定請求頭的值
	 屬性
	 value:請求頭的名稱
	 代碼如下:
	@RequestMapping(path="/hello")
	public String sayHello(@RequestHeader(value="Accept") String header) System.out.println(header);
	return "success";
	}
5.CookieValue註解
	 作用:用於獲取指定cookie的名稱的值
	 屬性
	 value:cookie的名稱
	 代碼:
	 @RequestMapping(path="/hello")
	public String sayHello(@CookieValue(value="JSESSIONID") String cookieValue) System.out.println(cookieValue);
	return "success";
	}
6.ModelAttribute註解
	 作用:出現在方法上:表示當前方法會在控制器方法執行前線執行。
	 出現在參數上:獲取指定的數據給參數賦值。
	 應用場景:
	 當提交表單數據不是完整的實體數據時,保證沒有提交的字段使用數據庫原來的數據。
	 具體的代碼
(1) 修飾的方法有返回值
	/**
	* 作用在方法,先執行
	* @param name
	* @return
	*/
	@ModelAttribute
	public User showUser(String name) {
	System.out.println("showUser執行了...");
	// 模擬從數據庫中查詢對象
	User user = new User();
	user.setName("哈哈");
	user.setPassword("123");
	user.setMoney(100d);
	return user;
	}
	/**
	* 修改用戶的方法
	* @param cookieValue
	* @return
	*/
	@RequestMapping(path="/updateUser")
	public String updateUser(User user) {
	System.out.println(user);
	return "success";
	}
(2) 修飾的方法沒有返回值
	/**
	* 作用在方法,先執行
	* @param name
	* @return
	*/
	@ModelAttribute
	public void showUser(String name,Map<String, User> map) {
	System.out.println("showUser執行了...");
	// 模擬從數據庫中查詢對象
	User user = new User();
	user.setName("哈哈");
	user.setPassword("123");
	user.setMoney(100d);
	map.put("abc", user);
	}
	/**
	* 修改用戶的方法
	* @param cookieValue
	* @return
	*/
	@RequestMapping(path="/updateUser")
	public String updateUser(@ModelAttribute(value="abc") User user) {
	System.out.println(user);
	return "success";
	}
4. SessionAttributes註解
	作用:用於多次執行控制器方法間的參數共享
	屬性
	 value:指定存入屬性的名稱
	 代碼:
	 代碼如下:
	@Controller
	@RequestMapping(path="/user")
	@SessionAttributes(value= {"username","password","age"},types=
	{String.class,Integer.class}) // 把數據存入到session域對象中
	public class HelloController {
	/**
	* 向session中存入值
	* @return
	*/
	@RequestMapping(path="/save")
	public String save(Model model) {
	System.out.println("向session域中保存數據");
	model.addAttribute("username", "root");
	model.addAttribute("password", "123");
	model.addAttribute("age", 20);
	return "success";
	}
	/**
	* 從session中獲取值
	* @return
	*/
	@RequestMapping(path="/find")
	public String find(ModelMap modelMap) {
	String username = (String) modelMap.get("username");
	String password = (String) modelMap.get("password");
	Integer age = (Integer) modelMap.get("age");
	System.out.println(username + " : "+password +" : "+age);
	return "success";
	}
	/**
	* 清除值
	* @return
	*/
	@RequestMapping(path="/delete")
	public String delete(SessionStatus status) {
		status.setComplete();
		return "success";
	}
	}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章