How to install Maven on Windows
Apache Maven is not require to install on Windows as a service component, you just need to download the Maven’s zip file, extract it and configure the Windows environment path variable. See following steps :
1. Add JAVA_HOME
2.Download Apache Maven
Download Apache Maven zip file from this official website, e.g apache-maven-2.2.1-bin.zip
3. Extract It
Extract the downloaded zip file, for instance, “
D:\maven“.4. Add MAVEN_HOME
5. Add PATH
Add the “Maven bin folder” into Windows environment variable, so that you can access Maven command everywhere
6. Verification
Done, to verify it, in command prompt, type “mvn –version” to verify the installation detail.
Maven Repsository location
Maven local repository is default to home directory :
- Unix/Mac OS X – ~/.m2 on
- Windows – C:\Documents and Settings\username\.m2 on Windows .
- 1. Maven configuration file
- Maven local repository is defined in the Maven’s configuration file, for example, {M2_HOME}\conf\setting.xml.Edit it “setting.xml”Find the following “localRepository” pattern, and define your new Maven local repository inside the “<localRepository>” element like this :<settings> <!-- localRepository | The path to the local repository maven will use to store artifacts. | | Default: ~/.m2/repository <localRepository>/path/to/local/repo</localRepository> --> <localRepository>D:/maven_repo</localRepository> Where is maven central repository ?While building a Maven’s project, Maven will check yourpom.xmlfile to download the entire project dependency libraries automatically.If Maven can’t find the defined dependency libraries in your Maven local repository, it will try to download it from the default Maven central repository, which is http://repo1.maven.org/maven2/.How to download from Maven remote repository?In Maven, when you need some libraries that are NOT EXITS the Maven center repository, the process will stopped and output error messages to your Maven console.To tell Maven to go to Maven remote repository like java.net, you need to declared a “remote repository” in your Maven’spom.xmlfile like this :<repositories> <repository> <id>java.net</id> <url>http://download.java.net/maven/2</url> </repository> </repositories> How to use Maven dependency to download library automaticallyInclude “Maven coordinates” into “pom.xml” file, under “<dependencies>” tag<dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.14</version> </dependency> </dependencies> order :
- Search log4j in Maven local repository.
- Search log4j in Maven central repository.
- Search log4j in Maven remote repository (if define in pom.xml)Searching maven coordinates
- Let say, you want to know the “logback” Maven’s coordinates , you can search it in Google with search text
- logback site:http://repo1.maven.org/maven2/ - How to include library manually into maven local repository?- There are still many Java libraries that are not support for Maven, or may be you want to create a custom library which is required to include it into your Maven local repository.- Fortunately, Maven comes with command to let you include your “non-maven-support” library into your Maven local repository easily.- For example, “kaptcha” is a third party library which is used to generate “captcha” image to stop spamming, but it did not support Maven.- 1. Install library – mvn install- mvn install:install-file -Dfile=c:\kaptcha-2.3.jar -DgroupId=com.google.code -DartifactId=kaptcha -Dversion=2.3 -Dpackaging=jar - 2. Modify pom.xml file- <dependency> <groupId>com.google.code</groupId> <artifactId>kaptcha</artifactId> <version>2.3</version> </dependency> - How to create a Java project with Maven- To create a Java project with Maven, you can issue this command :- mvn archetype:generate -DgroupId={packaging.path} -DartifactId={project-id} -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false - 1. mvn archetype:generate- ex:- 2. Java Project StructureMaven just generated so called “Maven Standard Directory Layout” for your new Java project, and the directory name is same as the given name in “artifactId”.In short, puts your source code in- src/main/java, resources file in- src/main/resources, unit test file in- src/test/java.- 3. pom.xmlSee the generated- pom.xmlfile, the tag “packaging” is “jar“, when build with Maven, this project will group it into a jar file.File : 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.mkyong.core</groupId> <artifactId>mkyong-core</artifactId> <packaging>jar</packaging> <version>1.0-SNAPSHOT</version> <name>mkyong-core</name> <url>http://maven.apache.org</url> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> </dependencies> </project> - How to convert Maven based Java Project to support Eclipse IDEIn last tutorial, you created a Java project with Maven, but that project is not able to import into Eclipse IDE, because it is not Eclipse style project.Here’s a guide to show you how to convert the Maven generated Java project to Eclipse supported style project.- 1. mvn eclipse:eclipse- mvn eclipse:eclipse - 2. Verify Java ProjectAfter that, you will notice two new files are created – “- .classpath” and “- .project“. Both files are created for Eclipse IDE.File : .classpath- <classpath> <classpathentry kind="src" path="src/test/java" output="target/test-classes" including="**/*.java"/> <classpathentry kind="src" path="src/main/java" including="**/*.java"/> <classpathentry kind="output" path="target/classes"/> <classpathentry kind="var" path="M2_REPO/junit/junit/3.8.1/junit-3.8.1.jar" sourcepath="M2_REPO/junit/junit/3.8.1/junit-3.8.1-sources.jar"/> <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/> </classpath> - File : .project - <projectDescription> <name>mkyong-core</name> <comment/> <projects/> <buildSpec> <buildCommand> <name>org.eclipse.jdt.core.javabuilder</name> </buildCommand> </buildSpec> <natures> <nature>org.eclipse.jdt.core.javanature</nature> </natures> </projectDescription> - 3. Import into Eclipse IDENow, import it into Eclipse IDE, follow below steps :In Eclipse IDE, menu bar , File -> Import… -> General -> Existing Projects into Workspace -> select root directory (select your project folder) -> Done.- How to create a Web Application Project with MavenIn last tutorial, you created a Java Project with Maven. But that project is not a web application project, to create a web project with Maven, issue this command :- 1. mvn archetype:generate- Navigate to the folder you want to generate your web project, e.g “- D:\workspace-new\“. In console, issue this command (inside the eclipse workspace)- mvn archetype:generate -DgroupId=com.sudheer.core -DartifactId=sudheerweb-core -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false - 2. Web Application Project StructureA new super clean “- web.xml” file is created under “D:\workspace-new\sudheerweb-core\src\main\webapp\WEB-INF” folder.File : web.xml- 3. pom.xmlRefer to the generated- pom.xmlfile, the tag “packaging” is “war“, when build with Maven, this project will group it into a war file for deployment.File : 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.mkyong.core</groupId> <artifactId>mkyongweb-core</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>mkyongweb-core 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> </dependencies> <build> <finalName>mkyongweb-core</finalName> </build> </project> - How to convert Maven based web application to support Eclipse IDE- 1. mvn eclipse:eclipse -Dwtpversion=2.0To convert a Maven based Java project to support IDE, you use this command :For web application, you need extra parameter to make it support Eclipse’s wtp, instead, you should use this command :- mvn eclipse:eclipse -Dwtpversion=2.0 - 2. Eclipse WTPStandard Eclipse’s “- .classpath” and “- .project” files are created. And you will noticed a new “.setting” folder is created and inside contains “- org.eclipse.wst.common.component” and “- org.eclipse.wst.common.project.facet.core.xml“, both files for WTP or Faces support in Eclipse.File : org.eclipse.wst.common.project.facet.core.xmlNote
 Maven 2.x generated web application with JDK1.4 (see above), which is rather outdated, you may need to upgrade it to latest JDK version.File : org.eclipse.wst.common.component- 3. Import into Eclipse IDENow, you have everything what a Eclipse web application want, so, you can start import your Maven based web application into Eclipse IDE.Steps :
 In Eclipse IDE, menu bar , File -> Import… -> General -> Existing Projects into Workspace -> select root directory (select your project folder) -> Done.- How to create a project with Maven template- 1. Maven – mvn archetype:generateNavigate to folder that you want Maven to generate the project, e.g “- E:\workspace\test“, and issue this command “mvn archetype:generate”. Maven will list out exiting 40+ Maven template projects for you to choose.- How to deploy Maven based war file to Tomcat- 1. Tomcat AuthenticationFirst, add an user with administrator access right for Tomcat. To add Tomcat user, edit this file – “- %TOMCAT_PATH%/conf/tomcat-users.xml“.File : tomcat-users.xml- 2. Maven AuthenticationIn Maven side, you need to add the same user authentication information in “- %MAVEN_PATH%/conf/settings.xml“.File : settings.xml- 3. Maven-Tomcat-PluginDeclare “Maven-Tomcat plugin” and related Tomcat server detail in your- pom.xmlfile.See a full pom.xml file.- 4. Deploy to TomcatIssue “- mvn tomcat:deploy” to package your project in a WAR file, and deploy it to Tomcat server. To verify it, just access to the Tomcat’s manager page and make sure “/mkyongWebApp” path is existed.
 
