1. 程式人生 > >如何使用VS Code編寫Spring Boot (第二彈)

如何使用VS Code編寫Spring Boot (第二彈)

本篇文章是續《如何使用VS Code編寫Spring Boot》 之後,結合自己.net經驗搗鼓的小demo,一個簡單的CRUD,對於習慣了VS操作模式的.net人員非常方便,強大的智慧提示,簡單又幹淨,一起開啟愉快的java程式設計之旅吧。

一.環境搭建

請移步《如何使用VS Code編寫Spring Boot》 ,當頁面輸出Hello World 就算成功啦

二.熟悉Spring註解,跟路由

Spring真的是將註解用到了極致,能一個註解搞定的東西,從來不羅嗦,熟練的使用這些註解不但減輕了程式碼工作量,而且可讀性更高,這裡直接放圖了,我也是用到哪些百度哪些

路由方面直接在註解裡定義就可以了,比較方便, 在.net裡mvc,webapi 都可以全域性配置,我想java應該也可以的,這裡就不糾結了

三.加個過濾器,方便以後記錄日誌,驗證許可權什麼的

百度了一下,這個就直接抄了,Spring已經預設給實現了過濾器,大致執行流程是  初始化->action執行前->action執行後->登出過濾器

public class LogCostFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        //初始化
    }
 
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest req = (HttpServletRequest) servletRequest;
        String requestURI = req.getRequestURI();
        System.out.println("--------------------->過濾器開始:請求地址"+requestURI);
        if(requestURI.contains("test")){
            //重定向
            servletRequest.getRequestDispatcher("/hello").forward(servletRequest, servletResponse);
        }else{
            filterChain.doFilter(servletRequest, servletResponse);
        }
        System.out.println("--------------------->過濾器結束:請求地址"+requestURI);
    }
 
    @Override
    public void destroy() {
        //登出
    }

} 

 

寫好過濾器後,再把過濾載入進去,這裡也是直接抄,大致可以看明白觸發條件,載入的過濾器名稱,猜測應該可以載入多個過濾器,以後可以根據業務分開寫不同的過濾器了

@Configuration
public class FilterConfig {
 
    @Bean
    public FilterRegistrationBean registFilter() {
        FilterRegistrationBean registration = new FilterRegistrationBean();
        registration.setFilter(new LogCostFilter());
        registration.addUrlPatterns("/*");
        registration.setName("LogCostFilter");
        registration.setOrder(1);
        return registration;
    }
 
}

四.整個ORM,完成簡單的CURD

現在java裡最流行的orm應該是mybatis了,我也想整合這個來著,但是需要點學習成本,為了求快,先整個簡單的jpa,因為這個跟EF比較相似,上手也簡單,這裡放我遇到的一些坑

4.1不同包的資料型別不匹配

 

因為java裡有很多時間型別,導錯了包導致

 

4.2資料來源型別錯誤

這裡引用alibaba的資料來源型別

         <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.9</version>
         </dependency>
spring.datasource.type = com.alibaba.druid.pool.DruidDataSource

 

 4.3掃描不到entity類

在程式啟動時,手動加上要掃描實體類的包

@SpringBootApplication
@EntityScan("com.example.demo.entity") //就是這句
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}

 

 4.4在花了一個下午的時間解決掉這些問題後,終於可以開心的使用jpa訪問資料庫了,但是奇葩的問題又來了,因為我表名是User, 操作的時候它自動給我建立了一個user表,並把資料插入了進去,懶得問人了,一群表面兄弟,直接百度

#區分表名大小寫
spring.jpa.hibernate.naming.physical-strategy = org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

 

五.搭建一個簡單的三層

完成了前面的步奏,可以直接在控制器裡呼叫repository層,實現crud,但是這顯然是不對的,我應該加個service層,哪怕是貧血的,這樣業務可以集中處理,方便維護

在service層直接呼叫repository時遇到一個問題,一直語法報錯,卡了很久,原來使用自定義的方法時,必須在repository裡定義介面,不能直接拿JpaRepository的介面,簡單的優化了一下,結構如圖

專案已開源在github, 地址:https://github.com/wmowm/demo