news 2026/3/1 8:08:27

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

作者头像

张小明

前端开发工程师

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/2/27 9:25:35

突破性能极限:如何用Z-Image-Turbo预置镜像实现2K高清输出

突破性能极限&#xff1a;如何用Z-Image-Turbo预置镜像实现2K高清输出 对于专业摄影师而言&#xff0c;将AI生成图像用于商业图库是一个极具吸引力的方向&#xff0c;但大多数模型在高分辨率输出时面临质量不稳定、生成速度慢等问题。Z-Image-Turbo预置镜像通过创新的8步蒸馏技…

作者头像 李华
网站建设 2026/2/28 9:57:36

技术创业者必看:低成本搭建AI图像生成SaaS

技术创业者必看&#xff1a;低成本搭建AI图像生成SaaS 为什么选择AI图像生成SaaS&#xff1f; 作为一名技术创业者&#xff0c;你可能已经注意到AI图像生成技术的巨大潜力。从营销海报到产品设计&#xff0c;Stable Diffusion等开源模型正在改变内容创作的方式。但传统部署方案…

作者头像 李华
网站建设 2026/2/27 8:38:33

typescript-数组和元组

今天我们开始复杂类型什么是数组&#xff1f;数组是一个可以保存多个同类型值的变量。可以通过索引来访问每一个位置中的值。&#xff08;注&#xff1a;程序中的索引是从0开始的&#xff0c;不是从1&#xff09;什么是元组&#xff1f;元组和数组差不多&#xff0c;是一个可以…

作者头像 李华
网站建设 2026/2/26 21:08:19

inline内联函数双重语义

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、先理清&#xff1a;inline的两个核心作用&#xff08;容易混淆&#xff09;二、头文件中写类成员函数的两种场景场景1&#xff1a;类体内部直接写函数实现&a…

作者头像 李华
网站建设 2026/2/27 23:05:29

阿里通义Z-Image-Turbo WebUI效率秘籍:10倍速生成高质量图像

阿里通义Z-Image-Turbo WebUI效率秘籍&#xff1a;10倍速生成高质量图像 作为一名每天需要生产大量配图的内容创作者&#xff0c;你是否也遇到过这样的困扰&#xff1a;现有的AI图像生成工具要么速度慢得让人抓狂&#xff0c;要么生成的图片质量参差不齐&#xff1f;今天我要分…

作者头像 李华