關(guān)于maven全局配置文件settings.xml解析
settings.xml有什么用?
如果在Eclipse中使用過(guò)Maven插件,想必會(huì)有這個(gè)經(jīng)驗(yàn):配置settings.xml文件的路徑。
settings.xml文件是干什么的,為什么要配置它呢?
從settings.xml的文件名就可以看出,它是用來(lái)設(shè)置maven參數(shù)的配置文件。并且,settings.xml是maven的全局配置文件。而pom.xml文件是所在項(xiàng)目的局部配置。
Settings.xml中包含類(lèi)似本地倉(cāng)儲(chǔ)位置、修改遠(yuǎn)程倉(cāng)儲(chǔ)服務(wù)器、認(rèn)證信息等配置。
settings.xml文件位置
settings.xml文件一般存在于兩個(gè)位置:
全局配置: ${M2_HOME}/conf/settings.xml
用戶(hù)配置: user.home/.m2/settings.xmlnote:用戶(hù)配置優(yōu)先于全局配置。{user.home} 和和所有其他系統(tǒng)屬性只能在3.0+版本上使用。請(qǐng)注意windows和Linux使用變量的區(qū)別。
配置優(yōu)先級(jí)
需要注意的是:局部配置優(yōu)先于全局配置。
配置優(yōu)先級(jí)從高到低:pom.xml> user settings > global settings
如果這些文件同時(shí)存在,在應(yīng)用配置時(shí),會(huì)合并它們的內(nèi)容,如果有重復(fù)的配置,優(yōu)先級(jí)高的配置會(huì)覆蓋優(yōu)先級(jí)低的。
settings.xml元素詳解
頂級(jí)元素概覽
下面列舉了settings.xml中的頂級(jí)元素
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" ? ? ? xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? ? ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? <localRepository/> ? <interactiveMode/> ? <usePluginRegistry/> ? <offline/> ? <pluginGroups/> ? <servers/> ? <mirrors/> ? <proxies/> ? <profiles/> ? <activeProfiles/> </settings>
LocalRepository
作用:該值表示構(gòu)建系統(tǒng)本地倉(cāng)庫(kù)的路徑。
其默認(rèn)值:~/.m2/repository。
<localRepository>${user.home}/.m2/repository</localRepository>
InteractiveMode
作用:表示maven是否需要和用戶(hù)交互以獲得輸入。
如果maven需要和用戶(hù)交互以獲得輸入,則設(shè)置成true,反之則應(yīng)為false。默認(rèn)為true。
<interactiveMode>true</interactiveMode>
UsePluginRegistry
作用:maven是否需要使用plugin-registry.xml文件來(lái)管理插件版本。
如果需要讓maven使用文件~/.m2/plugin-registry.xml來(lái)管理插件版本,則設(shè)為true。默認(rèn)為false。
<usePluginRegistry>false</usePluginRegistry>
Offline
作用:表示maven是否需要在離線模式下運(yùn)行。
如果構(gòu)建系統(tǒng)需要在離線模式下運(yùn)行,則為true,默認(rèn)為false。
當(dāng)由于網(wǎng)絡(luò)設(shè)置原因或者安全因素,構(gòu)建服務(wù)器不能連接遠(yuǎn)程倉(cāng)庫(kù)的時(shí)候,該配置就十分有用。
<offline>false</offline>
PluginGroups
作用:當(dāng)插件的組織id(groupId)沒(méi)有顯式提供時(shí),供搜尋插件組織Id(groupId)的列表。
該元素包含一個(gè)pluginGroup元素列表,每個(gè)子元素包含了一個(gè)組織Id(groupId)。
當(dāng)我們使用某個(gè)插件,并且沒(méi)有在命令行為其提供組織Id(groupId)的時(shí)候,Maven就會(huì)使用該列表。默認(rèn)情況下該列表包含了org.apache.maven.plugins和org.codehaus.mojo。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <pluginGroups> ? ? <!--plugin的組織Id(groupId) --> ? ? <pluginGroup>org.codehaus.mojo</pluginGroup> ? </pluginGroups> ? ... </settings>
Servers
作用:一般,倉(cāng)庫(kù)的下載和部署是在pom.xml文件中的repositories和distributionManagement元素中定義的。然而,一般類(lèi)似用戶(hù)名、密碼(有些倉(cāng)庫(kù)訪問(wèn)是需要安全認(rèn)證的)等信息不應(yīng)該在pom.xml文件中配置,這些信息可以配置在settings.xml中。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <!--配置服務(wù)端的一些設(shè)置。一些設(shè)置如安全證書(shū)不應(yīng)該和pom.xml一起分發(fā)。這種類(lèi)型的信息應(yīng)該存在于構(gòu)建服務(wù)器上的settings.xml文件中。 --> ? <servers> ? ? <!--服務(wù)器元素包含配置服務(wù)器時(shí)需要的信息 --> ? ? <server> ? ? ? <!--這是server的id(注意不是用戶(hù)登陸的id),該id與distributionManagement中repository元素的id相匹配。 --> ? ? ? <id>server001</id> ? ? ? <!--鑒權(quán)用戶(hù)名。鑒權(quán)用戶(hù)名和鑒權(quán)密碼表示服務(wù)器認(rèn)證所需要的登錄名和密碼。 --> ? ? ? <username>my_login</username> ? ? ? <!--鑒權(quán)密碼 。鑒權(quán)用戶(hù)名和鑒權(quán)密碼表示服務(wù)器認(rèn)證所需要的登錄名和密碼。密碼加密功能已被添加到2.1.0 +。詳情請(qǐng)?jiān)L問(wèn)密碼加密頁(yè)面 --> ? ? ? <password>my_password</password> ? ? ? <!--鑒權(quán)時(shí)使用的私鑰位置。和前兩個(gè)元素類(lèi)似,私鑰位置和私鑰密碼指定了一個(gè)私鑰的路徑(默認(rèn)是${user.home}/.ssh/id_dsa)以及如果需要的話,一個(gè)密語(yǔ)。將來(lái)passphrase和password元素可能會(huì)被提取到外部,但目前它們必須在settings.xml文件以純文本的形式聲明。 --> ? ? ? <privateKey>${usr.home}/.ssh/id_dsa</privateKey> ? ? ? <!--鑒權(quán)時(shí)使用的私鑰密碼。 --> ? ? ? <passphrase>some_passphrase</passphrase> ? ? ? <!--文件被創(chuàng)建時(shí)的權(quán)限。如果在部署的時(shí)候會(huì)創(chuàng)建一個(gè)倉(cāng)庫(kù)文件或者目錄,這時(shí)候就可以使用權(quán)限(permission)。這兩個(gè)元素合法的值是一個(gè)三位數(shù)字,其對(duì)應(yīng)了unix文件系統(tǒng)的權(quán)限,如664,或者775。 --> ? ? ? <filePermissions>664</filePermissions> ? ? ? <!--目錄被創(chuàng)建時(shí)的權(quán)限。 --> ? ? ? <directoryPermissions>775</directoryPermissions> ? ? </server> ? </servers> ? ... </settings>
Mirrors
作用:為倉(cāng)庫(kù)列表配置的下載鏡像列表。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <mirrors> ? ? <!-- 給定倉(cāng)庫(kù)的下載鏡像。 --> ? ? <mirror> ? ? ? <!-- 該鏡像的唯一標(biāo)識(shí)符。id用來(lái)區(qū)分不同的mirror元素。 --> ? ? ? <id>planetmirror.com</id> ? ? ? <!-- 鏡像名稱(chēng) --> ? ? ? <name>PlanetMirror Australia</name> ? ? ? <!-- 該鏡像的URL。構(gòu)建系統(tǒng)會(huì)優(yōu)先考慮使用該URL,而非使用默認(rèn)的服務(wù)器URL。 --> ? ? ? <url>http://downloads.planetmirror.com/pub/maven2</url> ? ? ? <!-- 被鏡像的服務(wù)器的id。例如,如果我們要設(shè)置了一個(gè)Maven中央倉(cāng)庫(kù)(http://repo.maven.apache.org/maven2/)的鏡像,就需要將該元素設(shè)置成central。這必須和中央倉(cāng)庫(kù)的id central完全一致。 --> ? ? ? <mirrorOf>central</mirrorOf> ? ? </mirror> ? </mirrors> ? ... </settings>
Proxies
作用:用來(lái)配置不同的代理。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <proxies> ? ? <!--代理元素包含配置代理時(shí)需要的信息 --> ? ? <proxy> ? ? ? <!--代理的唯一定義符,用來(lái)區(qū)分不同的代理元素。 --> ? ? ? <id>myproxy</id> ? ? ? <!--該代理是否是激活的那個(gè)。true則激活代理。當(dāng)我們聲明了一組代理,而某個(gè)時(shí)候只需要激活一個(gè)代理的時(shí)候,該元素就可以派上用處。 --> ? ? ? <active>true</active> ? ? ? <!--代理的協(xié)議。 協(xié)議://主機(jī)名:端口,分隔成離散的元素以方便配置。 --> ? ? ? <protocol>http</protocol> ? ? ? <!--代理的主機(jī)名。協(xié)議://主機(jī)名:端口,分隔成離散的元素以方便配置。 --> ? ? ? <host>proxy.somewhere.com</host> ? ? ? <!--代理的端口。協(xié)議://主機(jī)名:端口,分隔成離散的元素以方便配置。 --> ? ? ? <port>8080</port> ? ? ? <!--代理的用戶(hù)名,用戶(hù)名和密碼表示代理服務(wù)器認(rèn)證的登錄名和密碼。 --> ? ? ? <username>proxyuser</username> ? ? ? <!--代理的密碼,用戶(hù)名和密碼表示代理服務(wù)器認(rèn)證的登錄名和密碼。 --> ? ? ? <password>somepassword</password> ? ? ? <!--不該被代理的主機(jī)名列表。該列表的分隔符由代理服務(wù)器指定;例子中使用了豎線分隔符,使用逗號(hào)分隔也很常見(jiàn)。 --> ? ? ? <nonProxyHosts>*.google.com|ibiblio.org</nonProxyHosts> ? ? </proxy> ? </proxies> ? ... </settings>
Profiles
作用:根據(jù)環(huán)境參數(shù)來(lái)調(diào)整構(gòu)建配置的列表。
settings.xml中的profile元素是pom.xml中profile元素的裁剪版本。
它包含了id、activation、repositories、pluginRepositories和 properties元素。這里的profile元素只包含這五個(gè)子元素是因?yàn)檫@里只關(guān)心構(gòu)建系統(tǒng)這個(gè)整體(這正是settings.xml文件的角色定位),而非單獨(dú)的項(xiàng)目對(duì)象模型設(shè)置。如果一個(gè)settings.xml中的profile被激活,它的值會(huì)覆蓋任何其它定義在pom.xml中帶有相同id的profile。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <profiles> ? ? <profile> ? ? ? <!-- profile的唯一標(biāo)識(shí) --> ? ? ? <id>test</id> ? ? ? <!-- 自動(dòng)觸發(fā)profile的條件邏輯 --> ? ? ? <activation /> ? ? ? <!-- 擴(kuò)展屬性列表 --> ? ? ? <properties /> ? ? ? <!-- 遠(yuǎn)程倉(cāng)庫(kù)列表 --> ? ? ? <repositories /> ? ? ? <!-- 插件倉(cāng)庫(kù)列表 --> ? ? ? <pluginRepositories /> ? ? </profile> ? </profiles> ? ... </settings>
Activation
作用:自動(dòng)觸發(fā)profile的條件邏輯。
如pom.xml中的profile一樣,profile的作用在于它能夠在某些特定的環(huán)境中自動(dòng)使用某些特定的值;這些環(huán)境通過(guò)activation元素指定。
activation元素并不是激活profile的唯一方式。settings.xml文件中的activeProfile元素可以包含profile的id。profile也可以通過(guò)在命令行,使用-P標(biāo)記和逗號(hào)分隔的列表來(lái)顯式的激活(如,-P test)。
<activation> ? <!--profile默認(rèn)是否激活的標(biāo)識(shí) --> ? <activeByDefault>false</activeByDefault> ? <!--當(dāng)匹配的jdk被檢測(cè)到,profile被激活。例如,1.4激活JDK1.4,1.4.0_2,而!1.4激活所有版本不是以1.4開(kāi)頭的JDK。 --> ? <jdk>1.5</jdk> ? <!--當(dāng)匹配的操作系統(tǒng)屬性被檢測(cè)到,profile被激活。os元素可以定義一些操作系統(tǒng)相關(guān)的屬性。 --> ? <os> ? ? <!--激活profile的操作系統(tǒng)的名字 --> ? ? <name>Windows XP</name> ? ? <!--激活profile的操作系統(tǒng)所屬家族(如 'windows') --> ? ? <family>Windows</family> ? ? <!--激活profile的操作系統(tǒng)體系結(jié)構(gòu) --> ? ? <arch>x86</arch> ? ? <!--激活profile的操作系統(tǒng)版本 --> ? ? <version>5.1.2600</version> ? </os> ? <!--如果Maven檢測(cè)到某一個(gè)屬性(其值可以在POM中通過(guò)${name}引用),其擁有對(duì)應(yīng)的name = 值,Profile就會(huì)被激活。如果值字段是空的,那么存在屬性名稱(chēng)字段就會(huì)激活profile,否則按區(qū)分大小寫(xiě)方式匹配屬性值字段 --> ? <property> ? ? <!--激活profile的屬性的名稱(chēng) --> ? ? <name>mavenVersion</name> ? ? <!--激活profile的屬性的值 --> ? ? <value>2.0.3</value> ? </property> ? <!--提供一個(gè)文件名,通過(guò)檢測(cè)該文件的存在或不存在來(lái)激活profile。missing檢查文件是否存在,如果不存在則激活profile。另一方面,exists則會(huì)檢查文件是否存在,如果存在則激活profile。 --> ? <file> ? ? <!--如果指定的文件存在,則激活profile。 --> ? ? <exists>${basedir}/file2.properties</exists> ? ? <!--如果指定的文件不存在,則激活profile。 --> ? ? <missing>${basedir}/file1.properties</missing> ? </file> </activation>
注:在maven工程的pom.xml所在目錄下執(zhí)行mvn help:active-profiles命令可以查看中央倉(cāng)儲(chǔ)的profile是否在工程中生效。
properties
作用:對(duì)應(yīng)profile的擴(kuò)展屬性列表。
maven屬性和ant中的屬性一樣,可以用來(lái)存放一些值。這些值可以在pom.xml中的任何地方使用標(biāo)記${X}來(lái)使用,這里X是指屬性的名稱(chēng)。屬性有五種不同的形式,并且都能在settings.xml文件中訪問(wèn)。
<!--? ? 1. env.X: 在一個(gè)變量前加上"env."的前綴,會(huì)返回一個(gè)shell環(huán)境變量。例如,"env.PATH"指代了$path環(huán)境變量(在Windows上是%PATH%)。? ? 2. project.x:指代了POM中對(duì)應(yīng)的元素值。例如: <project><version>1.0</version></project>通過(guò)${project.version}獲得version的值。? ? 3. settings.x: 指代了settings.xml中對(duì)應(yīng)元素的值。例如:<settings><offline>false</offline></settings>通過(guò) ${settings.offline}獲得offline的值。? ? 4. Java System Properties: 所有可通過(guò)java.lang.System.getProperties()訪問(wèn)的屬性都能在POM中使用該形式訪問(wèn),例如 ${java.home}。? ? 5. x: 在<properties/>元素中,或者外部文件中設(shè)置,以${someVar}的形式使用。 ?--> <properties> ? <user.install>${user.home}/our-project</user.install> </properties>
注:如果該profile被激活,則可以在pom.xml中使用${user.install}。
Repositories
作用:遠(yuǎn)程倉(cāng)庫(kù)列表,它是maven用來(lái)填充構(gòu)建系統(tǒng)本地倉(cāng)庫(kù)所使用的一組遠(yuǎn)程倉(cāng)庫(kù)。
<repositories> ? <!--包含需要連接到遠(yuǎn)程倉(cāng)庫(kù)的信息 --> ? <repository> ? ? <!--遠(yuǎn)程倉(cāng)庫(kù)唯一標(biāo)識(shí) --> ? ? <id>codehausSnapshots</id> ? ? <!--遠(yuǎn)程倉(cāng)庫(kù)名稱(chēng) --> ? ? <name>Codehaus Snapshots</name> ? ? <!--如何處理遠(yuǎn)程倉(cāng)庫(kù)里發(fā)布版本的下載 --> ? ? <releases> ? ? ? <!--true或者false表示該倉(cāng)庫(kù)是否為下載某種類(lèi)型構(gòu)件(發(fā)布版,快照版)開(kāi)啟。 --> ? ? ? <enabled>false</enabled> ? ? ? <!--該元素指定更新發(fā)生的頻率。Maven會(huì)比較本地POM和遠(yuǎn)程POM的時(shí)間戳。這里的選項(xiàng)是:always(一直),daily(默認(rèn),每日),interval:X(這里X是以分鐘為單位的時(shí)間間隔),或者never(從不)。 --> ? ? ? <updatePolicy>always</updatePolicy> ? ? ? <!--當(dāng)Maven驗(yàn)證構(gòu)件校驗(yàn)文件失敗時(shí)該怎么做-ignore(忽略),fail(失敗),或者warn(警告)。 --> ? ? ? <checksumPolicy>warn</checksumPolicy> ? ? </releases> ? ? <!--如何處理遠(yuǎn)程倉(cāng)庫(kù)里快照版本的下載。有了releases和snapshots這兩組配置,POM就可以在每個(gè)單獨(dú)的倉(cāng)庫(kù)中,為每種類(lèi)型的構(gòu)件采取不同的策略。例如,可能有人會(huì)決定只為開(kāi)發(fā)目的開(kāi)啟對(duì)快照版本下載的支持。參見(jiàn)repositories/repository/releases元素 --> ? ? <snapshots> ? ? ? <enabled /> ? ? ? <updatePolicy /> ? ? ? <checksumPolicy /> ? ? </snapshots> ? ? <!--遠(yuǎn)程倉(cāng)庫(kù)URL,按protocol://hostname/path形式 --> ? ? <url>http://snapshots.maven.codehaus.org/maven2</url> ? ? <!--用于定位和排序構(gòu)件的倉(cāng)庫(kù)布局類(lèi)型-可以是default(默認(rèn))或者legacy(遺留)。Maven 2為其倉(cāng)庫(kù)提供了一個(gè)默認(rèn)的布局;然而,Maven 1.x有一種不同的布局。我們可以使用該元素指定布局是default(默認(rèn))還是legacy(遺留)。 --> ? ? <layout>default</layout> ? </repository> </repositories>
pluginRepositories
作用:發(fā)現(xiàn)插件的遠(yuǎn)程倉(cāng)庫(kù)列表。
和repository類(lèi)似,只是repository是管理jar包依賴(lài)的倉(cāng)庫(kù),pluginRepositories則是管理插件的倉(cāng)庫(kù)。
maven插件是一種特殊類(lèi)型的構(gòu)件。由于這個(gè)原因,插件倉(cāng)庫(kù)獨(dú)立于其它倉(cāng)庫(kù)。pluginRepositories元素的結(jié)構(gòu)和repositories元素的結(jié)構(gòu)類(lèi)似。每個(gè)pluginRepository元素指定一個(gè)Maven可以用來(lái)尋找新插件的遠(yuǎn)程地址。
<pluginRepositories> ? <!-- 包含需要連接到遠(yuǎn)程插件倉(cāng)庫(kù)的信息.參見(jiàn)profiles/profile/repositories/repository元素的說(shuō)明 --> ? <pluginRepository> ? ? <releases> ? ? ? <enabled /> ? ? ? <updatePolicy /> ? ? ? <checksumPolicy /> ? ? </releases> ? ? <snapshots> ? ? ? <enabled /> ? ? ? <updatePolicy /> ? ? ? <checksumPolicy /> ? ? </snapshots> ? ? <id /> ? ? <name /> ? ? <url /> ? ? <layout /> ? </pluginRepository> </pluginRepositories>
ActiveProfiles
作用:手動(dòng)激活profiles的列表,按照profile被應(yīng)用的順序定義activeProfile。
該元素包含了一組activeProfile元素,每個(gè)activeProfile都含有一個(gè)profile id。任何在activeProfile中定義的profile id,不論環(huán)境設(shè)置如何,其對(duì)應(yīng)的 profile都會(huì)被激活。如果沒(méi)有匹配的profile,則什么都不會(huì)發(fā)生。
例如,env-test是一個(gè)activeProfile,則在pom.xml(或者profile.xml)中對(duì)應(yīng)id的profile會(huì)被激活。如果運(yùn)行過(guò)程中找不到這樣一個(gè)profile,Maven則會(huì)像往常一樣運(yùn)行。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 ? ? ? ? ? ? ? ? ? ? ? https://maven.apache.org/xsd/settings-1.0.0.xsd"> ? ... ? <activeProfiles> ? ? <!-- 要激活的profile id --> ? ? <activeProfile>env-test</activeProfile> ? </activeProfiles> ? ... </settings>
至此,maven settings.xml中的標(biāo)簽都講解完畢,以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決java junit單元測(cè)試@Test報(bào)錯(cuò)的問(wèn)題
今天小編就為大家分享一篇解決java junit單元測(cè)試@Test報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11Jmeter參數(shù)化實(shí)現(xiàn)方法及應(yīng)用實(shí)例
這篇文章主要介紹了Jmeter參數(shù)化實(shí)現(xiàn)方法及應(yīng)用實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08MyBatis配置文件解析與MyBatis實(shí)例演示
這篇文章主要介紹了MyBatis配置文件解析與MyBatis實(shí)例演示以及怎樣編譯安裝MyBatis,需要的朋友可以參考下2022-04-04使用Java應(yīng)用程序添加或刪除 PDF 中的附件
當(dāng)我們?cè)谥谱鱌DF文件或者PPT演示文稿的時(shí)候,為了讓自己的文件更全面詳細(xì),就會(huì)在文件中添加附件,那么如何添加或刪除PDF中的附件呢,今天通過(guò)本文給大家詳細(xì)講解,需要的朋友參考下吧2023-01-01靜態(tài)方法中調(diào)用Spring注入過(guò)程解析
這篇文章主要介紹了靜態(tài)方法中調(diào)用Spring注入過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11