news 2026/6/10 16:06:07

基于 注解 + 配置类 的方式 整合三层架构组件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于 注解 + 配置类 的方式 整合三层架构组件

项目创建

practice-ioc

最终项目结构

依赖导入

这里的依赖没有版本号,是因为已经在父工程的dependencyManagement统一管理版本了

<?xml version="1.0" encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.english</groupId><artifactId>ssm-spring-part</artifactId><version>1.0-SNAPSHOT</version></parent><artifactId>practice-ioc</artifactId><properties><maven.compiler.source>17</maven.compiler.source><maven.compiler.target>17</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><dependencies><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId></dependency><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-api</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId></dependency><dependency><groupId>jakarta.annotation</groupId><artifactId>jakarta.annotation-api</artifactId></dependency></dependencies></project>

实体类准备

packagecom.english.pojo;publicclassStudent{privateIntegerid;privateStringname;privateStringgender;privateIntegerage;privateStringclasses;publicIntegergetId(){returnid;}publicvoidsetId(Integerid){this.id=id;}publicStringgetName(){returnname;}publicvoidsetName(Stringname){this.name=name;}publicStringgetGender(){returngender;}publicvoidsetGender(Stringgender){this.gender=gender;}publicIntegergetAge(){returnage;}publicvoidsetAge(Integerage){this.age=age;}publicStringgetClasses(){returnclasses;}publicvoidsetClasses(Stringclasses){this.classes=classes;}@OverridepublicStringtoString(){return"Student{"+"id="+id+", name='"+name+'\''+", gender='"+gender+'\''+", age="+age+", classes='"+classes+'\''+'}';}}

持久层

StudentDao接口

packagecom.english.dao;importcom.english.pojo.Student;importjava.util.List;publicinterfaceStudentDao{List<Student>queryAll();}

StudentDao接口的实现类

packagecom.english.dao.impl;importcom.english.dao.StudentDao;importcom.english.pojo.Student;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.jdbc.core.BeanPropertyRowMapper;importorg.springframework.jdbc.core.JdbcTemplate;importorg.springframework.stereotype.Repository;importjava.util.List;@RepositorypublicclassStudentDaoImplimplementsStudentDao{@AutowiredprivateJdbcTemplatejdbcTemplate;@OverridepublicList<Student>queryAll(){Stringsql="select id , name , age , gender , class as classes from students;";List<Student>stuList=jdbcTemplate.query(sql,newBeanPropertyRowMapper<>(Student.class));returnstuList;}}

业务层

StudentService接口

packagecom.english.service;importcom.english.pojo.Student;importjava.util.List;publicinterfaceStudentService{List<Student>findAll();}

StudentService接口的实现类

packagecom.english.service.impl;importcom.english.dao.StudentDao;importcom.english.pojo.Student;importcom.english.service.StudentService;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Service;importjava.util.List;@ServicepublicclassStudentServiceImplimplementsStudentService{@AutowiredprivateStudentDaostudentDao;@OverridepublicList<Student>findAll(){List<Student>stuList=studentDao.queryAll();returnstuList;}}

表述层

packagecom.english.controller;importcom.english.config.JavaConfig;importcom.english.pojo.Student;importcom.english.service.StudentService;importorg.junit.jupiter.api.Test;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.context.annotation.AnnotationConfigApplicationContext;importorg.springframework.stereotype.Controller;importjava.util.List;@ControllerpublicclassStudentController{@AutowiredprivateStudentServicestudentService;publicvoidfind(){List<Student>stuList=studentService.findAll();System.out.println(stuList);}"请忽略这个 test() 方法,这是我测试用的"@Testpublicvoidtest(){AnnotationConfigApplicationContextcontext=newAnnotationConfigApplicationContext(JavaConfig.class);StudentControllerstudentController=context.getBean(StudentController.class);studentController.find();context.close();}}

三层架构 ioc 配置类

packagecom.english.config;importcom.alibaba.druid.pool.DruidDataSource;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.ComponentScan;importorg.springframework.context.annotation.Configuration;importorg.springframework.context.annotation.PropertySource;importorg.springframework.jdbc.core.JdbcTemplate;@Configuration@PropertySource("classpath:jdbc.properties")@ComponentScan(basePackages="com.english")publicclassJavaConfig{@Value("${atguitu.url}")privateStringurl;@Value("${atguigu.driver}")privateStringdriverClassName;@Value("${atguigu.username}")privateStringusername;@Value("${atguigu.password}")privateStringpassword;@BeanpublicDruidDataSourcedataSource(){DruidDataSourcedataSource=newDruidDataSource();dataSource.setUrl(url);dataSource.setDriverClassName(driverClassName);dataSource.setUsername(username);dataSource.setPassword(password);returndataSource;}@BeanpublicJdbcTemplatejdbcTemplate(DruidDataSourcedataSource){JdbcTemplatejdbcTemplate=newJdbcTemplate();jdbcTemplate.setDataSource(dataSource);returnjdbcTemplate;}}

运行测试,请看 表述层的 test() 方法

主要是这段代码

@Testpublicvoidtest(){AnnotationConfigApplicationContextcontext=newAnnotationConfigApplicationContext(JavaConfig.class);StudentControllerstudentController=context.getBean(StudentController.class);studentController.find();context.close();}

打印结果如下:

D:\n_Java\jdk-17\bin\java.exe...108,20264:50:25下午com.alibaba.druid.support.logging.JakartaCommonsLoggingImplinfo 信息:{dataSource-1}inited[Student{id=1,name='张三',gender='男',age=20,classes='高中一班'},Student{id=2,name='李四',gender='男',age=19,classes='高中二班'},Student{id=3,name='王五',gender='女',age=18,classes='高中一班'},Student{id=4,name='赵六',gender='女',age=20,classes='高中三班'},Student{id=5,name='刘七',gender='男',age=19,classes='高中二班'},Student{id=6,name='陈八',gender='女',age=18,classes='高中一班'},Student{id=7,name='杨九',gender='男',age=20,classes='高中三班'},Student{id=8,name='吴十',gender='男',age=19,classes='高中二班'}]108,20264:50:25下午com.alibaba.druid.support.logging.JakartaCommonsLoggingImplinfo 信息:{dataSource-1}closing...108,20264:50:25下午com.alibaba.druid.support.logging.JakartaCommonsLoggingImplinfo 信息:{dataSource-1}closedProcessfinishedwithexitcode0

附上图片:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:43:10

零成本体验:免费GPU资源+预装镜像玩转AI绘画

零成本体验&#xff1a;免费GPU资源预装镜像玩转AI绘画 作为一名对AI绘画感兴趣的大学生&#xff0c;你是否曾因高昂的GPU云服务费用和复杂的本地部署流程而望而却步&#xff1f;本文将介绍如何利用免费GPU资源和预装镜像&#xff0c;零门槛体验Stable Diffusion等AI绘画技术&a…

作者头像 李华
网站建设 2026/6/10 12:42:55

使用 Selenium 爬取京东手机销量与评分数据 (1)

在电商数据分析场景中&#xff0c;京东作为头部电商平台&#xff0c;其手机品类的销量、评分数据是洞察市场趋势、分析用户偏好的核心依据。相较于静态网页爬取&#xff0c;京东采用动态渲染技术加载商品数据&#xff0c;传统的 RequestsBeautifulSoup 组合难以获取完整信息&am…

作者头像 李华
网站建设 2026/6/10 12:45:14

Z-Image-Turbo模型解析与二次开发:科哥定制镜像深度体验

Z-Image-Turbo模型解析与二次开发&#xff1a;科哥定制镜像深度体验 为什么你需要这个定制镜像 技术团队在基于Z-Image-Turbo进行深度定制开发时&#xff0c;往往会遇到两个主要痛点&#xff1a; 环境配置复杂&#xff1a;需要安装CUDA、PyTorch等依赖&#xff0c;版本兼容性问…

作者头像 李华
网站建设 2026/6/10 12:40:30

【std::map】获取键的索引

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录实现方法&#xff1a;遍历计数关键说明总结std::map 是有序关联容器&#xff08;基于红黑树实现&#xff09;&#xff0c;其元素按键&#xff08;key&#xff09;的排…

作者头像 李华
网站建设 2026/6/10 13:13:27

技术宅的快乐:用预配置镜像深度定制你的Z-Image-Turbo模型

技术宅的快乐&#xff1a;用预配置镜像深度定制你的Z-Image-Turbo模型 作为一名AI爱好者&#xff0c;你是否曾经被复杂的模型训练环境配置所困扰&#xff1f;想要快速体验Z-Image-Turbo模型的强大能力&#xff0c;却被各种依赖安装、环境配置等问题绊住了脚步&#xff1f;本文…

作者头像 李华
网站建设 2026/6/10 13:35:48

Z-Image-Turbo批量处理技巧:如何快速生成上千张图片

Z-Image-Turbo批量处理技巧&#xff1a;如何快速生成上千张图片 在电商运营中&#xff0c;为数千种商品手动制作展示图不仅耗时耗力&#xff0c;还难以保证风格统一。Z-Image-Turbo作为阿里开源的6B参数图像生成模型&#xff0c;通过创新的8步蒸馏技术&#xff0c;能在保持照片…

作者头像 李华