版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
SpringMVC技術(shù)體系介紹2024/3/161MVC模式介紹SpringMVC架構(gòu)SpringMVC重要組件2024/3/162目錄MVC模式介紹——J2EE中的MVC2024/3/163MVC模式介紹模型-視圖-控制器(Model-View-Controller)把一個(gè)應(yīng)用的輸入、處理、輸出流程按照Model、View、Controller的方式進(jìn)行別離,這樣一個(gè)應(yīng)用被分成三個(gè)層——模型層、視圖層、控制層。MVC模式是解決了展示以及業(yè)務(wù)邏輯實(shí)現(xiàn)的別離。讓開發(fā)者可以專心地解決不同層的編碼。也方便代碼重用和測(cè)試和維護(hù)。JSP、HTML、XMLServlet、Struts、Spring實(shí)體Bean、Entity、VO、FormBean2024/3/164Services層常用的應(yīng)用系統(tǒng)中的多層結(jié)構(gòu)View展示層Controller控制層業(yè)務(wù)邏輯處理層數(shù)據(jù)持久化層〔DAO〕實(shí)體Bean、Entity層數(shù)據(jù)庫2024/3/165MVC設(shè)計(jì)思想 MVC是一種復(fù)合模式,結(jié)合了觀察者模式、策略模式、組合模式、適配器模式。
模型使用觀察者模式,以便觀察者更新,同時(shí)保持兩者之間的解耦??刂破魇且晥D的策略,視圖使用組合模式實(shí)現(xiàn)用戶界面。適配器模式用來將模型適配成符合現(xiàn)有視圖和控制器的需要的模型。
這些模式合作把MVC模式的三層解耦。2024/3/166MVC設(shè)計(jì)思想視圖(View)代表用戶交互界面,對(duì)于Web應(yīng)用來說,可以是HTML,也可能是jsp、XML和Applet等。一個(gè)應(yīng)用可能有很多不同的視圖,MVC設(shè)計(jì)模式對(duì)于視圖的處理僅限于視圖上數(shù)據(jù)的采集和處理,以及用戶的請(qǐng)求,而不包括在視圖上的業(yè)務(wù)流程的處理。業(yè)務(wù)流程的處理交予模型(Model)處理。比方一個(gè)訂單的視圖只接受來自模型的數(shù)據(jù)并顯示給用戶,以及將用戶界面的輸入數(shù)據(jù)和請(qǐng)求傳遞給控制和模型。
2024/3/167MVC設(shè)計(jì)思想模型(Model):是業(yè)務(wù)的處理以及業(yè)務(wù)規(guī)那么的制定。模型接受視圖請(qǐng)求的數(shù)據(jù),并返回最終的處理結(jié)果。業(yè)務(wù)模型的設(shè)計(jì)是MVC最主要的核心。MVC設(shè)計(jì)模式告訴我們,把應(yīng)用的模型按一定的規(guī)那么抽取出來,抽取的層次很重要,抽象與具體不能隔得太遠(yuǎn),也不能太近。MVC并沒有提供模型的設(shè)計(jì)方法,而只是組織管理這些模型,以便于模型的重構(gòu)和提高重用性。業(yè)務(wù)模型還有一個(gè)很重要的模型那就是數(shù)據(jù)模型。數(shù)據(jù)模型主要指實(shí)體對(duì)象的數(shù)據(jù)保存〔持續(xù)化〕。比方將一張訂單保存到數(shù)據(jù)庫,從數(shù)據(jù)庫獲取訂單。我們可以將這個(gè)模型單獨(dú)列出,所有有關(guān)數(shù)據(jù)庫的操作只限制在該模型中。2024/3/168MVC設(shè)計(jì)思想控制(Controller)可以理解為從用戶接收請(qǐng)求,將模型與視圖匹配在一起,共同完成用戶的請(qǐng)求。劃分控制層的作用也很明顯,它清楚地告訴你,它就是一個(gè)分發(fā)器,選擇什么樣的模型,選擇什么樣的視圖,可以完成什么樣的用戶請(qǐng)求??刂茖硬⒉蛔鋈魏蔚臄?shù)據(jù)處理。例如,用戶點(diǎn)擊一個(gè)連接,控制層接受請(qǐng)求后,并不處理業(yè)務(wù)信息,它只把用戶的信息傳遞給模型,告訴模型做什么,選擇符合要求的視圖返回給用戶。因此,一個(gè)模型可能對(duì)應(yīng)多個(gè)視圖,一個(gè)視圖可能對(duì)應(yīng)多個(gè)模型。
2024/3/169JSPModel1架構(gòu)Model1的根底是JSP文件,它由一些相互獨(dú)立的JSP文件和其他一些JavaClass組成。這些JSP從HTTPRequest中獲得所需要的數(shù)據(jù),處理業(yè)務(wù)邏輯,然后將結(jié)果通過Response返前端瀏覽器。Model1的應(yīng)該說是唯一的好處是“簡(jiǎn)單”,可以大大加快系統(tǒng)的開發(fā)進(jìn)度。它把表現(xiàn)層和業(yè)務(wù)邏輯層柔和在一起,不利于以后的維護(hù)工作以及開發(fā)角色的分配,所以這種模式只能適合于小的系統(tǒng)開發(fā)。2024/3/1610JSPModel2架構(gòu) Model2采用面向?qū)ο蠹夹g(shù)實(shí)現(xiàn)MVC模式從而擴(kuò)展JSP/Servlet的模式。Model2是MVC在Web上的應(yīng)用。2024/3/1611一個(gè)Model2標(biāo)準(zhǔn)實(shí)現(xiàn)的Web框架2024/3/1612一個(gè)Model2標(biāo)準(zhǔn)實(shí)現(xiàn)的Web框架視圖層采用JSP實(shí)現(xiàn);控制層采用Servlet實(shí)現(xiàn),整個(gè)框架采用同一個(gè)Servlet,以實(shí)現(xiàn)請(qǐng)求的中轉(zhuǎn);模型層采用Java實(shí)現(xiàn),主要決定用來做什么;在模型層后添加了一個(gè)DAO,目的是將決定做什么和具體怎么做分開。整個(gè)Web框架大致的流程是:首先客戶端發(fā)送請(qǐng)求,提交JSP頁面給中轉(zhuǎn)器〔Servlet〕;中轉(zhuǎn)器根據(jù)客戶的請(qǐng)求,選擇相應(yīng)的模型層,即Logic,Logic進(jìn)行相應(yīng)的邏輯處理;如果需要使用數(shù)據(jù)庫,那么通過DAO進(jìn)行相應(yīng)的數(shù)據(jù)庫操作。2024/3/1613SpringMVC架構(gòu)2024/3/1614SpringMVC架構(gòu)SpringMVC是結(jié)構(gòu)最清晰的MVCModel2實(shí)現(xiàn)。它的Action也不叫Action,而是稱做Controller;Controller接收request,response參數(shù),然后返回ModelAndView〔其中的Model不是Object類型,而是Map類型〕。但在其它的WebFramework中,Action返回值一般都只是一個(gè)ViewName;Model那么需要通過其它的途徑〔如request.attribute,Context參數(shù),或Action本身的屬性數(shù)據(jù)〕傳遞上去。2024/3/1615SpringWebMVC請(qǐng)求處理流程2024/3/1616SpringMVC特點(diǎn)清晰的角色劃分:控制器〔controller〕、驗(yàn)證器〔validator〕、命令對(duì)象〔commandobject〕、表單對(duì)象〔formobject〕、模型對(duì)象〔modelobject〕、Servlet分發(fā)器〔DispatcherServlet〕、處理器映射〔handlermapping〕、視圖解析器〔viewresolver〕等。每一個(gè)角色都可以由一個(gè)專門的對(duì)象來實(shí)現(xiàn)。強(qiáng)大而直接的配置方式:將框架類和應(yīng)用程序類都能作為JavaBean配置,支持跨多個(gè)context的引用,例如,在web控制器中對(duì)業(yè)務(wù)對(duì)象和驗(yàn)證器〔validator〕的引用??蛇m配、非侵入:可以根據(jù)不同的應(yīng)用場(chǎng)景,選擇適宜的控制器子類〔simple型、command型、form型、wizard型、multi-action型或者自定義〕,而不是從單一控制器〔比方Action/ActionForm〕繼承。2024/3/1617SpringMVC特點(diǎn)可重用的業(yè)務(wù)代碼:可以使用現(xiàn)有的業(yè)務(wù)對(duì)象作為命令或表單對(duì)象,而不需要去擴(kuò)展某個(gè)特定框架的基類??啥ㄖ频慕壎ā瞓inding〕和驗(yàn)證〔validation〕:比方將類型不匹配作為應(yīng)用級(jí)的驗(yàn)證錯(cuò)誤,這可以保存錯(cuò)誤的值。再比方本地化的日期和數(shù)字綁定等等。在其他某些框架中,你只能使用字符串表單對(duì)象,需要手動(dòng)解析它并轉(zhuǎn)換到業(yè)務(wù)對(duì)象。可定制的handlermapping和viewresolution:Spring提供從最簡(jiǎn)單的URL映射,到復(fù)雜的、專用的定制策略。與某些webMVC框架強(qiáng)制開發(fā)人員使用單一特定技術(shù)相比,Spring顯得更加靈活。靈活的model轉(zhuǎn)換:在Springweb框架中,使用基于Map的鍵/值對(duì)來到達(dá)輕易地與各種視圖技術(shù)的集成。2024/3/1618SpringMVC特點(diǎn)可定制的本地化和主題〔theme〕解析:支持在JSP中可選擇地使用Spring標(biāo)簽庫、支持JSTL、支持Velocity〔不需要額外的中間層〕等等。簡(jiǎn)單而強(qiáng)大的JSP標(biāo)簽庫〔SpringTagLibrary〕:支持包括諸如數(shù)據(jù)綁定和主題〔theme〕之類的許多功能。JSP表單標(biāo)簽庫:在Spring2.0中引入的表單標(biāo)簽庫,使得在JSP中編寫表單更加容易。SpringBean的生命周期可以被限制在當(dāng)前的HTTPRequest或者HTTPSession。2024/3/1619SpringMVC重要組件2024/3/1620SpringMVC重要組件Springmvc請(qǐng)所有的請(qǐng)求都提交給DispatcherServlet,它會(huì)委托應(yīng)用系統(tǒng)的其他模塊負(fù)責(zé)負(fù)責(zé)對(duì)請(qǐng)求進(jìn)行真正的處理工作。DispatcherServlet查詢一個(gè)或多個(gè)HandlerMapping,找到處理請(qǐng)求的Controller。DispatcherServlet請(qǐng)請(qǐng)求提交到目標(biāo)Controller。Controller進(jìn)行業(yè)務(wù)邏輯處理后,會(huì)返回一個(gè)ModelAndView。Dispathcher查詢一個(gè)或多個(gè)ViewResolver視圖解析器,找到ModelAndView對(duì)象指定的視圖對(duì)象。視圖對(duì)象負(fù)責(zé)渲染返回給客戶端。
2024/3/1621SpringMVC架構(gòu)類圖2024/3/1622DispatcherServlet2024/3/1623DispatcherServlet應(yīng)用了“FrontController”
模式–是所有SpringMVC請(qǐng)求的中樞。繼承了HttpServlet,是一個(gè)Servlet,由WebApplicationContext加載如果不作其它配置,會(huì)加載默認(rèn)組件2024/3/1624在web.xml配DispatcherServletweb.xml…<servlet><servlet-name>dispatcher</servlet-name><servlet-class></servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>WEB-INF/mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet>…2024/3/1625HandlerMapping2024/3/1626HandlerMapping將web請(qǐng)求映射到正確的處理器〔handler〕上,通常是一個(gè)Controller不需用自定義處理器映射–已經(jīng)內(nèi)置了很多處理器映射策略在處理器映射中通過配置攔截器〔包括處理器執(zhí)行前、執(zhí)行后、或者執(zhí)行前后運(yùn)行攔截器〕將使其功能更強(qiáng)大2024/3/1627BeanNameUrlHandlerMapping把一個(gè)URL影射到一個(gè)和它名字相同的已注冊(cè)的bean–比方/simple將影射到一個(gè)名為“/simple”的bean??梢越obean多個(gè)名字(別名)通過空格來分隔必須有一個(gè)name屬性–“/”在xml中不能定義id屬性在bean名字中可以使用通配符(/simple*)是默認(rèn)的HandlerMapping,如果在上下文中沒有找到處理器映射,DispatcherServlet會(huì)為你創(chuàng)立一個(gè)BeanNameUrlHandlerMapping,但不鼓勵(lì)2024/3/1628BeanNameUrlHandlerMappingdispatcher-servlet.xml<beanclass="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/><beanname="/simple.htm/simpleSimon.htm"class="com.twoqubed.mvc.web.SimpleController">…</bean>2024/3/1629SimpleUrlHandlerMapping最常用的處理器映射,將請(qǐng)求的URLs影射到handlers由一系列的分別代表URLs和bean的名字的name/value對(duì)來定義影射。Bean的名字可以用通配符(/simple*)2024/3/1630SimpleUrlHandlerMappingdispatcher-servlet.xml…<beanclass="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"><propertyname="mappings"><value>/simple.htm=simpleController/test*=testController</value></property></bean>…2024/3/1631ControllerClassNameHandlerMapping支持慣例優(yōu)先原那么在它的應(yīng)用上下文中找出所有不同的處理器〔handler〕〔或Controller〕bean,并去掉名稱中的Controller,來定義它的處理器映射。Removed"Controller"fromclassname全部轉(zhuǎn)為小寫前面加“/”后面附"*“例子:WelcomeController映射到“/welcome*”請(qǐng)求URL極大的減少了影射的配置dispatcher-servlet.xml<beanclass=".
support.ControllerClassNameHandlerMapping"/>2024/3/1632Controllers2024/3/1633Controller接口負(fù)責(zé)處理請(qǐng)求內(nèi)部參數(shù)繼承HttpServlethandleRequest(HttpServletRequest,HttpServletResponse)返回一個(gè)ModelAndView對(duì)象所有實(shí)現(xiàn)都是線程平安的根本不用自己實(shí)現(xiàn)接口–已經(jīng)提供了很多實(shí)用的實(shí)現(xiàn)類2024/3/1634ModelAndView對(duì)象封裝了用來渲染頁面的model和viewModel用實(shí)現(xiàn)的添加對(duì)象,可以不需用名字:addObject(String,Object)–用顯式名字添加addObject(Object)–用默認(rèn)名添加(慣例優(yōu)先)View用String或View對(duì)象表示類似Struts的Action2024/3/1635Controller實(shí)現(xiàn)通常在我們的應(yīng)用中要求Controllers:自動(dòng)作默認(rèn)處理(不用編碼)簡(jiǎn)單web處理在web層和service層之間作相應(yīng)的處理參數(shù)處理視圖跳轉(zhuǎn)輸入驗(yàn)證2024/3/1636AbstractController提供了簡(jiǎn)單的操作用來處理一個(gè)簡(jiǎn)單的請(qǐng)求protectedModelAndViewhandleRequestInternal(HttpServletRequestrequest,HttpServletResponseresponse){Stringtext=service.getText();returnnewModelAndView("simple","text",text);}2024/3/1637ThrowawayController中文叫做一次性控制器,也就像一次性筷子那樣用完即丟并不在Spring的Controller繼承架構(gòu)中,而是一個(gè)獨(dú)立的接口定義當(dāng)映射的不是一個(gè)model對(duì)象時(shí)很有用Bean的作用域必須是prototype,他們本身不是線程平安的2024/3/1638ThrowawayControllerdispatcher-servlet.xml…<beanid="exampleThrowawayController"class="com.twoqubed.mvc.web.ExampleThrowawayController"scope="prototype"/>…配置作為一個(gè)prototypebean2024/3/1639ThrowawayControllerpublicclassExampleThrowawayControllerimplementsThrowawayController{privateStringmessage;publicvoidsetMessage(Stringmessage){this.message=message;}publicModelAndViewexecute()throwsException{StringhashCodeMessage="["+hashCode()+"]-"+message;returnnewModelAndView("throwaway","message",hashCodeMessage);}}2024/3/1640CommandControllers提供了一種和數(shù)據(jù)對(duì)象交互的方式,并動(dòng)態(tài)地將來自HttpServletRequest的參數(shù)綁定到指定的數(shù)據(jù)對(duì)象上。功能和Struts中的ActionForm有點(diǎn)像,不過在Spring中,不需要實(shí)現(xiàn)任何接口來實(shí)現(xiàn)數(shù)據(jù)綁定Command可以是任何POJO–通常是一個(gè)domain對(duì)象提供的功能:綁定用戶類型自動(dòng)驗(yàn)證自動(dòng)創(chuàng)立command對(duì)象稍后會(huì)用到…2024/3/1641CommandControllersAbstractCommandController–提供綁定和驗(yàn)證SimpleFormController–除了提供綁定和驗(yàn)證,還提供了工作流中的表單處理對(duì)表單form處理很有用具體細(xì)節(jié)后面介紹AbstractWizardFormController–適合涉及多個(gè)頁面的表單form處理2024/3/1642其他ControllersServletWrappingControllerandServletForwardingController–為了Struts專門設(shè)計(jì)的,在spring攔截器里封裝了Strutsservlet,作用相當(dāng)于代理Struts的ActionServletParameterizableViewController–簡(jiǎn)單的返回一個(gè)指定的視圖名稱,不涉及客戶端視圖技術(shù)〔從而防止了在Java代碼中的硬編碼〕UrlFilenameViewController–會(huì)檢查URL,獲取文件請(qǐng)求的文件名,并把它作為視圖名加以使用。如:對(duì)應(yīng)的視圖文件名是index2024/3/1643攔截器(Interceptors)2024/3/1644攔截器Interceptors在請(qǐng)求前后添加其它功能包括攔截器方法–preHandleandpostHandle包括回調(diào)方法–afterCompletetion可以通過HandlerMapping和一系列Controller關(guān)聯(lián)上2024/3/1645攔截器Interceptors實(shí)現(xiàn)實(shí)現(xiàn)HandlerInterceptor或WebRequestInterceptorSpring提供的幾個(gè)實(shí)現(xiàn)OvenXxxInViewInteceptor–用于ORM架構(gòu)JDO,JPAandHibernateUserRoleAuthorizationInterceptor–用于各種角色授權(quán)驗(yàn)證其他有用的擴(kuò)展:自定義平安,caching,…2024/3/1646攔截器Interceptors例子下面的例子提供了一個(gè)攔截器,它攔截所有請(qǐng)求,如果當(dāng)前時(shí)間不是在上午9點(diǎn)到下午6點(diǎn),它將用戶重定向到某個(gè)頁面。所有的請(qǐng)求都將被TimeBasedAccessInterceptor截獲,如果當(dāng)前時(shí)間不在上班時(shí)間,用戶會(huì)被重定向到一個(gè)靜態(tài)html頁面,提供諸如只有上班時(shí)間才能訪問網(wǎng)站之類的告示。2024/3/1647攔截器Interceptors例子<beans><beanid="handlerMapping"class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"><propertyname="interceptors"><list>
<refbean="officeHoursInterceptor"/></list></property><propertyname="mappings"><value> /*.form=editAccountFormController
/*.view=editAccountFormController</value></property></bean><beanid="officeHoursInterceptor"class="samples.TimeBasedAccessInterceptor"><propertyname="openingTime"value="9"/> <propertyname="closingTime"value="18"/></bean><beans>2024/3/1648攔截器Interceptors例子packagesamples;publicclassTimeBasedAccessInterceptorextendsHandlerInterceptorAdapter{ privateintopeningTime; privateintclosingTime; publicvoidsetOpeningTime(intopeningTime){ this.openingTime=openingTime; } publicvoidsetClosingTime(intclosingTime){ this.closingTime=closingTime; } publicbooleanpreHandle(HttpServletRequestrequest, HttpServletResponseresponse,Objecthandler)throwsException{ Calendarcal=Calendar.getInstance(); inthour=cal.get(HOUR_OF_DAY); if(openingTime<=hour<closingTime){ returntrue; }else{ response.sendRedirect("://host/outsideOfficeHours.html"); returnfalse; } }}2024/3/1649視圖解析器〔ViewResolver〕2024/3/1650視圖解析器〔ViewResolver〕從一個(gè)邏輯視圖名映射到一個(gè)視圖對(duì)象可以排序,所以能鏈在一起對(duì)JSP用戶,通常實(shí)現(xiàn)InternalResourceViewResolver:<beanid="internalResourceViewResolver"…<propertyname="prefix"value="/WEB-INF/jsp/"/><propertyname="suffix"value=".jsp"/></bean>2024/3/1651其它視圖解析器的實(shí)現(xiàn)VelocityViewResolver–針對(duì)Velocitytemplates設(shè)計(jì)的FreeMarkerViewResolver–針對(duì)FreeMarkertemplates設(shè)計(jì)的ResourceBundleViewResolver映射關(guān)系在一個(gè)properties文件支持國(guó)際化X
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版生態(tài)停車場(chǎng)雨棚建設(shè)與綠化合同3篇
- 2025年校園樂器更新?lián)Q代采購(gòu)與安裝合同3篇
- 二零二四年二手挖掘機(jī)交易合同與維修配件供應(yīng)協(xié)議3篇
- 2025年新能源車輛信托借款合同173篇
- 二零二五年度知識(shí)產(chǎn)權(quán)授權(quán)使用合同樣本6篇
- 二零二五版水利工程招投標(biāo)合同范本及管理要求6篇
- 2025年度高效溫室大棚租賃與農(nóng)業(yè)科技成果轉(zhuǎn)化與應(yīng)用合同3篇
- 二零二五年節(jié)能減排項(xiàng)目投資與建設(shè)合同2篇
- 二零二五版企業(yè)日常經(jīng)營(yíng)信息安全與網(wǎng)絡(luò)安全合同3篇
- 2025年度拆除工程驗(yàn)收與移交分包合同標(biāo)準(zhǔn)文本4篇
- 江蘇省無錫市2024年中考語文試卷【附答案】
- 管理者的九大財(cái)務(wù)思維
- 四年級(jí)上冊(cè)數(shù)學(xué)應(yīng)用題練習(xí)100題附答案
- 2024年度中國(guó)電建集團(tuán)北京勘測(cè)設(shè)計(jì)研究院限公司校園招聘高頻難、易錯(cuò)點(diǎn)500題模擬試題附帶答案詳解
- 有關(guān)企業(yè)會(huì)計(jì)人員個(gè)人工作總結(jié)
- 人教版高中數(shù)學(xué)必修二《第十章 概率》單元同步練習(xí)及答案
- 干部人事檔案專項(xiàng)審核工作情況報(bào)告(8篇)
- 智慧校園信息化建設(shè)項(xiàng)目組織人員安排方案
- 多旋翼無人機(jī)駕駛員執(zhí)照(CAAC)備考試題庫大全-下部分
- 2024年青海一級(jí)健康管理師高頻核心題庫300題(含答案詳解)
- 2024年貴州省銅仁市中考文科綜合試卷真題
評(píng)論
0/150
提交評(píng)論