springmvc常用注解与类型转换

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
 
1.@RequestMapping用来定义访问的URL,你可以为整个类定义一个

@RequestMapping,或者为每个方法指定一个。
把@RequestMapping放在类级别上,这可令它与方法级别上的

@RequestMapping注解协同工作,取得缩小选择范围的效果。
例如:
@RequestMapping("/test")
public class TestController {}
则,该类下的所有访问路径都在/test之下。

2.将@RequestMapping用于整个类不是必须的,如果没有配置,所有的方法

的访问路径配置将是完全独立的,没有任何关联。
 
3.完整的参数项为:@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
 
4.value的配置还可以采用模版变量的形式 ,例如:@RequestMapping

(value="/owners/{ownerId}", method=RequestMethod.GET),这点将在介

绍@PathVariable中详细说明。
 
5.@RequestMapping params的补充说明,你可以通过设置参数条件来限制

访问地址,例如params="myParam=myValue"表达式,访问地址中参数只有

包含了该规定的值"myParam=myValue"才能匹配得上,类似"myParam"之类

的表达式也是支持的,表示当前请求的地址必须有该参数(参数的值可以是

任意),"!myParam"之类的表达式表明当前请求的地址不能包含具体指定的

参数"myParam"。
 
6.有一点需要注意的,如果为类定义了访问地址为*.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);
}

 

 

---完---

下次补充

 

转载于:https://www.cnblogs.com/chenyq/p/5363808.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值