springboot快速創建項目框架

来源:https://www.cnblogs.com/fanbao/archive/2020/02/25/12315033.html
-Advertisement-
Play Games

一、項目框架準備 1.1 新建maven空項目,併在pom中引入依賴 1 <parent> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-starter-parent</artifactId> 4 <v ...


一、項目框架準備

1.1 新建maven空項目,併在pom中引入依賴

 1     <parent>
 2         <groupId>org.springframework.boot</groupId>
 3         <artifactId>spring-boot-starter-parent</artifactId>
 4         <version>2.1.12.RELEASE</version>
 5     </parent>
 6 
 7     <properties>
 8         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 9         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
10         <java.version>1.8</java.version>
11     </properties>
12 
13     <dependencies>
14         <!-- web啟動器 -->
15         <dependency>
16             <groupId>org.springframework.boot</groupId>
17             <artifactId>spring-boot-starter-web</artifactId>
18         </dependency>
19         <!--jdbc連接及其啟動器 -->
20         <dependency>
21             <groupId>org.springframework.boot</groupId>
22             <artifactId>spring-boot-starter-data-jdbc</artifactId>
23         </dependency>
24         <dependency>
25             <groupId>mysql</groupId>
26             <artifactId>mysql-connector-java</artifactId>
27             <version>5.1.48</version>
28         </dependency>
29         <!--tk.mybatis及mybatis啟動器 -->
30         <dependency>
31             <groupId>org.mybatis.spring.boot</groupId>
32             <artifactId>mybatis-spring-boot-starter</artifactId>
33             <version>1.3.2</version>
34         </dependency>
35         <dependency>
36             <groupId>tk.mybatis</groupId>
37             <artifactId>mapper-spring-boot-starter</artifactId>
38             <version>2.1.5</version>
39         </dependency>
40         <!--thymeleaf啟動器 -->
41         <dependency>
42             <groupId>org.springframework.boot</groupId>
43             <artifactId>spring-boot-starter-thymeleaf</artifactId>
44         </dependency>
45     </dependencies>
46 
47     <build>
48         <plugins>
49             <plugin>
50                 <groupId>org.springframework.boot</groupId>
51                 <artifactId>spring-boot-maven-plugin</artifactId>
52             </plugin>
53         </plugins>
54     </build>

1.2 準備mysql數據表

 1 CREATE TABLE `user` (
 2   `id` int(11) NOT NULL AUTO_INCREMENT,
 3   `username` varchar(255) NOT NULL,
 4   `password` varchar(255) NOT NULL,
 5   `birthday` date DEFAULT NULL,
 6   `address` varchar(255) DEFAULT NULL,
 7   PRIMARY KEY (`id`)
 8 ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4;
 9 INSERT INTO `user` VALUES ('1', '張三', '12345', '2020-01-16', '許昌市');
10 INSERT INTO `user` VALUES ('2', '李四', '54321', '2020-01-01', '河南省許昌市');

二、實現數據的展示

2.1 新建啟動入口並測試

在java文件夾中新建 MyApplication.java 文件,作為程式的啟動入口。

1 @SpringBootApplication
2 public class MyApplication {
3     public static void main(String[] args) {
4         SpringApplication.run(MyApplication.class, args);
5     }
6 }

在resources文件夾中新建application.yml文件,配置埠和資料庫連接

1 server:
2   port: 7001
3 spring:
4   datasource:
5     driver-class-name: com.mysql.jdbc.Driver
6     url: jdbc:mysql://localhost:3306/mydb
7     username: root
8     password: fanbao0713

新建controller --> UserController.java 文件,並啟動測試:http://localhost:7001/user/hello

1 @RestController
2 @RequestMapping("user")
3 public class UserController {
4     @GetMapping("hello")
5     public String hello(){
6         return "Hello World!";
7     }
8 }

2.2 資料庫連接配置

新建 pojo --> User.java 文件:

 1 @Table(name = "user")
 2 public class User {
 3     @Id
 4     @GeneratedValue(strategy = GenerationType.IDENTITY)
 5     private Integer id;
 6     private String username;
 7     private String password;
 8     private Date birthday;
 9     private String address;
10 
11     public Integer getId() {
12         return id;
13     }
14 
15     public void setId(Integer id) {
16         this.id = id;
17     }
18 
19     public String getUsername() {
20         return username;
21     }
22 
23     public void setUsername(String username) {
24         this.username = username;
25     }
26 
27     public String getPassword() {
28         return password;
29     }
30 
31     public void setPassword(String password) {
32         this.password = password;
33     }
34 
35     public Date getBirthday() {
36         return birthday;
37     }
38 
39     public void setBirthday(Date birthday) {
40         this.birthday = birthday;
41     }
42 
43     public String getAddress() {
44         return address;
45     }
46 
47     public void setAddress(String address) {
48         this.address = address;
49     }
50 }

在 application.yml 文件中,新增mybatis關聯

1 mybatis:
2   type-aliases-package: com.springbootdemo.pojo

在 mapper --> UserMapper.java 文件:

1 @Mapper
2 public interface UserMapper extends tk.mybatis.mapper.common.Mapper<User> {
3 }

在 service --> UserService.java 文件,由於tk.mybati不是spring官方插件,“userMapper”會報錯,可以忽略:

 1 @Service
 2 public class UserService {
 3     @Autowired
 4     private UserMapper userMapper;
 5 
 6     public User selectById(Long id){
 7         return this.userMapper.selectByPrimaryKey(id);
 8     }
 9 
10     public List<User> selectAll(){
11         return userMapper.selectAll();
12     }
13 }

在 controller --> UserController.java 文件中,展示介面,併進行測試:http://localhost:7001/user/findAll

 1 @RestController
 2 @RequestMapping("user")
 3 public class UserController {
 4     @Autowired
 5     private UserService userService;
 6 
 7     @GetMapping("{id}")
 8     public User selectById(@PathVariable("id") Long id){
 9         return this.userService.selectById(id);
10     }
11 
12     @GetMapping("findAll")
13     public Map<String, Object> findAll(){
14         Map<String, Object> map = new HashMap<>();
15         map.put("用戶列表", userService.selectAll());
16         return map;
17     }
18 }

三、靜態資源訪問及攔截器

3.1 訪問靜態資源

在 resources 文件夾中新增static中,並加入目錄中,static中的各類資源可以直接訪問:http://localhost:7001/js/common.js

3.2 攔截器設置

在 interceptors --> UserInterceptor中,首先我們定義一個攔截器:

 1 @Component
 2 public class UserInterceptor implements HandlerInterceptor {
 3     @Override
 4     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
 5         System.out.println("preHandle/前置攔截器 method is running!");
 6         return true;
 7     }
 8 
 9     @Override
10     public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
11         System.out.println("postHandle/運行攔截器 method is running!");
12     }
13 
14     @Override
15     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
16         System.out.println("postHandle/後置攔截器 method is running!");
17     }
18 }

新建 config --> MvcConfig.java 中,定義配置類,註冊攔截器:

 1 @Configuration
 2 public class MvcConfig implements WebMvcConfigurer {
 3     @Autowired
 4     private HandlerInterceptor handlerInterceptor;
 5 
 6     @Override
 7     public void addInterceptors(InterceptorRegistry registry) {
 8         registry.addInterceptor(handlerInterceptor).addPathPatterns("/**");
 9     }
10 }

 

 

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • <router-view> 是基本的動態組件,所以我們可以用 <transition> 組件給它添加一些過渡效果: <transition name="slide-left" mode="out-in"> <router-view /> </transition> 過渡的類名 在進入/離開的過渡中, ...
  • 在CSS中,根據元素顯示模式的不同元素標簽被分為了兩類:行內元素(inline-level)、塊級元素(block-level)。 1,首先介紹什麼是行內元素,什麼又是塊級元素? 1.1,行內元素就是不會獨占一行的元素,例如:span buis strong em ins del等 1.2,塊級元素 ...
  • 一、CSS偽元素 CSS 偽元素用於向某些選擇器設置特殊效果。 偽元素的用法如下: selector:pseudo-element {property:value;} CSS 類也可以和偽元素搭配使用 selector.class:pseudo-element {property:value;} 二 ...
  • 參考 博客 1、 "中高級前端面試題(萬字長文)" 2、 "大前端弔打面試官系列" 資料 1、 "HTML 5 教程" 2、 "CSS3 教程" 3、 "JavaScript 教程" 收費小冊 "前端面試之道" 註:某大佬這本收費小冊乾貨很多,有些參考其中的問題,就不列答案了。 寫在前面的話 因為一 ...
  • RX.js變化 RxJS 6主要用於Angular應用程式,從Angular 6開始,它是一個強制依賴。 與RxJS版本5相比,RxJS 6(或更高版本)引入了兩個重要更改: 1. import的導入結構發生變化 // 以前: import { Observable } from 'rxjs/Obs ...
  • 一、Overview angular 入坑記錄的筆記第二篇,介紹組件中的相關概念,以及如何在 angular 中通過使用組件來完成系統功能的實現 對應官方文檔地址: "顯示數據" "模板語法" "用戶輸入" "組件之間的交互" "管道" "生命周期鉤子" 配套代碼地址: "angular pract ...
  • 簡介 WebSocket 使得客戶端和伺服器之間的數據交換變得更加簡單, 允許服務端主動向客戶端推送數據。 在 WebSocket API 中,瀏覽器和伺服器只需要完成一次握手,兩者之間就直接 可以創建持久性的連接,併進行雙向數據傳輸。 現在,很多網站為了實現 推送技術 ,所用的技術都是 Ajax ...
  • 現如今,新型冠狀病毒疫情牽動著每一個人的神經,每天起床後的第一件事就是打開疫情地圖,看看最新的疫情數據。如何防控對於普通居民來說,減少外出,註意衛生等都是有效措施,另外保持室內通風換氣也是至關重要的,無論是飛沫傳播還是流傳的氣溶膠傳播,環境密閉導致空氣渾濁,易造成病菌滋生,增加人體感染疾病的風險。勤... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...