spring-02-对象创建三法

本文详细介绍了Spring框架中创建对象的三种方法:构造器创建、静态工厂创建与普通工厂创建,以及如何通过配置XML文件实现这些创建过程。同时,通过具体示例展示了不同创建方式的应用场景。

对象创建三法

1、构造器创建
appContext.getBean(Class/“id”);
Spring默认调用类的“无参构造方法”来创建对象。

2、静态工厂创建&普通工厂
静态工厂,里面写一个静态方法返回一个类的实例,普通工厂就把静态关键字去掉

public class 静态工厂 {
	public 静态工厂(){
		System.out.println("====="+getClass());
	}
	static Cat createObj(){
		return  new Cat();
	}
	
}
------------------------------------------------------------
public class 普通工厂 {
	public 普通工厂(){
		System.out.println("==="+getClass());
	}
	Cat createObj(){
		return  new Cat();
	}
	

}

3、配置xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
	http://www.springframework.org/schema/beans/spring-beans.xsd">
	//静态工厂方法
	<bean id = "factory_static" class="spring02.静态工厂"  factory-method="createObj" />
	
	//普通工厂方法
	<bean id = "factory_common" class="spring02.普通工厂"/>
	<bean id="prodect1" factory-bean="factory_common" factory-method="createObj"></bean>

</beans>

4、测试
——静态工厂使用的工厂的的id获取对象,而普通工厂使用的工厂下面的方法的id获取对象 ;

public class Test02 {
	public static void main(String[] args) {
		ApplicationContext ac = new ClassPathXmlApplicationContext("spring02/applicationContext.xml");
		System.out.println("----------------");
		System.out.println(ac);
		//静态工厂,使用工厂的id获取对象(工厂不会实例化)
		Cat cat =(Cat)ac.getBean("factory_static");
		System.out.println(cat);
		cat.speak();
		
		//普通工厂,使用产品的ID获取对象(工厂不会实例化)
		Cat cat2 = (Cat)ac.getBean("prodect1");
		System.out.println(cat2);
		cat2.speak();
		
	}

}

运行结果:从结果上看静态工厂没有实例化
在这里插入图片描述

练习

富士康代工生产小米和苹果,乐视生产汽车

public class MI {
	public void slogan(){
		System.out.println("为发烧而生!");
	}

}
--------------------------------------------------------
public class Iphone {
	public void slogan(){
		System.out.println("唯一的不同就是处处不同!");
	}
}
--------------------------------------------------------
public class Car {
	public void go(){
		System.out.println("跑起来!");
	}

}

创建工厂

public class Foxconn {
	public Iphone productionIphone(){
		return new Iphone();
	}
	public MI productionMi(){
		return new MI();
	}
}
--------------------------------------------------------
public class LeEco {
	public static Car productionCar(){
		return new Car();
	}

}

配置 xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
	http://www.springframework.org/schema/beans/spring-beans.xsd">
	<!-- 普通工厂 -->
	<bean id="foxconn" class="spring02Test.Foxconn" />
	<!-- 普通工厂:产品 -->
	<bean id="iphone" factory-bean="foxconn" factory-method="productionIphone" />
	<bean id="mi" factory-bean="foxconn" factory-method="productionMi" />
	
	<!-- 静态工厂 -->
	<bean id="leeco" class="spring02Test.LeEco" factory-method="productionCar" />

</beans>

测试

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Test01 {
	
	@Test
	public void test(){
		ApplicationContext ac = new ClassPathXmlApplicationContext("spring02Test/applicationContext.xml");
		 Iphone iphone = (Iphone) ac.getBean("iphone");
		 iphone.slogan();
		 MI mi = (MI) ac.getBean("mi");
		 mi.slogan();
		 
		Car car = (Car) ac.getBean("leeco");
		car.go();
		 
		
	}

}

运行结果
在这里插入图片描述

### 如何在 Spring Boot 中使用 MyBatis Plus 代码生成器并集成 Swagger #### 配置 MyBatis Plus 和 Swagger 的依赖 为了实现这一目标,在 `pom.xml` 文件中添加必要的 Maven 依赖来引入 MyBatis Plus 及其代码生成工具,以及 Swagger UI。 ```xml <dependencies> <!-- MyBatis Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> <!-- MyBatis Plus Code Generator --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.4.0</version> </dependency> <!-- Velocity Template Engine (for code generation templates) --> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> <version>2.3</version> </dependency> <!-- Swagger/OpenAPI for API documentation --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>3.0.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency> </dependencies> ``` #### 创建 MyBatis Plus 自动化代码生成功能 定义一个 Java 类用于启动自动化代码生成过程。此操作可以通过编写一段简单的程序完成: ```java import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.config.DataSourceConfig; import com.baomidou.mybatisplus.generator.config.GlobalConfig; import com.baomidou.mybatisplus.generator.config.PackageConfig; import com.baomidou.mybatisplus.generator.config.StrategyConfig; public class MpCodeGen { public static void main(String[] args) { // 初始化自动生成对象 AutoGenerator mpg = new AutoGenerator(); // 设置全局配置 GlobalConfig gc = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java"); // 输出路径设置为当前项目的 src/main/java 下 // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC"); dsc.setUsername("root"); dsc.setPassword("password"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); // 包名策略配置 PackageConfig pc = new PackageConfig(); pc.setParent("com.example.demo"); pc.setModuleName(null); // 表策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setInclude("table_name"); // 此处填写要生成表的名字 strategy.setNaming(mp.service.NamingStrategy.underline_to_camel); strategy.setColumnNaming(mp.service.NamingStrategy.underline_to_camel); strategy.setEntityLombokModel(true); // 使用 Lombok 注解简化实体类开发 strategy.setRestControllerStyle(true); // 开启驼峰命名到下划线风格转换功能 // 将以上配置应用至AutoGenerator实例上 mpg.setGlobalConfig(gc).setDataSource(dsc).setPackageInfo(pc).setStrategy(strategy); // 执行代码生成命令 mpg.execute(); } } ``` 这段代码将会基于数据库中的指定表格来自动生成相应的 Controller, Service, Mapper 接口及其对应的 XML 映射文件[^1]。 #### 启用 Swagger 文档支持 为了让应用程序能够通过 Swagger 展示 RESTful APIs 的文档信息,需进一步调整 Spring Boot 应用程序的主要入口点(通常是带有@SpringBootApplication注解的那个类),加入@EnableSwagger2 或者 @EnableOpenApi 来激活 Swagger 功能: ```java import org.springframework.context.annotation.Bean; import springfox.documentation.builders.PathSelectors; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; @SpringBootApplication @EnableSwagger2 public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } @Bean public Docket api() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build(); } } ``` 现在访问 http://localhost:8080/swagger-ui.html 即可查看由 Swagger 自动生成的 API 文档界面[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值