Maven-高级

文章目录

回顾Maven初级

maven是一个项目管理工具。
依赖管理:maven对项目中jar包的管理过程。传统工程我们直接把jar包放置在项目中。
          maven工程真正的jar包放置在仓库中,项目中只用放置jar包的坐标。
仓库的种类:本地仓库,远程仓库【私服】,中央仓库。
仓库之间的关系:当我们启动一个maven工程的时候,maven工程会通过pom文件中jar包的坐标去本地仓库找对应jar包。
                默认情况下,如果本地仓库没有对应jar包,maven工程会自动去中央仓库下载jar包到本地仓库。
		在公司中,如果本地没有对应jar包,会先从私服下载jar包,
		如果私服没有jar包,可以从中央仓库下载,也可以从本地上传。
一键构建:maven自身集成了tomcat插件,可以对项目进行编译,测试,打包,安装,发布等操作。
maven常用命令:clean,compile,test,package,install,deploy。
maven三套生命周期:清理生命周期,默认生命周期,站点生命周期。

1.Maven 的好处

节省磁盘空间
可以一键构建
可以跨平台
应用在大型项目时可以提高开发效率

2.安装配置 maven

注意:3.3+版本需要 jdkj.7+以上的支持

3.三种仓库

本地仓库
远程仓库(私服)
中央仓库

4.常见的命令

Compile
Test
Package
Install
Deploy
Clean

5.坐标的书写规范

groupId 公司或组织域名的倒序
artifactId 项目名或模块名
version 版本号

6.如何添加坐标

在本地仓库中搜索
互联网上搜,推荐网址 http://www.mvnrepository.com/

7.依赖范围

Compile
Provided
Runtime
Test

在 maven-project工程中测试各各 scop
默认引入 的 jar 包 ------- compile 【默认范围 可以不写】(编译、测试、运行 都有效 )
servlet-api 、jsp-api ------- provided (编译、测试 有效, 运行时无效 防止和 tomcat 下 jar 冲突)
jdbc 驱动 jar 包 ------- runtime (测试、运行 有效 )
junit ------- test (测试有效)

依赖范围由强到弱的顺序是:compile>provided>runtime>test

Maven导入jar包解决jar包冲突

在构建SSM工程之我觉得需要把导入jar包是冲突解决这个问题要说一下,因为这个问题不解决,在实际开发中会有很多的问题。

1.jar包冲突演示图解

在这里插入图片描述

2.jar包冲突的解决方式

maven工程要导入jar包的坐标,就必须要考虑解决jar包冲突。

maven导入jar包中的一些概念:
     直接依赖:项目中直接导入的jar包,就是该项目的直接依赖包。
     传递依赖:项目中没有直接导入的jar包,可以通过项目直接依赖jar包传递到项目中去。

1.解决jar包冲突的方式一

第一声明优先原则:哪个jar包的坐标在靠上的位置,这个jar包就是先声明的,先声明的jar包坐标下的依赖包,可以优先进入项目中。

spring-context比spring-beans先声明图解
在这里插入图片描述

spring-beans比spring-context先声明图解
在这里插入图片描述

2.解决jar包冲突的方式二

路径近者优先原则:直接依赖路径比传递依赖路径近,那么最终项目进入的jar包会是路径近的直接依赖包。
路径近者优先原则图解
在这里插入图片描述

3.解决jar包冲突的方式三【推荐使用】

直接排除法:当我们要排除某个jar包下依赖包,在配置exclusions标签的时候,内部可以不写版本号,因为此时依赖包使用的版本和默认和本jar包一样。
直接排除法图解
在这里插入图片描述

pom文件中有关jar包标签介绍

写到jar包标签,我觉得下面几个标签需要说下,其他标签没什么好说的。
<dependency>: 这个标签用于管理jar包版本。
<dependencyManagement>:该标签用于锁定jar的版本,这个需要详细说明。
<properties>:这个标签是最常用的,就是j写ar包的所在坐标。

1.dependency和properties标签管理jar包

<!-- 统一管理jar包版本 -->
<properties>
    <spring.version>5.0.2.RELEASE</spring.version>
</properties>
<!--项目依赖jar-->
<dependencies>
    <!--导入springjar包坐标-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aop</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>
</dependencies>

2.dependency和dependencyManagement以及properties标签管理jar包

dependencyManagement标签适用场景
maven工程是可以分父子依赖关系的。
凡是依赖别的项目后,拿到的别的项目的依赖包,都属于传递依赖,比如:当前A项目,被B项目依赖。那么我们A项目中所有jar包都会传递到B项目中。B项目开发者,如果再在B项目中导入一套ssm框架的jar包,对于B项目是直接依赖。那么直接依赖的jar包就会把我们A项目传递过去的jar包覆盖掉。
为了防止以上情况的出现。我们可以把A项目中主要jar包的坐标锁住,即便是有同名jar包直接依赖,也无法覆盖。
在这里插入图片描述
锁定jar包版本

<!--统一管理jar包版本 -->
<properties>
    <spring.version>5.0.2.RELEASE</spring.version>
</properties>

<!--锁定jar包版本-->
<dependencyManagement>
<dependencies>
	<dependency>
		<groupId>org.springframework</groupId>
		<artifactId>spring-aop</artifactId>
		<version>${spring.version}</version>
		</dependency>
		<dependency>
		    <groupId>org.springframework</groupId>
		    <artifactId>spring-context</artifactId>
		    <version>${spring.version}</version>
		</dependency>
		<dependency>
		    <groupId>org.springframework</groupId>
		    <artifactId>spring-web</artifactId>
		    <version>${spring.version}</version>
		</dependency>
	</dependencies>
</dependencyManagement>

<!--项目依赖jar-->
<dependencies>
   <!--导入springjar包坐标-->
   <dependency>
       <groupId>org.aspectj</groupId>
       <artifactId>aspectjweaver</artifactId>
       <version>1.6.8</version>
   </dependency>
   <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-aop</artifactId>
       <!--锁定jar包版本号后,这里可以省略不写-->
       <!--<version>${spring.version}</version>-->
   </dependency>
   <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-context</artifactId>
       <!--锁定jar包版本号后,这里可以省略不写-->
       <version>${spring.version}</version>
   </dependency>
   <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-web</artifactId>
       <!--锁定jar包版本号后,这里可以省略不写-->
       <version>${spring.version}</version>
   </dependency>
</dependencies>

Maven构建 SSM 工程

1.需求

实现 SSM 工程构建,规范依赖管理。场景:根据 id 展示商品信。

2.准备数据库

CREATE TABLE `items` (
  `id` INT(10) NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(20) DEFAULT NULL,
  `price` FLOAT(10,0) DEFAULT NULL,
  `pic` VARCHAR(40) DEFAULT NULL,
  `createtime` DATETIME DEFAULT NULL,
  `detail` VARCHAR(200) DEFAULT NULL,
  PRIMARY KEY  (`id`)
) ENGINE=INNODB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8;

在这里插入图片描述

3.创建一个maven工程

在这里插入图片描述
在这里插入图片描述

4.导入依赖

<!-- 统一管理jar包版本 -->
<properties>
    <spring.version>5.0.2.RELEASE</spring.version>
    <slf4j.version>1.6.6</slf4j.version>
    <log4j.version>1.2.12</log4j.version>
    <shiro.version>1.2.3</shiro.version>
    <mysql.version>5.1.6</mysql.version>
    <mybatis.version>3.4.5</mybatis.version>
    <spring.security.version>5.0.1.RELEASE</spring.security.version>
</properties>

<!-- 锁定jar包版本 -->
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>${mybatis.version}</version>
        </dependency>
    </dependencies>
</dependencyManagement>

<!-- 项目依赖jar包 -->
<dependencies>
    <!-- spring -->
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.6.8</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aop</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>${mysql.version}</version>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <version>2.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>jstl</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
    </dependency>
    <!-- log start -->
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>${log4j.version}</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>${slf4j.version}</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>${slf4j.version}</version>
    </dependency>
    <!-- log end -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>${mybatis.version}</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.3.0</version>
    </dependency>
    <dependency>
        <groupId>c3p0</groupId>
        <artifactId>c3p0</artifactId>
        <version>0.9.1.2</version>
        <type>jar</type>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>com.github.pagehelper</groupId>
        <artifactId>pagehelper</artifactId>
        <version>5.1.2</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-web</artifactId>
        <version>${spring.security.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-config</artifactId>
        <version>${spring.security.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-core</artifactId>
        <version>${spring.security.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-taglibs</artifactId>
        <version>${spring.security.version}</version>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>1.0.9</version>
    </dependency>
</dependencies>
<!-- 添加tomcat7插件 -->
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.tomcat.maven</groupId>
            <artifactId>tomcat7-maven-plugin</artifactId>
            <version>2.2</version>
        </plugin>
    </plugins>
</build>

5.dao层代码编写

1.实体类

/**
 * 商品项实体类
 */
public class Items {
    private Integer id;
    private String name;
    private Integer price;
    private Integer pic;
    private Date createtime;
    private String detail;
    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;
    }
    public Integer getPrice() {
        return price;
    }
    public void setPrice(Integer price) {
        this.price = price;
    }
    public Integer getPic() {
        return pic;
    }
    public void setPic(Integer pic) {
        this.pic = pic;
    }
    public Date getCreatetime() {
        return createtime;
    }
    public void setCreatetime(Date createtime) {
        this.createtime = createtime;
    }
    public String getDetail() {
        return detail;
    }
    public void setDetail(String detail) {
        this.detail = detail;
    }
    @Override
    public String toString() {
        return "Items{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", price=" + price +
                ", pic=" + pic +
                ", createtime=" + createtime +
                ", detail='" + detail + '\'' +
                '}';
    }
}

2.编写接口

/**
 * 操作商品项dao接口
 */
public interface ItemsDao {
    /**
     *  根据id查询
      * @param id
     * @return
     */
  Items findItemsById(Integer id);
}

3.编写配置文件

1.编写映射文件
<mapper namespace="com.ginger.dao.ItemsDao">
    <select id="findItemsById" parameterType="int" resultType="items">
        select * from items where id= #{id}
    </select>
</mapper>
2.在applicationContext.xml配置文件添加dao层配置
<!--dao层配置文件开始-->
<!--配置连接池-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
    <property name="url" value="jdbc:mysql:///maven"></property>
    <property name="username" value="root"></property>
    <property name="password" value="root"></property>
</bean>

<!--配置生产SqlSession对象的工厂-->
<bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!--注入连接池-->
    <property name="dataSource" ref="dataSource"></property>
    <!--配置实体类别名-->
    <property name="typeAliasesPackage" value="com.ginger.pojo"></property>
</bean>

<!--扫描接口包路径,生成包下所有接口的代理对象,并且放入spring容器中-->
<bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.ginger.dao"></property>
</bean>
<!--dao层配置文件结束-->

4.dao测试

/**
 * 测试dao
 */
@Test
public void test(){
    //创建Spring容器
    ClassPathXmlApplicationContext cpxac = new ClassPathXmlApplicationContext("applicationContext.xml");
    //dao测试
    ItemsDao id = cpxac.getBean(ItemsDao.class);
    Items items = id.findItemsById(1);
    System.out.println(items);
}

执行结果:

Items{id=1, name='至高之拳', price=69, pic=null, createtime=Tue Mar 13 09:29:30 CST 2018, detail='我用双手成就你的梦想'}

6.service层代码编写

1.编写接口和实现类

ItemsService接口

/**
 * 操作商品项service接口
 */
public interface ItemsService {
    Items findItemsById(Integer id);
    void saveItems(Items items);
}

ItemsServiceImpl实现类

@Service
public class ItemsServiceImpl implements ItemsService{

    @Autowired
    private ItemsDao itemsDao;

    /**
     * 根据id查询商品项
     * @param id
     * @return
     */
    public Items findItemsById(Integer id) {
        Items items = itemsDao.findItemsById(id);
        return items;
    }

    /**
     * 插入商品项
     * @param items
     */
    public void saveItems(Items items) {
        itemsDao.saveItems(items);
    }
}

2.编写配置文件

1.编写映射文件
<mapper namespace="com.ginger.dao.ItemsDao">
    <select id="findItemsById" parameterType="int" resultType="items">
        select * from items where id= #{id}
    </select>

    <insert id="saveItems" parameterType="items">
        insert into items(name,price,pic,createtime,detail) values(#{name},#{price},#{pic},#{createtime},#{detail})
    </insert>
</mapper>
2.在applicationContext.xml配置文件添加service层配置
<!--service层配置文件开始-->
<!--扫描service层注解-->
<context:component-scan base-package="com.ginger.service"></context:component-scan>
<!--配置service层事务-->
<!--配置事务管理器-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"></property>
</bean>

<!--配置事务通知-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
    <tx:attributes>
        <tx:method name="save*" propagation="REQUIRED" read-only="false"/>
        <tx:method name="delete*" propagation="REQUIRED" read-only="false"/>
        <tx:method name="update*" propagation="REQUIRED" read-only="false"/>
        <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
        <tx:method name="*" propagation="REQUIRED" read-only="false"/>
    </tx:attributes>
</tx:advice>

<!--配置aop事务-->
<aop:config>
    <!--配置切入点-->
    <aop:pointcut id="pointcut" expression="execution(* com.ginger.service.impl.*.*(..))"></aop:pointcut>
    <!--配置切面 切入点+通知-->
    <aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut"></aop:advisor>
</aop:config>
<!--service层配置文件结束-->

3.service测试

/**
 * 测试service
 */
@Test
public void test2(){
   //创建Spring容器
   ClassPathXmlApplicationContext cpxac = new ClassPathXmlApplicationContext("applicationContext.xml");
   ItemsService is = cpxac.getBean(ItemsService.class);
   //测试根据id查询商品项
   Items items = is.findItemsById(2);
   System.out.println(items);

   //测试插入项目项目,看事务是否配置成功。
   Items items2 = new Items();
   items2.setName("吕布奉贤");
   items2.setPrice(99);
   items2.setPic(null);
   items2.setCreatetime(new Date());
   items2.setDetail("给我找些更抢的敌人");
   ItemsService is2 = cpxac.getBean(ItemsService.class);
   is2.saveItems(items2);
}

执行结果:

Items{id=1, name='至高之拳', price=69, pic=null, createtime=Tue Mar 13 09:29:30 CST 2018, detail='我用双手成就你的梦想'}

在这里插入图片描述

7.web层代码编写

1.编写控制器类

@Controller
@RequestMapping("/items")
public class ItemsController {
    @Autowired
    private ItemsService itemsService;

    @RequestMapping("/findAll")
    public String findAll(Model model){
        Items item = itemsService.findItemsById(1);
        model.addAttribute("item",item);
        return "itemDetail";
    }
}

2.编写配置文件

1.配置web.xml文件
<!--配置解决POST乱码过滤器-->
<filter>
    <filter-name>encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <!--设置编码-->
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <!--使用该编码-->
    <init-param>
        <param-name>forceEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

<!--配置spring的核心监听器-->
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
    <!--重新指定spring配置文件的路径-->
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
</context-param>

<!--springmvc的核心servlet-->
<servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:springmvc.xml</param-value>
    </init-param>
    <!--服务器启动时就创建-->
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
2.配置springmvc.xml文件
<!--web层配置文件开启-->
<!--扫描web层注解-->
<context:component-scan base-package="com.ginger.controller"></context:component-scan>

<!--配置事务解析器-->
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!--配置前缀-->
    <property name="prefix" value="/WEB-INF/pages/"></property>
    <!--配置后缀-->
    <property name="suffix" value=".jsp"></property>
</bean>

<!--配置SpringMVC 映射器 适配器-->
<mvc:annotation-driven/>

<!--释放静态资源-->
<!--下面这个注解的意思是,如果是静态资源交给默认的HttpServlet来处理,而不是SpringMVC的DispatcherServlet。
    因为DispatcherServlet会把静态资源拦截调。-->
<mvc:default-servlet-handler/>
<!--以前的配置方式-->
<!--<mvc:resources location="/css/" mapping="/css/**"></mvc:resources>-->
<!--web层配置文件结束-->
3.配置log4j.properties文件
# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE            debug   info   warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE

# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE

# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

3.编写jsp测试web

index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <a href="items/findAll">根据id查询商品项</a>
</body>
</html>

itemDetail.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
		 pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt"  prefix="fmt"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	<title>Insert title here</title>
</head>
<body>
<form>
	<table width="100%" border=1>
		<tr>
			<td>商品名称</td>
			<td> ${item.name } </td>
		</tr>
		<tr>
			<td>商品价格</td>
			<td> ${item.price } </td>
		</tr>
		<tr>
			<td>生成日期</td>
			<td> <fmt:formatDate value="${item.createtime}" pattern="yyyy-MM-dd HH:mm:ss"/> </td>
		</tr>
		<tr>
			<td>商品简介</td>
			<td>${item.detail} </td>
		</tr>
	</table>
</form>
</body>
</html>

执行结果:
在这里插入图片描述

Maven工程拆分与聚合

1.maven工程拆分与聚合的思想图解

在这里插入图片描述

2.工程和模块的关系以及继承和依赖的概念

在这里插入图片描述

3.传递依赖下来的包是否可用图解(了解)

在这里插入图片描述

4.maven父子工程的创建

这是一个父工程,使用IDEA创建Project或者Model其实一样的,我自己使用的是Project来创建该工程。这个没什么好纠结的。
在这里插入图片描述

1.maven_dao模块创建

因为不是 web层所以不用使用骨架,直接创建一个maven_dao子模块即可。
在这里插入图片描述

1.实体类
/**
 * 商品项实体类
 */
public class Items {
    private Integer id;
    private String name;
    private Integer price;
    private Integer pic;
    private Date createtime;
    private String detail;

    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;
    }
    public Integer getPrice() {
        return price;
    }
    public void setPrice(Integer price) {
        this.price = price;
    }
    public Integer getPic() {
        return pic;
    }
    public void setPic(Integer pic) {
        this.pic = pic;
    }
    public Date getCreatetime() {
        return createtime;
    }
    public void setCreatetime(Date createtime) {
        this.createtime = createtime;
    }
    public String getDetail() {
        return detail;
    }
    public void setDetail(String detail) {
        this.detail = detail;
    }
    @Override
    public String toString() {
        return "Items{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", price=" + price +
                ", pic=" + pic +
                ", createtime=" + createtime +
                ", detail='" + detail + '\'' +
                '}';
    }
}
2.编写接口
/**
 * 操作商品项接口
 */
public interface ItemsDao {
    /**
     * 根据id查询
     *
     * @param id
     * @return
     */
    Items findItemsById(Integer id);

    /**
     * 插入商品项
     *
     * @param items
     */
    void saveItems(Items items);
}
3.编写配置文件
1.编写ItemsDao.xml映射文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ginger.dao.ItemsDao">
    <select id="findItemsById" parameterType="int" resultType="items">
        select * from items where id= #{id}
    </select>

    <insert id="saveItems" parameterType="items">
        insert into items(name,price,pic,createtime,detail) values(#{name},#{price},#{pic},#{createtime},#{detail})
    </insert>
</mapper>
2.编写applicationContext-dao.xml配置文件
<?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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
			    http://www.springframework.org/schema/beans/spring-beans.xsd
			    http://www.springframework.org/schema/context
			    http://www.springframework.org/schema/context/spring-context.xsd
			    http://www.springframework.org/schema/aop
			    http://www.springframework.org/schema/aop/spring-aop.xsd
			    http://www.springframework.org/schema/tx
			    http://www.springframework.org/schema/tx/spring-tx.xsd
			    http://www.springframework.org/schema/mvc
			    http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--dao层配置文件开始-->
    <!--配置连接池-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
        <property name="url" value="jdbc:mysql:///maven"></property>
        <property name="username" value="root"></property>
        <property name="password" value="root"></property>
    </bean>
    <!--配置生产SqlSession对象的工厂-->
    <bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!--注入连接池-->
        <property name="dataSource" ref="dataSource"></property>
        <!--配置实体类别名-->
        <property name="typeAliasesPackage" value="com.ginger.pojo"></property>
    </bean>
    <!--扫描接口包路径,生成包下所有接口的代理对象,并且放入spring容器中-->
    <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.ginger.dao"></property>
    </bean>
    <!--dao层配置文件结束-->
</beans>

2.maven_service模块创建

因为不是 web层所以不用使用骨架,直接创建一个maven_service子模块即可。
在这里插入图片描述

1.编写接口和实体类

ItemsService接口

/**
 * 操作商品项service接口
 */
public interface ItemsService {
    Items findItemsById(Integer id);
    void saveItems(Items items);
}

ItemsServiceImpl实体类

@Service
public class ItemsServiceImpl implements ItemsService {
    @Autowired
    private ItemsDao itemsDao;
    /**
     * 根据id查询商品项
     *
     * @param id
     * @return
     */
    public Items findItemsById(Integer id) {
        Items items = itemsDao.findItemsById(id);
        return items;
    }
    /**
     * 插入商品项
     *
     * @param items
     */
    public void saveItems(Items items) {
        itemsDao.saveItems(items);
    }
}
2.编写applicationContext-service.xml配置文件
<?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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
			    http://www.springframework.org/schema/beans/spring-beans.xsd
			    http://www.springframework.org/schema/context
			    http://www.springframework.org/schema/context/spring-context.xsd
			    http://www.springframework.org/schema/aop
			    http://www.springframework.org/schema/aop/spring-aop.xsd
			    http://www.springframework.org/schema/tx
			    http://www.springframework.org/schema/tx/spring-tx.xsd
			    http://www.springframework.org/schema/mvc
			    http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--service层配置文件开始-->
    <!--扫描service层注解-->
    <context:component-scan base-package="com.ginger.service"></context:component-scan>
    <!--配置service层事务-->
    <!--配置事务管理器-->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>

    <!--配置事务通知-->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="save*" propagation="REQUIRED" read-only="false"/>
            <tx:method name="delete*" propagation="REQUIRED" read-only="false"/>
            <tx:method name="update*" propagation="REQUIRED" read-only="false"/>
            <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
            <tx:method name="*" propagation="REQUIRED" read-only="false"/>
        </tx:attributes>
    </tx:advice>

    <!--配置aop事务-->
    <aop:config>
        <!--配置切入点-->
        <aop:pointcut id="pointcut" expression="execution(* com.ginger.service.impl.*.*(..))"></aop:pointcut>
        <!--配置切面 切入点+通知-->
        <aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut"></aop:advisor>
    </aop:config>
    <!--service层配置文件结束-->
</beans>

3.maven_web模块创建

web层要使用骨架,直接创建一个maven_web子模块。
在这里插入图片描述

1.编写控制器类

ItemsController 控制器类

@Controller
@RequestMapping("/items")
public class ItemsController {
    @Autowired
    private ItemsService itemsService;
    @RequestMapping("/findAll")
    public String findAll(Model model){
        Items item = itemsService.findItemsById(1);
        model.addAttribute("item",item);
        return "itemDetail";
    }
}
2.编写配置文件
1.配置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 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">
  <!--配置解决POST乱码过滤器-->
  <filter>
    <filter-name>encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <!--设置编码-->
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <!--使用该编码-->
    <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

  <!--配置spring的核心监听器-->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <context-param>
    <!--重新指定spring配置文件的路径-->
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>

  <!--springmvc的核心servlet-->
  <servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:springmvc.xml</param-value>
    </init-param>
    <!--服务器启动时就创建-->
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>
</web-app>
2.配置springmvc.xml文件
<?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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
			    http://www.springframework.org/schema/beans/spring-beans.xsd
			    http://www.springframework.org/schema/context
			    http://www.springframework.org/schema/context/spring-context.xsd
			    http://www.springframework.org/schema/aop
			    http://www.springframework.org/schema/aop/spring-aop.xsd
			    http://www.springframework.org/schema/tx
			    http://www.springframework.org/schema/tx/spring-tx.xsd
			    http://www.springframework.org/schema/mvc
			    http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--web层配置文件开启-->
    <!--扫描web层注解-->
    <context:component-scan base-package="com.ginger.controller"></context:component-scan>

    <!--配置事务解析器-->
    <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <!--配置前缀-->
        <property name="prefix" value="/WEB-INF/pages/"></property>
        <!--配置后缀-->
        <property name="suffix" value=".jsp"></property>
    </bean>

    <!--配置SpringMVC 映射器 适配器-->
    <mvc:annotation-driven/>

    <!--释放静态资源-->
    <!--下面这个注解的意思是,如果是静态资源交给默认的HttpServlet来处理,而不是SpringMVC的DispatcherServlet。
        因为DispatcherServlet会把静态资源拦截调。-->
    <mvc:default-servlet-handler/>
    <!--以前的配置方式-->
    <!--<mvc:resources location="/css/" mapping="/css/**"></mvc:resources>-->
    <!--web层配置文件结束-->
</beans>
3.配置applicationContext-web.xml文件
<?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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
			    http://www.springframework.org/schema/beans/spring-beans.xsd
			    http://www.springframework.org/schema/context
			    http://www.springframework.org/schema/context/spring-context.xsd
			    http://www.springframework.org/schema/aop
			    http://www.springframework.org/schema/aop/spring-aop.xsd
			    http://www.springframework.org/schema/tx
			    http://www.springframework.org/schema/tx/spring-tx.xsd
			    http://www.springframework.org/schema/mvc
			    http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <import resource="classpath:spring/applicationContext-service.xml"></import>
    <import resource="classpath:spring/applicationContext-dao.xml"></import>
</beans>
4.配置log4j.properties文件
# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE            debug   info   warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE

# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE

# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n
3.编写jsp测试

index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<a href="items/findAll">根据id查询商品项</a>
</body>
</html>

itemDetail.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
		 pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt"  prefix="fmt"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	<title>Insert title here</title>
</head>
<body>
<form>
	<table width="100%" border=1>
		<tr>
			<td>商品名称</td>
			<td> ${item.name } </td>
		</tr>
		<tr>
			<td>商品价格</td>
			<td> ${item.price } </td>
		</tr>
		<tr>
			<td>生成日期</td>
			<td> <fmt:formatDate value="${item.createtime}" pattern="yyyy-MM-dd HH:mm:ss"/> </td>
		</tr>
		<tr>
			<td>商品简介</td>
			<td>${item.detail} </td>
		</tr>
	</table>
</form>
</body>
</html>

执行结果:
在这里插入图片描述

4.maven父子工程三种启动方式

1.直接启动父工程

在这里插入图片描述
启动成功:
在这里插入图片描述

2.启动maven-web模块

直接启动maven-web工程会报错,因为在maven-web依赖maven-service的jar,启动时会去本地仓库中去找jar,但是就没有,所以就报错了。要想不报错就要maven-service打成jar安装到本地仓库,maven-dao同理。

那为什么直接启动父工程不报错呢?其实可以看到在父工程中pom文件中,根本没有三个子模块的jar包坐标,也就不会去本地仓库中找所以就不报错了,可以直接启动成功。
在这里插入图片描述
将子模块安装到本地仓库,一个一个安装那样太慢了,可以直接安装maven_parent,就可以直接把子模块也安装到本地仓库中。
在这里插入图片描述
启动maven-web模块
在这里插入图片描述
启动结果:
在这里插入图片描述

3.使用本地服务器启动

配置服务器
在这里插入图片描述

启动服务器在启动服务器之前,会出现一些错误,应该要把缓存全部清除,在启动就没有问题了。
启动结果:
在这里插入图片描述

Maven私服

1.Maven私服安装和启动

1.需求

正式开发,不同的项目组开发不同的工程,ssm_dao 工程开发完毕,发布到私服,ssm_service 从私服下载 dao。

2.分析

公司在自己的局域网内搭建自己的远程仓库服务器,称为私服,私服服务器即是公司内部的 maven 远程仓库,每个员工的电脑上安装 maven 软件并且连接私服服务器,员工将自己开发的项目打成 jar 并发布到私服服务器,其它项目组从私服服务器下载所依赖的构(jar)。

私服还充当一个代理服务器,当私服上没有 jar 包会从互联网中央仓库自动下载,如下图:
在这里插入图片描述

3.搭建私服环境

1.下载 nexus

Nexus 是 Maven 仓库管理器,通过 nexus 可以搭建 maven 仓库,同时 nexus 还提供强大的仓库管理功能,构件搜索功能等。
下载 Nexus, 下载地址:http://www.sonatype.org/nexus/archived/

2.安装 nexus

解压 nexus-2.12.0-01-bundle.zip,它解压在桌面,进入 bin 目录:
在这里插入图片描述
cmd 进入 bin 目录,执行 nexus.bat install:
在这里插入图片描述
安装成功在服务中查看有 nexus 服务:
在这里插入图片描述

3.卸载 nexus

cmd 进入 nexus 的 bin 目录,执行:nexus.bat uninstall:
在这里插入图片描述
查看 window 服务列表 nexus 已被删除。

4.启动 nexus

方法 1:cmd 进入 bin 目录,执行 nexus.bat start
方法 2:直接启动 nexus 服务
在这里插入图片描述
查看 nexus 的主配置文件 conf/nexus.properties
在这里插入图片描述

# Jetty section
application-port=8081 # nexus 的访问端口配置
application-host=0.0.0.0 # nexus 主机监听配置(不用修改)
nexus-webapp=${bundleBasedir}/nexus # nexus 工程目录
nexus-webapp-context-path=/nexus # nexus 的 web 访问路径
# Nexus section
nexus-work=${bundleBasedir}/../sonatype-work/nexus # nexus 仓库目录
runtime=${bundleBasedir}/nexus/WEB-INF # nexus 运行程序目录

访问:http://localhost:8081/nexus/
在这里插入图片描述
使用 Nexus 内置账户 admin/admin123 登陆:点击右上角的 Log in,输入账号和密码 登陆。
在这里插入图片描述
登陆成功:
在这里插入图片描述

5.nexus仓库类型

查看 nexus 的仓库:
在这里插入图片描述
hosted:宿主仓库,部署自己的 jar 到这个类型的仓库,包括 releases 和 snapshot 两部分,Releases 公司内部发布版本仓库、 Snapshots 公司内部测试版本仓库。
proxy:代理仓库,用于代理远程的公共仓库,如 maven 中央仓库,用户连接私服,私服自动去中央仓库下载 jar 包或者插件。
group:仓库组,用来合并多个 hosted/proxy 仓库,通常我们配置自己的 maven 连接仓库组。
virtual(虚拟):兼容 Maven1 版本的 jar 或者插件

nexus仓库类型图解:
在这里插入图片描述
配置gorup数据库组:
在这里插入图片描述
nexus 仓库默认在 sonatype-work 目录中:
在这里插入图片描述
central:代理仓库,代理中央仓库
在这里插入图片描述
apache-snapshots:代理仓库存储 snapshots 构件,代理地址 https://repository.apache.org/snapshots/
central-m1:virtual 类型仓库,兼容 Maven1 版本的 jar 或者插件
releases:本地仓库,存储 releases构件。
snapshots:本地仓库,存储 snapshots构件。
thirdparty:第三方仓库
public:仓库组

2.将项目maven_dao发布到私服

1.需求

企业中多个团队协作开发通常会将一些公用的组件、开发模块等发布到私服供其它团队或模块开发人员使用。

假设团队分别开发 maven_dao、maven_service、maven_web,某个团队开发完在maven_dao 会将 maven_dao 发布到私服供 maven_service 团队使用,本例子会将 maven_dao 工程打成jar 包发布到私服。
在这里插入图片描述

2.配置

第一步:需要在客户端即部署 ssm_dao 工程的电脑上配置 maven环境,并修改 settings.xml文件,配置连接私服的用户和密码 。
此用户名和密码用于私服校验,因为私服需要知道上传的账号和密码是否和私服中的账号和密码一致。

在这里插入图片描述

<server>
	<id>releases</id>
	<username>admin</username>
	<password>admin123</password>
</server>
<server>
	<id>snapshots</id>
	<username>admin</username>
	<password>admin123</password>
</server>

上述就是releases 连接发布版本项目仓库,snapshots 连接测试版本项目仓库。

第二步: 配置项目 pom.xml
配置私服仓库的地址,本公司的自己的 jar 包会上传到私服的宿主仓库,根据工程的版本号决定上传到哪个宿主仓库,如果版本为 release 则上传到私服的 release 仓库,如果版本为snapshot 则上传到私服的 snapshot 仓库。
在这里插入图片描述

<distributionManagement>
 <repository>
 	<id>releases</id> 
	<url>http://localhost:8081/nexus/content/repositories/releases/</url>
 </repository>
 
 <snapshotRepository>
 	<id>snapshots</id>
	<url>http://localhost:8081/nexus/content/repositories/snapshots/</url>
 </snapshotRepository>
</distributionManagement>

注意:pom.xml 这里 和 settings.xml 配置 对应!

3.测试maven_dao项目是否上传到私服

在这里插入图片描述
查看snapshots仓库上传maven_dao成功:
根据本项目pom.xml中version定义决定发布到哪个仓库,如果version定义为snapshot,执行 deploy后查看 nexus 的 snapshot仓库,如果 version定义为 release则项目将发布到 nexus的 release 仓库,本项目将发布到 snapshot 仓库:

maven_dao是 1.0-SNAPSHOT也就是测试版所以就发送到snapshots。
在这里插入图片描述
通过http方式查看http://localhost:8081/nexus/content/repositories/snapshots/com/ginger/maven_dao/
在这里插入图片描述

3.从私服中下载maven_dao项目

1.需求

没有配置 nexus 之前,如果本地仓库没有,去中央仓库下载,通常在企业中会在局域网内部署一台私服服务器,有了私服本地项目首先去本地仓库找 jar,如果没有找到则连接私服从私服下载 jar 包,如果私服没有 jar 包私服同时作为代理服务器从中央仓库下载 jar 包,这样做的好处是一方面由私服对公司项目的依赖 jar 包统一管理,一方面提高下载速度,项目连接私服下载 jar 包的速度要比项目连接中央仓库的速度快的多。

2.配置

如果不配置无法从私服中下载jar包。
在客户端的 setting.xml 中配置私服的仓库,由于 setting.xml 中没有 repositories 的配置标签需要使用 profile 定义仓库。
在这里插入图片描述

<!-- 远程仓库下载jar包配置 -->
<profile> 
	<!--profile的id -->
	<id>dev</id>
	<repositories>
		<repository> <!--仓库id,repositories可以配置多个仓库,保证id不重复 -->
			<id>nexus</id> <!--仓库地址,即nexus仓库组的地址 -->
			<url>http://localhost:8081/nexus/content/groups/public/</url> <!--是否下载releases构件 -->
			<releases>
				<enabled>true</enabled>
			</releases> <!--是否下载snapshots构件 -->
			<snapshots>
				<enabled>true</enabled>
			</snapshots>
		</repository>
	</repositories>
	<pluginRepositories> <!-- 插件仓库,maven的运行依赖插件,也需要从私服下载插件 -->
		<pluginRepository> <!-- 插件仓库的id不允许重复,如果重复后边配置会覆盖前边 -->
			<id>public</id>
			<name>Public Repositories</name>
			<url>http://localhost:8081/nexus/content/groups/public/</url>
		</pluginRepository>
	</pluginRepositories>
</profile>

<!--使用 profile 定义仓库需要激活才可生效。-->
<activeProfiles>
	<activeProfile>dev</activeProfile>
</activeProfiles>

注意:<activeProfile>dev</activeProfile>和profile的id<id>dev</id>要相同

3.测试私服中是否可以下载maven_dao项目

测试之前需要把本地仓库中的maven_dao,删除才会到私服中去下载maven_dao项目。
启动maven_web:
在这里插入图片描述
执行结果:
在这里插入图片描述

安装第三方jar包

1.安装第三方jar包到本地仓库

--安装第三方jar包到本地仓库
----进入jar包所在目录运行
mvn install:install-file -DgroupId=com.alibaba -DartifactId=fastjson -Dversion=1.1.37 -Dfile=fastjson-1.1.37.jar -Dpackaging=jar
----打开cmd直接运行
mvn install:install-file -DgroupId=com.alibaba -DartifactId=fastjson -Dversion=1.1.37 -Dpackaging=jar -Dfile=C:\Users\Administrator\Desktop\jar\fastjson-1.1.37.jar

进入jar包所在目录运行
在这里插入图片描述
执行结果:
在这里插入图片描述
打开cmd直接运行
在这里插入图片描述
执行结果:
在这里插入图片描述

2.安装第三方jar包到私服

--在settings配置文件中添加登录私服第三方登录信息
<server>
	<id>thirdparty</id>
	<username>admin</username>
	<password>admin123</password>
</server>
----进入jar包所在目录运行
mvn deploy:deploy-file -DgroupId=com.alibaba -DartifactId=fastjson -Dversion=1.1.37 -Dpackaging=jar -Dfile=fastjson-1.1.37.jar -Durl=http://localhost:8081/nexus/content/repositories/thirdparty/ -DrepositoryId=thirdparty
----打开cmd直接运行
mvn deploy:deploy-file -DgroupId=com.alibaba -DartifactId=fastjson -Dversion=1.1.37 -Dpackaging=jar -Dfile=C:\Users\Administrator\Desktop\jar\fastjson-1.1.37.jar -Durl=http://localhost:8081/nexus/content/repositories/thirdparty/ -DrepositoryId=thirdparty

首先配置setting.xml
在这里插入图片描述
进入jar包所在目录运行
在这里插入图片描述
执行结果:
在这里插入图片描述
打开cmd直接运行
在这里插入图片描述
执行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值