IntellIJ IDEA 配置 Maven 以及 修改 默認 Repository***


一.配置Maven環境

1.下載apache-maven文件,選擇自己需要的版本,地址: http://mirror.bit.edu.cn/apache/maven/maven-3/3.5.0/binaries/apache-maven-3.5.0-bin.zip

2.解壓1所下載文件,本人解壓到:D:\server\maven\apache-maven-3.5.0

3.配置Maven環境變量

a. MAVEN_HOME : D:\server\maven\apache-maven-3.5.0

b.PATH : %MAVEN_HOME%\bin;

c. MAVEN_OPTS : -Xms128m -Xmx512m -Duser.language=zh -Dfile.encoding=UTF-8

4.在CMD中輸入mvn -v,如出現下列信息,表示配置成功。

其中會顯示Java 配置環境以及Maven配置環境

 

二.修改Maven倉庫路徑

1.在D盤(個人根據自身情況而定)新建文件,如下:

 

2.配置D:\server\maven\中setting.xml文件,內容如下:

復制代碼
<?xml version="1.0" encoding="UTF-8"?>
<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 http://maven.apache.org/xsd/settings-1.0.0.xsd">
    
    <pluginGroups />
    <proxies />
    <servers />
    
    <localRepository>D:/server/maven/repository</localRepository>
    
    <mirrors>
        <mirror>
            <id>alimaven</id>
            <mirrorOf>central</mirrorOf>
            <name>aliyun maven</name>
            <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
        </mirror>
        <mirror>
            <id>alimaven</id>
            <name>aliyun maven</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
            <mirrorOf>central</mirrorOf>
        </mirror>
        <mirror>
            <id>central</id>
            <name>Maven Repository Switchboard</name>
            <url>http://repo1.maven.org/maven2/</url>
            <mirrorOf>central</mirrorOf>
        </mirror>
        <mirror>
            <id>repo2</id>
            <mirrorOf>central</mirrorOf>
            <name>Human Readable Name for this Mirror.</name>
            <url>http://repo2.maven.org/maven2/</url>
        </mirror>
        <mirror>
            <id>ibiblio</id>
            <mirrorOf>central</mirrorOf>
            <name>Human Readable Name for this Mirror.</name>
            <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
        </mirror>
        <mirror>
            <id>jboss-public-repository-group</id>
            <mirrorOf>central</mirrorOf>
            <name>JBoss Public Repository Group</name>
            <url>http://repository.jboss.org/nexus/content/groups/public</url>
        </mirror>
        <mirror>
            <id>google-maven-central</id>
            <name>Google Maven Central</name>
            <url>https://maven-central.storage.googleapis.com
            </url>
            <mirrorOf>central</mirrorOf>
        </mirror>
        <!-- 中央倉庫在中國的鏡像 -->
        <mirror>
            <id>maven.net.cn</id>
            <name>oneof the central mirrors in china</name>
            <url>http://maven.net.cn/content/groups/public/</url>
            <mirrorOf>central</mirrorOf>
        </mirror>
    </mirrors>
    
</settings>
復制代碼

 注意,如果MAVEN是安裝文件,settings.xml在“C:\Users\xxx\.m2\settings”也要重新修改一下,否則cmd下運行mvn使用的倉庫沒有修改。

 

三.IntellIJ IDEA 中配置Maven

Idea 自帶了apache maven,默認使用的是內置maven,所以我們可以配置全局setting,來調整一下配置,比如遠程倉庫地址,本地編譯環境變量等。

1.打開Settings,在輸入框輸入maven,如圖

 

 

2.如果本地設置了MAVEN_OPTS 系統環境變量,這個步驟可以忽略。

 

3.如果配置了本地apache-maven setting.xml 中的軟件源,這步驟可以忽略。

 

利用maven骨架建立一個webapp

  • 選擇create new project-Maven-Create from archetype。找到maven-archetype-webapp這個骨架,然后next。
  • 輸入GroupId和ArtifactId后下一步。
    填寫maven信息
  • 填寫本地的maven環境,這里可以選擇自己本地的環境,也可以用idea自帶的maven3.0.5。配置相應的配置文件,idea自帶的maven是沒有配置文件的,需要單獨配置的可以在相應的目錄中添加setting.xml文件,例如需要配置jdk版本或者maven mirror的。
    填寫本地的maven環境
    由於maven骨架和一些jar需要去maven的倉庫下載,所以創建項目的時候速度會非常慢(外國的服務器你懂得),因此我們可以直接訪問http://repo1.maven.org/maven2/archetype-catalog.xml,把這個xml下載下來放到本地的maven目錄中,然后在添加一個參數archetypeCatalog=internal就可以了。
  • next 填寫項目名稱,finish即可。

建立相應的目錄

項目創建完成后,src-main下建立java目錄后,是無法在該目錄下創建新的包和java類等文件的。在idea中需要對目錄進行標注。
這里寫圖片描述

  • Sources 一般用於標注類似 src 這種可編譯目錄。有時候我們不單單項目的 src 目錄要可編譯,還有其他一些特別的目錄也許我們也要作為可編譯的目錄,就需要對該目錄進行此標注。只有 Sources 這種可編譯目錄才可以新建 Java 類和包,這一點需要牢記。
  • Tests 一般用於標注可編譯的單元測試目錄。在規范的 maven 項目結構中,頂級目錄是 src,maven 的 src 我們是不會設置為 Sources 的,而是在其子目錄 main 目錄下的 java 目錄,我們會設置為 Sources。而單元測試的目錄是 src - test - java,這里的 java 目錄我們就會設置為 Tests,表示該目錄是作為可編譯的單元測試目錄。一般這個和后面幾個我們都是在 maven 項目下進行配置的,但是我這里還是會先說說。從這一點我們也可以看出 IntelliJ IDEA 對 maven 項目的支持是比較徹底的。
  • Resources 一般用於標注資源文件目錄。在 maven 項目下,資源目錄是單獨划分出來的,其目錄為:src - main -resources,這里的 resources 目錄我們就會設置為 Resources,表示該目錄是作為資源目錄。資源目錄下的文件是會被編譯到輸出目錄下的。
    Test Resources 一般用於標注單元測試的資源文件目錄。在 maven 項目下,單元測試的資源目錄是單獨划分出來的,其目錄為:src - test -resources,這里的 resources 目錄我們就會設置為 Test Resources,表示該目錄是作為單元測試的資源目錄。資源目錄下的文件是會被編譯到輸出目錄下的。
  • Excluded 一般用於標注排除目錄。被排除的目錄不會被 IntelliJ IDEA 創建索引,相當於被 IntelliJ IDEA 廢棄,該目錄下的代碼文件是不具備代碼檢查和智能提示等常規代碼功能。
  • 通過上面的介紹,我們知道對於非 maven 項目我們只要會設置 src 即可。
    (引用自http://wiki.jikexueyuan.com/project/intellij-idea-tutorial/eclipse-java-web-project-introduce.html)

標注完后,建立如下的目錄。
這里寫圖片描述

配置Maven和SpringMVC

配置Maven的pom.xml

完整的配置文件如下。

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.example</groupId> <artifactId>maven-springmvc</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>maven-springmvc Maven Webapp</name> <url>http://maven.apache.org</url> <!--項目依賴 --> <dependencies> <!--日志包--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.21</version> </dependency> <!--j2ee相關包 servlet、jsp、jstl--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!--mysql驅動包--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.35</version> </dependency> <!--spring相關包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.3.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.1.RELEASE</version> </dependency> <!--其他需要的包--> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.4</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> </dependencies> <build> <finalName>maven-springmvc</finalName> <resources> <!--表示把java目錄下的有關xml文件,properties文件編譯/打包的時候放在resource目錄下--> <resource> <directory>${basedir}/src/main/java</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> </includes> </resource> <resource> <directory>${basedir}/src/main/resources</directory> </resource> </resources> <plugins> <!--servlet容器 jetty插件--> <plugin> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-maven-plugin</artifactId> <version>9.3.10.v20160621</version> </plugin> </plugins> </build> </project>

更新完pom.xml文件后,idea應該會自動下載相應的jar包(可能需要vpn),如果沒有自動下載的話,可以點擊“Reimport All Maven Projects”按鈕進行項目的重新載入。如圖所示。
這里寫圖片描述
jar下載完成后,所有項目所需的依賴就已經添加完成了。

配置web.xml

maven默認生成的web.xml版本是2.3的,所以有些配置節點idea會識別不出來,因此我們重新添加一個3.0的。

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <!--welcome pages--> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <!--配置springmvc DispatcherServlet--> <servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <!--Sources標注的文件夾下需要新建一個spring文件夾--> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> <async-supported>true</async-supported> </servlet> <servlet-mapping> <servlet-name>springMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>

接收到的http請求通過DispatcherServlet進行分發。

配置contextConfigLocation文件

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!--啟用spring的一些annotation --> <context:annotation-config/> <!-- 自動掃描該包,使SpringMVC認為包下用了@controller注解的類是控制器 --> <context:component-scan base-package="com.zjut.ssm.controller"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan> <!--HandlerMapping 無需配置,springmvc可以默認啟動--> <!--靜態資源映射--> <!--本項目把靜態資源放在了WEB-INF的statics目錄下,資源映射如下--> <mvc:resources mapping="/css/**" location="/WEB-INF/statics/css/"/> <mvc:resources mapping="/js/**" location="/WEB-INF/statics/js/"/> <mvc:resources mapping="/image/**" location="/WEB-INF/statics/image/"/> <!--但是項目部署到linux下發現WEB-INF的靜態資源會出現無法解析的情況,但是本地tomcat訪問正常,因此建議還是直接把靜態資源放在webapp的statics下,映射配置如下--> <!--<mvc:resources mapping="/css/**" location="/statics/css/"/>--> <!--<mvc:resources mapping="/js/**" location="/statics/js/"/>--> <!--<mvc:resources mapping="/image/**" location="/statics/images/"/>--> <!-- 配置注解驅動 可以將request參數與綁定到controller參數上 --> <mvc:annotation-driven/> <!-- 對模型視圖名稱的解析,即在模型視圖名稱添加前后綴(如果最后一個還是表示文件夾,則最后的斜杠不要漏了) 使用JSP--> <!-- 默認的視圖解析器 在上邊的解析錯誤時使用 (默認使用html)- --> <bean id="defaultViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> <property name="prefix" value="/WEB-INF/views/"/><!--設置JSP文件的目錄位置--> <property name="suffix" value=".jsp"/> </bean> <!-- springmvc文件上傳需要配置的節點--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="20971500"/> <property name="defaultEncoding" value="UTF-8"/> <property name="resolveLazily" value="true"/> </bean> </beans>

配置log4j.properties

日志文件是debug中一個必不可少的工具,因此添加了log4j日志包。配置文件如下。

#配置根Logger 后面是若干個Appender log4j.rootLogger=DEBUG,A1,R #log4j.rootLogger=INFO,A1,R # ConsoleAppender 輸出 log4j.appender.A1=org.apache.log4j.ConsoleAppender log4j.appender.A1.layout=org.apache.log4j.PatternLayout log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n # File 輸出 一天一個文件,輸出路徑可以定制,一般在根路徑下 log4j.appender.R=org.apache.log4j.DailyRollingFileAppender log4j.appender.R.File=log.txt log4j.appender.R.MaxFileSize=500KB log4j.appender.R.MaxBackupIndex=10 log4j.appender.R.layout=org.apache.log4j.PatternLayout log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c] [%p] - %m%n

controller和view的編寫

在controller下新建一個“HomeController”。編寫如下代碼。

package com.zjut.ssm.controller; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; /** * @author Chingyu Mo * @create 2016-07-23-20:20 */ // 注解標注此類為springmvc的controller,url映射為"/home" @Controller @RequestMapping("/home") public class HomeController { //添加一個日志器 private static final Logger logger = LoggerFactory.getLogger(HomeController.class); //映射一個action @RequestMapping("/index") public String index(){ //輸出日志文件 logger.info("the first jsp pages"); //返回一個index.jsp這個視圖 return "index"; } }

在views文件夾下建立一個jsp文件,名為“index.jsp”

基本的代碼編寫就完成了。

servlet容器的配置和運行

servlet容器有兩種配置方式。

  • 配置本地的tomcat服務器
  • 配置maven插件

配置本地的tomcat服務器

這里寫圖片描述
根據上圖配置tomcat服務器,如果用這種方法,本地需要下載tomcat並配置好環境變量。
這里寫圖片描述
主要有以下幾個要點

  • 1.選擇本地的tomcat容器。
  • 2.可以選擇修改訪問路徑。
  • 3.On Update action 當我們按 Ctrl + F10 進行容器更新的時候,可以根據我們配置的這個事件內容進行容器更新。其中我選擇的 Update classes and resources 事件是最常用的,表示我們在按 Ctrl + F10 進行容器更新的時候,我們觸發更新編譯的類和資源文件到容器中。
  • 4.默認 Tomcat 的 HTTP 端口是 8080,如果你需要改其端口可以在這里設置。
  • 5.在 Deployment 選項卡中添加了 Artifact。

配置maven插件

maven插件的話有tomcat和jetty,兩者都是servlet的容器。我這里配置的是jetty。插件已經在pom.xml中配置完成了。

 <plugins> <!--servlet容器 jetty插件--> <plugin> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-maven-plugin</artifactId> <version>9.3.10.v20160621</version> </plugin> </plugins>

再在idea中配置jetty。
這里寫圖片描述

運行第一個Spring MVC應用

點擊Run,運行。

以上就是一個簡單的Spring MVC應用在idea中的創建方式。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM