尝试使用注解开发

本文探讨了Spring和Hibernate采用注解配置后的变化。Spring通过@Component等注解简化了Bean的配置,而Hibernate则利用注解SessionFactoryBean实现了实体类的一次性配置。这些改变大大减少了XML配置工作,并提升了开发效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PS:貌似很早大家就开始用了,小小的跟进了一下

Spring中的变化

以前在Spring中配置一个Bean,都是在一个XML中,这样:

<bean id="sendMsgService" class="mesModel.service.Impl.MsgSendServiceImpl">

        <property name="msgSendDAO" ref="msgSendDAO"/>

 </bean>

 

 

现在这些XML配置都可以去掉了,applicationContext.xml文件里加上

 

<context:component-scan base-package="com.hjx" />

 

 

 

以后,就只需要在每个类上面加上@Component就可以了,在要注入的属性上面加上@Autowired。当然除了@Component以外,还有@Service、@Repository和@Controller,目前它们只是语义上和@Component有区别,大家也看的出来,是领域里面的服务,仓储等。

 

Hibernate的变化

 

以前配置一个Entity,需要在一个XML文件和一个类文件中,同时还要在XML文件中配置,现在使用Spring的AnnotationSessionFactoryBean,在XMl文件中一次性配置,以后就不用管配置文件了,特别重要的是packagesToScan属性,如下:

<property name="packagesToScan" value="com/hjx/entity/"/>

 

这样以后只要你在com.hjx.entity加入类文件就可以了,不用XML文件,当然类文件里面少不了一些hibernate注解。

至于表示层,还没决定是用FLEX还是用html+CSS+JS形式,或者说Ajax吧,所以也没什么好写的。

查了很多资料,大家对注解褒贬不一,有很多人说注解学习成本太大,不好理解啥啥啥的,特别是hibernate annonation。呵呵,只能说你没花心思学吧,稍微花点时间,你就会体会到使用注解的快感,XML文件真的很干净。再也不用CTRL+F了!

### 使用注解编写第一个程序 在现代 Java 开发中,注解是一种非常强大的工具,它能够显著减少样板代码并提高开发效率。以下是基于 Spring Boot 的一个简单示例,展示如何通过注解快速构建一个应用程序。 #### 1. 创建项目结构 首先创建一个标准的 Maven 或 Gradle 项目,并确保其具有 `spring-boot-starter` 依赖项。这一步可以通过 IDE 插件或者手动编辑 `pom.xml` 文件完成[^4]。 ```xml <dependencies> <!-- 引入 Spring Boot Starter --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!-- 测支持 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> ``` #### 2. 编写主类 使用 `@SpringBootApplication` 注解标记主类。此注解是一个复合注解,包含了 `@SpringBootConfiguration`, `@EnableAutoConfiguration` 和 `@ComponentScan` 功能[^3]。 ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class MyFirstApplication { public static void main(String[] args) { SpringApplication.run(MyFirstApplication.class, args); } } ``` 上述代码会启动 Spring Boot 应用程序,并自动加载配置文件以及扫描指定包下的组件。 #### 3. 定义控制器 为了演示 RESTful API 接口的功能,可以定义一个简单的控制器类: ```java import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/api") public class HelloController { @GetMapping("/hello") public String sayHello() { return "Hello from the first annotated program!"; } } ``` 这里使用了 `@RestController` 来表明这是一个返回 JSON 数据的控制器,而不是渲染视图模板;同时利用了 `@RequestMapping` 和 `@GetMapping` 进行路径映射[^1]。 #### 4. 添加自定义注解(可选) 如果希望扩展功能,还可以尝试实现自己的注解。比如下面的例子展示了如何验证方法参数的有效性[^2]: ```java import javax.validation.ConstraintValidator; import javax.validation.ConstraintValidatorContext; // 自定义约束逻辑 public class NotNullAndRangeValidator implements ConstraintValidator<NotNullAndRange, String> { private int max; @Override public void initialize(NotNullAndRange constraintAnnotation) { this.max = constraintAnnotation.max(); } @Override public boolean isValid(String value, ConstraintValidatorContext context) { if (value == null || value.isEmpty()) { return false; // 不允许为空字符串 } try { int num = Integer.parseInt(value); // 尝试转换为整数 return num >= 0 && num <= max; // 判断范围是否合法 } catch (NumberFormatException e) { return false; // 如果无法解析,则认为非法 } } } // 自定义注解声明 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; import javax.validation.Constraint; import javax.validation.Payload; @Constraint(validatedBy = NotNullAndRangeValidator.class) @Target({ElementType.METHOD, ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) public @interface NotNullAndRange { String message() default "Value must be a number between 0 and specified maximum."; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; int max(); // 参数化最大值 } ``` 然后可以在任何需要的地方应用这个新创建的注解: ```java public class ExampleService { public void processInput(@NotNullAndRange(max=100) String input) throws Exception { System.out.println("Processing valid input: " + input); } } ``` --- #### 总结 以上就是使用注解开发的第一个完整程序实例。从项目的搭建到核心业务逻辑的设计都体现了注解的强大之处及其带来的便利性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值