serviceimpl層 Action、Dao、DaoImpl、Service、ServiceImpl各自的作用是什么,他們之間有什么關(guān)系?
Action、Dao、DaoImpl、Service、ServiceImpl各自的作用是什么,他們之間有什么關(guān)系?這是Struts2項(xiàng)目的基本框架。它是一個(gè)三層結(jié)構(gòu)。Action從服務(wù)接口獲取數(shù)據(jù),并
Action、Dao、DaoImpl、Service、ServiceImpl各自的作用是什么,他們之間有什么關(guān)系?
這是Struts2項(xiàng)目的基本框架。它是一個(gè)三層結(jié)構(gòu)。
Action從服務(wù)接口獲取數(shù)據(jù),并負(fù)責(zé)處理和過濾網(wǎng)頁(yè)中的數(shù)據(jù)。Service是定義接口,serviceimpl是定義接口的實(shí)現(xiàn),是函數(shù)代碼的編寫地,它從daoimpl接口獲取數(shù)據(jù),Dao是操作數(shù)據(jù)庫(kù)的代碼。簡(jiǎn)而言之,action調(diào)用serviceimpl,service實(shí)現(xiàn)serviceimpl,serviceimpl調(diào)用daoimpl,Dao實(shí)現(xiàn)daoimpl。如果你看一下三層Struts2結(jié)構(gòu),你就會(huì)知道發(fā)生了什么
這主要取決于你的項(xiàng)目:
例如,如果項(xiàng)目中使用了hibernate,以后可能會(huì)切換到mybatis,那么Dao需要使用這個(gè)接口。這不會(huì)影響上層代碼的更改。
另一個(gè)例子是,項(xiàng)目是一個(gè)單一的應(yīng)用程序。任何代碼修改都需要重新編譯整個(gè)項(xiàng)目,因此不需要接口。如果項(xiàng)目是由模塊編譯和部署的,那么可以使用接口解耦。假設(shè)修改了Dao,只需要重新編譯和部署Dao模塊,而不影響上層模塊。
此外,如果項(xiàng)目團(tuán)隊(duì)中有許多新手,簡(jiǎn)單的代碼結(jié)構(gòu)可能更合適。復(fù)雜項(xiàng)目結(jié)構(gòu)的學(xué)習(xí)成本較高。
如果工程進(jìn)度非常緊迫,我們可以用簡(jiǎn)單粗暴的方式用經(jīng)濟(jì)成本來說明原因。
使用接口的成本是不使用接口的成本(包括后續(xù)維護(hù)成本)。
如果項(xiàng)目變化很大,部署了模塊,項(xiàng)目不急,使用接口的成本比不使用接口的成本低,雖然早期不使用接口似乎更簡(jiǎn)單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢
Service層和Dao層真的有必要每個(gè)類都加上接口嗎?
struts的基本結(jié)構(gòu),JSP頁(yè)面是表示層視圖,動(dòng)作是業(yè)務(wù)邏輯,即控制層control,Dao,daoimpl,service,serviceimpl都是數(shù)據(jù)訪問的東西。General service和serviceimpl用于將action與Dao和daoimpl連接起來。通常使用彈簧注釋。在XML中,Dao和daoimpl是最后一個(gè)操作數(shù)據(jù)庫(kù)的。如果使用ibatis,則使用service和serviceimpl調(diào)用Dao和daoimpl,然后在Dao和daoimpl中編寫數(shù)據(jù)庫(kù)操作語句,最后在相應(yīng)的XML中編寫真正的數(shù)據(jù)庫(kù)操作語句
是SSH架構(gòu)的項(xiàng)目嗎?它代表三層。模型是一個(gè)實(shí)例,服務(wù)提供各種方法,Dao實(shí)現(xiàn)各種方法。Impl指的是實(shí)現(xiàn)。服務(wù)和Dao都需要實(shí)現(xiàn)。Dao的內(nèi)部方法一般實(shí)現(xiàn)與數(shù)據(jù)庫(kù)的交互,而model一般是數(shù)據(jù)庫(kù)中表的實(shí)例
rest是一種體系結(jié)構(gòu)風(fēng)格。它的核心是面向資源,遵循crud原則,它告訴我們對(duì)資源只需要四種行為:創(chuàng)建、獲取、更新和刪除。這些資源的操作由HTTP協(xié)議指定。WebService的底層是soap協(xié)議,核心是面向活動(dòng)的。有嚴(yán)格的規(guī)范和標(biāo)準(zhǔn),包括安全、交易等。
如果我們想使用restful或WebService,我們需要考慮資源本身。我們要看資源本身是一個(gè)簡(jiǎn)單的業(yè)務(wù)操作,類似于添加、刪除、修改、查詢,還是一個(gè)比較復(fù)雜的業(yè)務(wù)操作,比如轉(zhuǎn)移、事務(wù)處理等;第二是看是否有嚴(yán)格的規(guī)范和標(biāo)準(zhǔn),當(dāng)有多個(gè)業(yè)務(wù)系統(tǒng)的集成和開發(fā)時(shí),我們需要考慮在使用soap協(xié)議方面有比較優(yōu)勢(shì)。如果是簡(jiǎn)單的數(shù)據(jù)操作,沒有事務(wù)處理,并且開發(fā)和調(diào)用相對(duì)簡(jiǎn)單,那么使用rest架構(gòu)風(fēng)格就比較有優(yōu)勢(shì)。對(duì)于更復(fù)雜的面向活動(dòng)的服務(wù),使用rest是沒有意義的。
serviceImpl是在哪里被調(diào)用的。和dao層是什么關(guān)系?
JSP是MVC模式下的V,用于在視圖層中顯示。Servlet是C控制層,是系統(tǒng)的核心控制器。實(shí)際上,服務(wù)中有Dao,它是M模型層,用于與數(shù)據(jù)庫(kù)交互。一般來說,JSP向servlet發(fā)送數(shù)據(jù)。servlet接收到數(shù)據(jù)后,進(jìn)行分析,然后根據(jù)數(shù)據(jù)調(diào)用相應(yīng)的服務(wù)進(jìn)行服務(wù)。如果服務(wù)想調(diào)用數(shù)據(jù)庫(kù),它將與數(shù)據(jù)庫(kù)交互,將結(jié)果返回給servlet,servlet將結(jié)果返回給JSP。這是整個(gè)過程