springmvc常用注解与类型转换

时间:2021-12-14 05:03:09

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);
}

---完---

下次补充