Solon

十五、与Spring、Jsr330的注解对比

1、注解对比

SolonSpringJSR 330
@Inject *@Autowired@Inject注入Bean(by type)
@Inject("name")@Qualifier +
@Autowired
@Qualifier +
@Inject
注入Bean(by name)
@Inject("${name}")@Value("${name}")-注入配置
@Component@Component@Named托管组件
@Singleton@Scope(“singleton”)@Singleton单例(Solon 默认是单例)
@Singleton(false)@Scope(“prototype”)-非单例
@Init *@PostConstruct-构造完成并注入后的初始化
@Configuration@Configuration-配置类
@Bean@Bean配置组件
@Mapping@RequestMapping...-映射
@Controller@Controller
@RestController
-控制器类(有类代理)
@Service@Service-服务类(有类代理)
@Dao@Dao-数据访问类(有类代理)
@Import@Import +
@ComponentScan
-组件导入或扫描
  • Solon 的 @Inject 算是: Spring 的@Value、@Autowired、@Qualifier 三者的结合,但又不完全等价
  • Solon 的 @Import 算是:Spring 的@Import、@ComponentScan 两者的结合,即有导入功能也有扫描功能
  • Solon 托管的 Bean 初始化顺序:new() - > @Inject - > @Init
  • 注1:Method@Bean,只执行一次(只在 @Configuration 里有效)
  • 注2:@Inject 的参数注入,只在Method@Bean上有效
  • 注3:@Inject 的类型注入,只在@Configuration类上有效

2、部分用例说明

Solon 强调有节制的注解使用,尤其对于增加处理链路的操会比较节制。

  • @Component(组件托管:基于 name 或者 类型;且只记录第一次的注册)
@Component
public class UserService{
    @Db("db1")    //@Db为第三方扩展的注入注解
    BaseMapper<User> mapper;
    
    UserModel getUser(long puid){
        return db1.selectById(puid);
    }
}

/* @Component("userService")
public class UserService{
    @Db("db1") 
    BaseMapper<User> mapper;
    
    UserModel getUser(long puid){
        return db1.selectById(puid);
    }
} */
  • @Controller
@Singleton(false)    //非单例注解
@Controller
public class UserController{
    @Inject("${message.notnull}")
    String message;
    
    @Inject
    UserService userService
    
    @Mapping("/user/{puid}")
    public Object user(Long puid){
        if(puid == null){
            return message;
        }
        return userService.getUser(puid);
    }
}
  • @Configuration
@Configuration
public class Config {
    @Bean("db1")
    public DataSource db1(@Inject("${test.db1}") HikariDataSource ds) {
        return ds;
    }
}

//系统异常监听(这个系统会发的,还可以监听不同的异常)
//
@Configuration
public class ThrowableListener implements EventListener<Throwable> {
    WaterLogger log = new WaterLogger("rock_log");

    @Override
    public void onEvent(Throwable err) {
        Context ctx = Context.current();

        if (ctx != null) {
            String _in = ONode.stringify(ctx.paramMap());

            log.error(ctx.path(), _in, err);
        }
    }
}