springmvc常用注解与类型转换
一:前置 spring -servlet.xml 注入
<!-- 启用spring mvc 注解 -->
<context:annotation-config/> <context:component-scan base-package="com.controller"/> <!-- 启动springMvc注解功能,完成请求和注解POJO的映射 -->
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
二:枚举状态转换器(在程序里是枚举,数据库是数字转换)
2.1,一个枚举,值为数字
@JsonSerialize(as=IntValueEnum.class)
public enum BankStatus implements IntValueEnum { /** 储蓄卡 */
NORMAL(0, "储蓄卡"),
/** 信用卡 */
REPAIR(1, "信用卡")
; private int value;
private String text; private BankStatus(int val, String text) {
this.value = val;
this.text = text;
}
public int getValue() {
return value;
}
public void setValue(int value) {
this.value = value;
}
public String getText() {
return text;
} public void setText(String text) {
this.text = text;
} }
转换,直接添加,能保存到数据库
@MappedTypes({BankStatus.class})
public class BankStatusHandle extends AbstractIntValueHandle<BankStatus> { public BankStatusHandle(Class<BankStatus> type) {
super(type);
} }
//--------------------测试-------------------------
//测试添加:
在Bank类中:
private BankStatus status; //测试:
Bank bank = new Bank (1,BankStatus.NORMAL,"身份证号");
obs.insert(bank);
可添加进去
2.2 一个枚举,value为string
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.zhonglian.jinjufin.support.enums.StringValueTextEnum; @JsonSerialize(as = StringValueTextEnum.class)
public enum ProductType implements StringValueTextEnum { /** 活期产品 */
current("current", "活期产品"), /** 定期产品 */
periodical("periodical", "定期产品");
}
一样可以转换
三:自定义注释例子:
属性:
/** 注册手机号 */
@ValidateNotBlank(message = "注册手机号空")
private String mobile; /** 登陆密码 */
@ValidateNotBlank(message = "登陆密码 ")
private String password;
自定义ValidateNotBlank
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import java.lang.annotation.ElementType;
import java.lang.annotation.RetentionPolicy; /**
* @description 非空验证
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface ValidateNotBlank
{
String message() default "属性值不能为空";
}
四:注释解释:
3.1 @Controller
@Controller 负责注册一个bean 到spring 上下文中,bean 的ID 默认为类名称开头字母小写,你也可以自己指定,如下
方法一:
@Controller
public class TestController {}
方法二:
@Controller("tmpController")
public class TestController {}
3.2@RequestMapping
.@RequestMapping用来定义访问的URL,你可以为整个类定义一个
@RequestMapping,或者为每个方法指定一个。
把@RequestMapping放在类级别上,这可令它与方法级别上的
@RequestMapping注解协同工作,取得缩小选择范围的效果。
例如:
@RequestMapping("/test")
public class TestController {}
则,该类下的所有访问路径都在/test之下。
.将@RequestMapping用于整个类不是必须的,如果没有配置,所有的方法
的访问路径配置将是完全独立的,没有任何关联。
.完整的参数项为:@RequestMapping(value="",method =
{"",""},headers={},params={"",""}),各参数说明如下:
value :String[] 设置访问地址
method: RequestMethod[]设置访问方式,字符数组,查看RequestMethod
类,包括GET, HEAD, POST, PUT, DELETE, OPTIONS, TRACE,常用
RequestMethod.GET,RequestMethod.POST
headers:String[] headers一般结合method = RequestMethod.POST使用
params: String[] 访问参数设置,字符数组 例如:userId=id
.value的配置还可以采用模版变量的形式 ,例如:@RequestMapping
(value="/owners/{ownerId}", method=RequestMethod.GET),这点将在介
绍@PathVariable中详细说明。
.@RequestMapping params的补充说明,你可以通过设置参数条件来限制
访问地址,例如params="myParam=myValue"表达式,访问地址中参数只有
包含了该规定的值"myParam=myValue"才能匹配得上,类似"myParam"之类
的表达式也是支持的,表示当前请求的地址必须有该参数(参数的值可以是
任意),"!myParam"之类的表达式表明当前请求的地址不能包含具体指定的
参数"myParam"。
.有一点需要注意的,如果为类定义了访问地址为*.do,*.html之类的,则
在方法级的@RequestMapping,不能再定义value值,否则会报错,例如
Java代码
@RequestMapping("/bbs.do")
public class BbsController {
@RequestMapping(params = "method=getList")
public String getList() {
return "list";
}
@RequestMapping(value= "/spList")
public String getSpecialList() {
return "splist";
}
}
如上例:/bbs.do?method=getList 可以访问到方法getList() ;而访
问/bbs.do/spList则会报错.
3.3@ResponseBody
这个注解可以直接放在方法上,表示返回类型将会直接作为HTTP响应字节,流输出(不被放置在Model,也不被拦截为视图页面名称)。可以用于ajax。
3.4@RequestParam
@RequestParam是一个可选参数,例如:@RequestParam("id") 注解,所以
它将和URL所带参数 id进行绑定
如果入参是基本数据类型(如 int、long、float 等),URL 请求参数中
一定要有对应的参数,否则将抛出
org.springframework.web.util.NestedServletException 异常,提示无
法将 null 转换为基本数据类型.
@RequestParam包含3个配置 @RequestParam(required = ,value="",
defaultValue = "")
required :参数是否必须,boolean类型,可选项,默认为true
value: 传递的参数名称,String类型,可选项,如果有值,对应到设置方
法的参数
defaultValue:String类型,参数没有传递时为参数默认指定的值
@SessionAttributes session管理
Spring 允许我们有选择地指定 ModelMap 中的哪些属性需要转存到
session 中,以便下一个请求属对应的 ModelMap 的属性列表中还能访问
到这些属性。这一功能是通过类定义处标注 @SessionAttributes 注解来
实现的。@SessionAttributes 只能声明在类上,而不能声明在方法上。
例如
@SessionAttributes("currUser") // 将ModelMap 中属性名为currUser 的属性
@SessionAttributes({"attr1","attr2"})
@SessionAttributes(types = User.class)
@SessionAttributes(types = {User.class,Dept.class})
@SessionAttributes(types = {User.class,Dept.class},value={"attr1","attr2"})
3.5@ModelAttribute
1.应用于方法参数,参数可以在页面直接获取,相当于
request.setAttribute(,)
2.应用于方法,将任何一个拥有返回值的方法标注上 @ModelAttribute,使
其返回值将会进入到模型对象的属性列表中.
3.应用于方法参数时@ModelAttribute("xx"),须关联到Object的数据类型
,基本数据类型 如:int,String不起作用
mvc 类 例子
Controller层
@Controller
@RequestMapping("user")
@ResponseBody
public class UserController { @Resource
private UserService service; @RequestMapping("add")
public JsonResult add(User user) {
service.add(user);
}
service层
@Service
public class UserServiceImpl implements UserService { @Resource
private UserMapper mapper; public void add(user user){
mapper.insert(user);
}
}
dao层
@Repository
public interface UserMapper {
void insert();
List<User> selectUserByIds(@Param("userIds") List<Long> userIds);
}
---完---
下次补充