Maven学习笔记-基础
文章目录
1.介绍
试想,如果现在有一种工具,可以把你从上面的繁琐工作中解放出来,能帮你构建工程,管理jar包,编译代码,还能帮你自动运行单元测试,打包,生成报表,甚至能帮你部署项目,生成Web站点,你会心动吗? Maven就可以解决上面所提到的这些问题。
- 依赖管理:maven工程对jar的管理过程
- 一键构建:指的是从编译,测试,运行,打包,安装,部署整个都交给maven管理,一个命令完成✅
安装包的内容
- bin目录:一些命令。如mvn.cmd,mvn主要用来构建项目
- boot目录:自身运行所需要的类加载器
- conf目录:其中settings.xml主要的配置文件
- lib目录:类库
命令行使用
- mvn -v 检查版本
jar包查找运行过程
- 本地仓库->远程仓库(私服)->中央仓库
设置本地仓库地址
<localRepository> C:\x\x </localRepository>
标准目录结构
src/main/java目录 核心代码部分
src/main/resources 配置文件部分
src/test/java目录 测试代码部分
src/test/resources 测试配置文件
src/main/webapp 页面资源,js,css,图片等
Maven常见命令
- mvn clean //将编译的项目进行清除,即清除target目录
- mvn compile //编译项目,src/main目录下的文件进行编译,放置在target目录中
- mvn test //编译测试代码和main中的代码
- mvn package //打包,先编译。打包成什么类型取决于pom.xml中war
- mvn install //打包,编译,安装到本地仓库
生命周期
maven 概念模型图
idea中使用
配置
-DarchetypeCatalog=internal //默认从本地找插件
新建项目
- quickstart是提供的java项目的骨架;webapp是web的骨架
- 新建的项目目录不齐
- 手动补齐
- 手动补齐
作用域scope
- compile
- test
- provided
- runtime
- system
简单的web项目
-
查找jar坐标
- 百度maven仓库,搜索需要的jar,选择版本,会自动产生坐标
-
写一个servlet
public class MyServlet extends javax.servlet.http.HttpServlet {
@Override
protected void doPost(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
}
@Override
protected void doGet(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws ServletException, IOException {
request.getRequestDispatcher("/hello.jsp").forward(request,response);
}
}
//配置web。xml
<servlet>
<servlet-name>MyServlet</servlet-name>
<servlet-class>servlet.MyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>MyServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
//添加jar包坐标
<dependency>
<groupId> javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
//调整tomcat版本(maven默认是6)
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration> //修改端口
<port>8888</port>
</configuration>
</plugin>
//jdk插件
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<target>1.8</target> //使用java1.8进行编译
<source>1.8</source>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
- 启动运行
选择m输入命令:tomcat7:run(tomcat:run启动的是默认版本的tomcat)
2 与mysql连用
- 新建一个空白的maven项目
- 修改pom文件
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
- 写java
//包domain
public class Items {
private Integer id;
private String name;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
//包dao
public interface ItemsDao {
public List<Items> findAll() ;
}
//包dao.impl
public class ItemsDaoImpl implements ItemsDao {
@Override
public List<Items> findAll() {
List<Items> list=new ArrayList<>();
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn= DriverManager.getConnection("jdbc:mysql://localhost/ssm?user=root&password=123");
PreparedStatement stmt=conn.prepareCall("select * from account");
ResultSet rs=stmt.executeQuery();
while(rs.next()){
Items items =new Items();
items.setId(rs.getInt("id"));
items.setName(rs.getString("name"));
list.add(items);
}
rs.close();
stmt.close();
conn.close();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}finally {
}
return list;
}
}
//test目录下
public class ItemsTest {
@Test
public void findAll(){
ItemsDao itemsDao =new ItemsDaoImpl();
List<Items> list=itemsDao.findAll();
for(Items s:list){
System.out.println(s.getName());
}
}
}
运行成功😄