1. IDEA 集成 Maven 19
1.1 在idea中设置maven ,让idea和maven结合使用。19
idea中内置了maven ,一般不使用内置的, 因为用内置修改maven的设置不方便。
使用自己安装的maven, 需要覆盖idea中的默认的设置。让idea指定maven安装位置等信息
1.2 配置的入口 19
①:配置当前工程的设置, file--settings ---Build, Excution,Deployment--Build Tools
--Maven
Maven Home directory: maven的安装目录
User Settings File : 就是maven安装目录conf/setting.xml配置文件
Local Repository : 本机仓库的目录位置
--Build Tools--Maven--Runner
VM Options : -DarchetypeCatalog=internal
JRE: 你项目的jdk
-DarchetypeCatalog=internal , maven项目创建时,会联网下载模版文件,比较大, 使用-DarchetypeCatalog=internal,不用下载, 创建maven项目速度快。
②:配置以后新建工程的设置, file--other settings--Settings for New Project 20
File---->Settings:设置 maven 安装主目录、maven 的 settings.xml 文件和本地仓库所在位置。
2. IDEA 创建 Maven 版 java 工程 21
2.1 maven-archetype-quickstart : 普通的java项目 21-22
代码在main 22
com.bjpowernode
HelloMaven
package com.bjpowernode;
//写一个简单的类 22
public class HelloMaven {
public int add(int n1,int n2){
return n1+n2;
}
public static void main(String[] args){
HelloMaven hello = new HelloMaven();
int res = hello.add(10,20);
System.out.println("10+20="+res);
}
}
test 23
com.bjpowernode
TestHelloMaven
package com.bjpowernode;
import org.junit.Assert;
import org.junit.Test;
//测试23
public class TestHelloMaven {
@Test
public void testAdd(){
System.out.println("=========testAdd测试add方法");
HelloMaven hello = new HelloMaven();
int res = hello.add(10,20);
//判断是否正确
Assert.assertEquals(30,res);
}
@Test
public void testAdd2(){
System.out.println("+++++++testAdd测试add方法");
HelloMaven hello = new HelloMaven();
int res = hello.add(10,20);
//判断是否正确
Assert.assertEquals(30,res);
}
}
3. maven-archetype-webapp : web工程 24
3.1 创建缺省文件夹 24
src-main-java / resources,src-test-java/resources
3.1.1 把文件夹标识为源码文件夹 24
File -> Project Structure,选择Modules:右边找到java这层机构,在上面有个“Mask as”,点下Sources,
表示这里面是源代码类
4. 代码演示 24
代码在main
com.bjpowernode.controller
HelloServlet
package com.bjpowernode.controller;
import jakarta.servlet.ServletException;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
//写一个简单的servlet 24
public class HelloServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text;html;charset=utf-8");
PrintWriter pw = response.getWriter();
pw.println("Hello Maven web");
pw.flush();
pw.close();
}
}
web.xml
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>HelloServlet</servlet-name>
<servlet-class>com.bjpowernode.controller.HelloServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloServlet</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>
</web-app>
tomcat10的依赖
<!-- 加入servlet依赖servlet的jar-->
<dependency>
<groupId>jakarta.servlet</groupId>
<artifactId>jakarta.servlet-api</artifactId>
<version>5.0.0</version>
<scope>provided</scope>
</dependency>
<!-- jsp的依赖jsp的jar包-->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
index.jsp
<%@ page contentType="text/html;charset=utf-8" language="java" %>
<html>
<body>
<h2>Hello World!</h2>
<a href="hello">访问HelloServlet</a>
</body>
</html>
5. 依赖范围 28
5.1 使用scope表示的
scope的值有 compile, test, provided , 默认是compile
scope:表示依赖使用的范围,也就是在maven构建项目的那些阶段中起作用。
maven构建项目 编译, 测试 ,打包, 安装 ,部署 过程(阶段)
5.1.1 junit的依赖范围是 test 28
test只在测试阶段才有效
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
5.1.2 compile 28
compile在编译, 测试 ,打包, 安装 ,部署 过程有效
<dependency>
<groupId>a</groupId>
<artifactId>b</artifactId> b.jar
<version>4.11</version>
<scope>compile</scope>
</dependency>
1.1.3 provided 28
provided在编译, 测试
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version> servlet.jar
<scope>provided</scope> 提供者
</dependency>
5.2 总结 28
依赖的范围
依赖的范围:compile、test、provided,默认采用 compile
你在写项目的中的用到的所有依赖(jar ) ,必须在本地仓库中有。
没有必须通过maven下载, 包括provided的都必须下载。
你在servlet需要继承HttpServlet( provided) , 你使用的HttpServlet是maven仓库中的。
当你的写好的程序, 放到 tomat服务器中运行时, 此时你的程序中不包含servlet的jar
因为tomcat提供了 servlet的.jar
6. maven常用操作 30
6.1 maven的属性设置 30
设置maven的常用属性
6.1.1 maven的全局变量 30
自定义的属性
1.在 通过自定义标签声明变量(标签名就是变量名)
2.在pom.xml文件中的其它位置,使用 ${标签名} 使用变量的值
自定义全局变量一般是定义 依赖的版本号, 当你的项目中要使用多个相同的版本号,先使用全局变量定义, 在使用${变量名}
6.2 资源插件 30-31
<build>
<resources>
<resource>
<directory>src/main/java</directory><!--所在的目录-->
<includes><!--包括目录下的.properties,.xml 文件都会扫描到-->
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<!--filtering 选项 false 不启用过滤器, *.property 已经起到过滤的作用了 -->
<filtering>false</filtering>
</resource>
</resources>
</build>
2.2.1 作用:30-31
1. 默认没有使用resources的时候, maven执行编译代码时, 会把src/main/resource目录中的文件拷贝到target/classes目录中。对于src/main/java目录下的文件不处理不会拷贝到target/classes目录中
2. 但是呢,我们的程序需要把一些文件放到src/main/java目录下,当我在执行java程序时,需要用到src/main/java目录下的文件,需要告诉maven在mvn compile src/main/java目录下的程序时,需要把文件一同拷贝到target/classes目录中,此时就需要在<build></build>种加入<resources>
标签:java,--,idea,maven,import,main,servlet,属性 From: https://blog.51cto.com/u_15784725/6365084