springBoot框架的一些概念


Spring的發展史
1. Spring1.x 時代 在Spring1.x時代,都是通過xml文件配置bean,隨着項目的不斷擴大,需要將xml配置分放到不同的配置文件中,需要頻繁的在java類和xml配置文件中切換。 2. Spring2.x時代 隨着JDK 1.5帶來的注解支持,Spring2.x可以使用注解對Bean進行申明和注入,大大的減少了xml配置文件,同時也大大簡化了項目的開發。 那么,問題來了,究竟是應該使用xml還是注解呢? 最佳實踐: 1、應用的基本配置用xml,比如:數據源、資源文件等; 2、業務開發用注解,比如:Service中注入bean等;

3. Spring3.x到Spring4.x 從Spring3.x開始提供了Java配置方式,使用Java配置方式可以更好的理解你配置的Bean,現在我們就處於這個時代,
並且Spring4.x和Spring boot都推薦使用java配置的方式。

 

SpringBoot的配置方式
Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置。
1.    @Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個注解實現的:
1、@Configuration 作用於類上,相當於一個xml配置文件;
2、@Bean 作用於方法上,相當於xml配置中的<bean>


2. 示例 該示例演示了通過Java配置的方式進行配置Spring,並且實現了Spring IOC功能。 創建工程以及導入依賴 POM.XML <project xmlns="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> <groupId>com.xiaowu.springboot</groupId> <artifactId>xiaowu-springboot</artifactId> <version>1.0.0-SNAPSHOT</version> <packaging>war</packaging> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.7.RELEASE</version> </dependency> <!-- 連接池 --> <dependency> <groupId>com.jolbox</groupId> <artifactId>bonecp-spring</artifactId> <version>0.8.0.RELEASE</version> </dependency> </dependencies> <build> <finalName>${project.artifactId}</finalName> <plugins> <!-- 資源文件拷貝插件 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-resources-plugin</artifactId> <configuration> <encoding>UTF-8</encoding> </configuration> </plugin> <!-- java編譯插件 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.7</source> <target>1.7</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> <pluginManagement> <plugins> <!-- 配置Tomcat插件 --> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> </plugin> </plugins> </pluginManagement> </build> </project>

 

//User 類
public class User {

    private String username;

    private String password;

    private Integer age;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

}

 

UserDao類
public class UserDAO {
    
    public List<User> queryUserList(){
        List<User> result = new ArrayList<User>();
        // 模擬數據庫的查詢
        for (int i = 0; i < 10; i++) {
            User user = new User();
            user.setUsername("username_" + i);
            user.setPassword("password_" + i);
            user.setAge(i + 1);
            result.add(user);
        }
        return result;
    }

 

UserService 類,業務實現
@Service
public class UserService {

    @Autowired // 注入Spring容器中的bean對象
    private UserDAO userDAO;

    public List<User> queryUserList() {
        // 調用userDAO中的方法進行查詢
        return this.userDAO.queryUserList();
    }

}

 

編寫SpringConfig 用於實例化Spring容器

@Configuration //通過該注解來表明該類是一個Spring的配置,相當於一個xml文件
@ComponentScan(basePackages = "com.xiaowu.springboot.javaconfig") //配置掃描包
public class SpringConfig {
    
    @Bean // 通過該注解來表明是一個Bean對象,相當於xml中的<bean>
    public UserDAO getUserDAO(){
        return new UserDAO(); // 直接new對象做演示
    }
    
}

 

//定義main方法,啟動項目

public class Main {
    
    public static void main(String[] args) {
        // 通過Java配置來實例化Spring容器
        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
        
        // 在Spring容器中獲取Bean對象
        UserService userService = context.getBean(UserService.class);
        
        // 調用對象中的方法
        List<User> list = userService.queryUserList();
        for (User user : list) {
            System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword());
        }
        
        // 銷毀該容器
        context.destroy();
    }

}

 

測試結果:

 

 

 

 定義讀取,外部的配置文件--->讀取外部的資源配置文件

通過@PropertySource可以指定讀取的配置文件,通過@Value注解獲取值,具體用法:

@Configuration //通過該注解來表明該類是一個Spring的配置,相當於一個xml文件

@ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置掃描包

@PropertySource(value= {"classpath:jdbc.properties"})

public class SpringConfig {
    @Value("${jdbc.url}")

    private String jdbcUrl;
   

    @Bean // 通過該注解來表明是一個Bean對象,相當於xml中的<bean>

    public UserDAO getUserDAO(){

        return new UserDAO(); // 直接new對象做演示

    }
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM