亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

什么是SpringBoot

發布時間:2020-07-25 12:29:12 來源:網絡 閱讀:479 作者:Java萌新 欄目:編程語言

隨著動態語言的流行(Ruby,Groovy,Scala,Node.js),Java的開發顯得格外的笨重;繁多的配置,低下的開發效率,復雜的部署流程以及第三方技術集成難度大.

在上述環境 下,Spring Boot應運而生.它使用"習慣優于配置"(項目中存在大量的配置,此外還內置一個習慣性的配置,讓你無須手段進行配置)的理念讓你的項目快速運行起來.

使用Spring Boot很容易創建一個獨立運行(運行jar,內嵌Servlet容器),準生產級別的基于Spring框架的項目,使用Spring Boot你可以不用或者只需要很少的Spring配置.

Spring Boot的優缺點

優點 :

(1) 快速構建項目;

(2) 對主流開發框架的無配置集成;

(3) 項目可獨立運行,無須外部依賴 Servlet容器;

(4) 提供運行時的應用監控;

(5) 極大地提高了開發,部署效率;

(6) 與云計算的天然集成.

缺點 :

(1) 書籍文檔少且不夠深入;

(2) 如果你不認同Spring框架,這也許是它的缺點,但建議你一定要使用Spring框架.

快速入門

設置Spring boot的parent

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.5.2.RELEASE</version>

</parent>

說明 : Spring Boot的項目必須要將parent設置為Spring boot的parent, 該parent包含了大量的默認的配置,大大簡化了我們的開發.

導入Spring Boot的web支持

<dependency>

<groupId>org.springframework.book</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

添加Spring Boot的插件

<plugin>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-maven-plugin</artifactId>

</plugin>

編寫第一個Spring Boot的應用

@Controller

@SpringBootApplication

@Configuration

public class HelloApplication {

@RequestMapping("hello")

@ResponseBody

public String hello() {

return "hello world!";

}

public static void main(String[] args) {

SpringApplication.run(HelloApplication.class, args);

}

}

代碼說明 :

1 : @SpringBootApplication : Spring Boot項目的核心注解, 主要目的是開啟自動配置;

2 : @Configuration : 這是一個配置Spring的配置類;

3 : @Controller : 標明這是一個SpringMVC的Controller控制器;

4 : main方法 : 在main方法中啟動一個應用,既 : 這個應用的入口;

啟動應用

在Spring Boot項目中,啟動的方式有兩種,一種是直接run Java Application另外一種是通過Spring Boot的Maven插件運行.

Spring Boot的核心

入口類和@SpringBootApplication

Spring Boot的項目一般都會有*Application的入口類,入口類中會有main方法,這是一個標準的Java應用程序的入口方法.

@SpringBootApplication注解是Spring Boot的核心注解,它其實是一個組合注解;

@Target(ElementType.TYPE)

@Retention(RetentionPolicy.RUNTIME)

@Documented

@Inherited

@SpringBootConfiguration

@EnableAutoConfiguration

@ConmpnentScan(excludeFilters = {

@Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),

@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class)

})

public @interface SpringBootApplication {}

該注解主要組合了以下注解 :

1 : @SpringBootConfiguration : 這是Spring Boot項目的配置注解,這也是一個組合注解 :

@Target(ElementType.TYPE)

@Retention(RetentionPolicy.RUNTIME)

@Documented

@Configuration

public @interface SpringBootConfiguration{}

在Spring Boot項目中推薦使用@SpringBootConfiguration替代@Configuration

2 : @EnableAutoConfiguration : 啟用自動配置,該注解會使Spring Boot根據項目中依賴的jar包自動配置項目的配置項 :

a) 如 : 我們添加了Spring-boot-starter-web的依賴,項目中也就會引入SpringMVC的依賴,Spring Boot就會自動配置tomcat和SpringMVC

spring-boot-starter-web : 1.5.2.RELEASE[compile]

spring-boot-starter : 1.5.2.RELEASE[compile]

spring-boot-starter-tomcat : 1.5.2.RELEASE[compile]

tomcat-embed-core : 8.5.11[compile]

tomcat-embed-el : 8.5.11[compile]

tomcat-embed-websocked : 8.5.11[compile]

tomcat-embed-core : 8.5.11(omitted for conflict with 8.5.11)[compile]

hibernate-vaildator : 5.3.4.Final[compile]

jackson-databind : 2.8.7[compile]

spring-web : 4.3.7.RELEASE(omitted for confilct with 4.3.7.RELEASE)[compile]

spring-webmvc : 4.3.7.RELEASE(omitted for confilct with 4.3.7.RELEASE)[compile]

3 : @ComponentScan : 默認掃描@SpringBootApplication所在類的同級目錄以及它的子目錄.

關閉自動配置

Spring Boot會根據項目中的jar包依賴,自動做出配置,Spring Boot支持的自動配置(非常多);

比如 : 我們不想自動配置Redis,想手動配置.

@SpringBootApplication(exclude = {RedisAutoConfiguration.class})

public class HelloApplication {

}

如果不想看到banner,可以將其關閉 :

public static void main(Stirng[] args) {

SpringApplication app = new SpringApplication(HelloApplication.class, args);

app.setBannerMode(Banner.Mode.OFF); //關閉banner

app.run-正在西部數碼(www.west.cn)進行交易(args);

}

Spring Boot項目使用一個全局的配置文件application.properties或者是application.yml,在resources目錄下或者類路徑下的/config下,一般我們放到resources下。

1、 修改tomcat的端口為8088(server.port=8088)

2、 修改進入DispatcherServlet的規則為:.html(server.servlet.path=.html)

Xml配置文件

Spring Boot提倡零配置,既無xml配置,但是在實際項目中,可能有一些特殊要求你 必須使用 xml配置,這時我們可以通過Spring提供的@ImportResource來加載xml配置,

例如 :

@ImportResource({"classpath:some-context.xml","classpath:another-context.xml"})

日志

Spring Boot對各種日志框架都支持,通過配置修改默認的日志的配置 :

#設置日志級別

logging.level.org.springframework=DEBUG

格式 :

logging.level.*= # log levels serverity. For instance 'logging.level.org.springframework=DEBUG'

Spring Boot的自動配置的原理

Spring Boot在進行SpringApplication對象實例化時會加載META-INF/spring.factories文件,將該配置文件中的配置載入到Spring容器.

進入規則為 /

如果進入SpringMVC的規則為/時,Spring Boot的默認靜態資源的路徑為:

spring.resources.static-locations=classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/

進入規則為*.xxx 或者 不指定靜態文件路徑時

將靜態資源放置到webapp下的static目錄中即可通過地址訪問:

自定義SpringMVC的配置

有些時候我們需要自已配置SpringMVC而不是采用默認,比如說增加一個攔截器,這個時候就得通過繼承WebMvcConfigurerAdapter然后重寫父類中的方法進行擴展。

在Spring Boot中推薦使用@Transaction注解來申明事務.

首先需要導入依賴 :

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-jdbc</artifactId>

</dependency>

當引入jdbc依賴之后,Spring Boot會自動默認分別注入DataSourceTransactionManager或JpaTransactionManager,所以我們不需要任何額外配置就可以用@Transactional

注解進行事務使用.

例如 :

在service中添加@Transactional注解 :

發布到獨立的tomcat中運行

在開發階段我們推薦使用內嵌的tomcat進行開發,因為這樣會方便很多,但是到生成環境,我們在獨立的tomcat容器中運行,因為我們需要對tomcat做額外的優化,這時我們

需要將工程打成war包進行發布到外部的tomcat里面.

工程的打包方式為war

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.5.2.RELEASE</version>

<parent>

<groupId>com.taotao.cart</groupId>

<artifactId>taotao-cart-springboot</artifactId>

<version>1.0.0-SNAPSHOT</versio>

<packageing>war</packageing>

將spring-boot-starter-tomcat的范圍設置為provided

設置為provided是打包時會將該包排除,因為要放到獨立的tomcat中運行,是不需要的.

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-tomcat</artifactId>

<scope>provided</scope>

</dependency>

修改代碼,設置啟動配置

需要集成SpringBootServletInitializer,然后重寫configure,將Spring Boot的入口類設置進去.

需要啟動類繼承需要集成SpringBootServletInitializer

@Configuration

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

@ComponentScan(basePackages = "con.taotao")

@ImportResource(value = "classpath:dubbo/dubbo-consumer.xml") // dubbo的配置文件,將dubbo整合到spring容器中

@SpringBootApplication

public class TaobaoApplication extends SpringBootServletInitializer {

@Override

protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {

// 設置啟動類,用于獨立tomcat運行的入口

return builder.sources(TaotaoApplication.class);

}

}

maven命令 : clean package // 把項目打包成war包.

把打包成war的項目放到tomcat的webapps的ROOT里面,并解壓.

在配置Mybatis時使用java配置

@Configuration

@AutoConfiureAfter(MyBatisConfig.class) // 保證在MyBatisConfig實例化之后再實例化該類

public class MapperScannerConfig {

// mapper接口的掃描器

@Bean

public MapperScannerConfigurer mapperScannerConfigurer() {

MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();

mapperScannerConfigurer.setBasePackage("com.taotao.cart.mapper");

return mapperScannerConfigurer;

}

}

全局捕獲異常

  1. 新建一個Class,這里取名為GlobalDefaultExceptionHandler;

  2. 在class上添加注解,@ControllerAdvice;

  3. 在class中添加一個方法;

  4. 在方法上添加@ExceptionHandler攔截相應的異常信息;

  5. 如果返回的是View -- 方法的返回值是ModelAndView;

  6. 如果返回的是String或者是Json數據,那么需要在方法上添加@ResponseBody注解
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

晋宁县| 会东县| 高雄市| 鄂州市| 临武县| 新闻| 什邡市| 化德县| 温宿县| 新野县| 昭觉县| 昌图县| 晋江市| 江孜县| 鹤山市| 平阴县| 肇州县| 阿鲁科尔沁旗| 抚松县| 松阳县| 鄂伦春自治旗| 黄陵县| 宁蒗| 黑水县| 安义县| 辉南县| 赤城县| 景洪市| 清水县| 乳源| 新建县| 随州市| 望奎县| 滦平县| 吴川市| 英超| 荆州市| 庆城县| 茂名市| 许昌市| 蓬安县|