maven学习笔记【配置参考】

2024-09-07 17:48

本文主要是介绍maven学习笔记【配置参考】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文接上一篇 第一部分 继续来介绍。 
    目前为止我们还是手工命令行方式执行程序的,没有和IDE结合,其实Maven天生就对Eclipse做了集成,我们使用mvn eclipse:eclipse就得到了一个Eclipse的项目结构,在Eclipse中使用import功能就能直接导入到IDE中了。我们来看一下这个过程: 
 
    此时的demo就是Eclipse项目格式的了,出现了.project和.classpath文件。我们在Eclipse中引入这个项目,此时的Eclipse没有安装Maven插件,不能自动运行Maven命令,我们来安装Maven的Eclipse插件M2E。 
 
    在Eclipse的Install New Software中直接选择安装即可,非常简单。下面我们来创建Web项目并导入Eclipse中,在Jetty容器中运行程序。首先执行mvn archetype:generate命令创建。 
 
    可以看到,刚创建的web项目结构包含了resources目录,而没有java代码目录,我们需要手工创建,在Eclipse中创建source folder,路径为src/main/java/src,现在我们得到如下一个项目结构,新建一个Servlet用于测试。 
 
    此时,项目中没有Servlet的依赖,需要添加,我们使用m2eclipse插件来直接添加依赖,如下所示: 
 
    相应的XML为: 
Xml代码   收藏代码
  1. <dependency>  
  2.         <groupId>javax.servlet</groupId>  
  3.         <artifactId>servlet-api</artifactId>  
  4.         <version>2.5</version>  
  5.         <type>jar</type>  
  6.         <scope>compile</scope>  
  7. </dependency>  

    下面就可以编写Servlet了,很简单,就输出HelloWorld吧。 
Java代码   收藏代码
  1. package org.ourpioneer.servlets;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5.   
  6. import javax.servlet.ServletException;  
  7. import javax.servlet.http.HttpServlet;  
  8. import javax.servlet.http.HttpServletRequest;  
  9. import javax.servlet.http.HttpServletResponse;  
  10.   
  11. public class HelloWorldServlet extends HttpServlet {  
  12.   
  13.     protected void doGet(HttpServletRequest request,  
  14.             HttpServletResponse response) throws ServletException, IOException {  
  15.         this.process(request, response);  
  16.     }  
  17.   
  18.     protected void doPost(HttpServletRequest request,  
  19.             HttpServletResponse response) throws ServletException, IOException {  
  20.         this.process(request, response);  
  21.     }  
  22.   
  23.     private void process(HttpServletRequest request,  
  24.             HttpServletResponse response) throws ServletException, IOException {  
  25.         response.setContentType("text/html;charset=utf-8");  
  26.         response.setCharacterEncoding("utf-8");  
  27.         PrintWriter out = response.getWriter();  
  28.         String title="Webapp Demo";  
  29.         out.println("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">");  
  30.         out.println("<html xmlns=\"http://www.w3.org/1999/xhtml\">");  
  31.         out.println("<head>");  
  32.         out.println("<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />");  
  33.         out.println("<title>" + title + "</title>");  
  34.         out.println("<body>");  
  35.         out.println("<h1>Hello World!</h1>");  
  36.         out.println("</body>");  
  37.         out.println("</html>");  
  38.     }  
  39. }  

    然后不能忘了在web.xml中配置这个Servlet,这里是Servlet 2.5的规范,不是Servlet 3,不能用注解。这也很简单。 
Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   
  5.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  
  6.   
  7.     <display-name>Archetype Created Web Application</display-name>  
  8.   
  9.     <servlet>  
  10.         <servlet-name>helloworld</servlet-name>  
  11.         <servlet-class>org.ourpioneer.servlets.HelloWorldServlet</servlet-class>  
  12.     </servlet>  
  13.   
  14.     <servlet-mapping>  
  15.         <servlet-name>helloworld</servlet-name>  
  16.         <url-pattern>/helloworld</url-pattern>  
  17.     </servlet-mapping>  
  18. </web-app>  

    程序都有了,剩下就是运行了,Maven既然天生和Jetty是一对儿,这里我们就使用Jetty吧,在Maven中配置Jetty,首先是webdefault.xml要准备好,它是配置Jetty的,这个可以从Jetty的包中找到,并复制到resources下,这里多说一点,默认Jetty运行时是锁定JS/CSS等静态文件的,如果想在Jetty运行时也能修改它们,要在webdefault.xml中修改如下设置: 
Xml代码   收藏代码
  1. <init-param>  
  2.   <param-name>useFileMappedBuffer</param-name>  
  3.   <param-value>false</param-value>  
  4. </init-param>  

    Jetty也准备了,运行命令是jetty:run,这要在Maven中设置,那么需要在pom.xml中加入Jetty的插件的设置信息。这里直接贴出其整体构建信息。 
Xml代码   收藏代码
  1. <build>  
  2.     <finalName>webapp</finalName>  
  3.     <sourceDirectory>src/main/java/src</sourceDirectory>  
  4.     <testSourceDirectory>src/test</testSourceDirectory>  
  5.     <plugins>  
  6.         <plugin>  
  7.             <groupId>org.apache.maven.plugins</groupId>  
  8.             <artifactId>maven-compiler-plugin</artifactId>  
  9.             <version>2.0.2</version>  
  10.             <configuration>  
  11.                 <source>1.6</source>  
  12.                 <target>1.6</target>  
  13.                 <encoding>utf-8</encoding>  
  14.             </configuration>  
  15.         </plugin>  
  16.         <plugin>  
  17.             <groupId>org.apache.maven.plugins</groupId>  
  18.             <artifactId>maven-resources-plugin</artifactId>  
  19.             <configuration>  
  20.                 <encoding>UTF-8</encoding>  
  21.             </configuration>  
  22.         </plugin>  
  23.         <plugin>  
  24.             <groupId>org.mortbay.jetty</groupId>  
  25.             <artifactId>jetty-maven-plugin</artifactId>  
  26.             <version>7.1.6.v20100715</version>  
  27.             <configuration>  
  28.                 <stopKey>stop</stopKey>  
  29.                 <stopPort>5599</stopPort>  
  30.                 <webAppConfig>  
  31.                     <contextPath>/</contextPath>  
  32.                     <defaultsDescriptor>src/main/resources/webdefault.xml</defaultsDescriptor>  
  33.                 </webAppConfig>  
  34.                 <scanIntervalSeconds>0</scanIntervalSeconds>  
  35.                 <connectors>  
  36.                     <connector implementation="org.eclipse.jetty.server.nio.SelectChannelConnector">  
  37.                         <port>80</port>  
  38.                         <maxIdleTime>60000</maxIdleTime>  
  39.                     </connector>  
  40.                 </connectors>  
  41.             </configuration>  
  42.         </plugin>  
  43.         <plugin>  
  44.             <groupId>org.apache.maven.plugins</groupId>  
  45.             <artifactId>maven-eclipse-plugin</artifactId>  
  46.             <version>2.7</version>  
  47.             <configuration>  
  48.                 <addVersionToProjectName>false</addVersionToProjectName>  
  49.                 <useProjectReferences>false</useProjectReferences>  
  50.                 <encoding>UTF-8</encoding>  
  51.                 <wtpmanifest>false</wtpmanifest>  
  52.                 <wtpapplicationxml>true</wtpapplicationxml>  
  53.                 <wtpversion>1.5</wtpversion>  
  54.                 <additionalBuildcommands>  
  55.                     <buildcommand>org.eclipse.jdt.core.javabuilder</buildcommand>  
  56.                     <buildcommand>org.eclipse.wst.common.project.facet.core.builder</buildcommand>  
  57.                     <buildcommand>org.eclipse.wst.validation.validationbuilder</buildcommand>  
  58.                 </additionalBuildcommands>  
  59.   
  60.                 <additionalProjectnatures>  
  61.                     <nature>org.springframework.ide.eclipse.core.springnature</nature>  
  62.                     <nature>org.maven.ide.eclipse.maven2Nature</nature>  
  63.                     <nature>org.eclipse.wst.common.project.facet.core.nature</nature>  
  64.                     <nature>org.eclipse.jdt.core.javanature</nature>  
  65.                     <nature>org.eclipse.wst.common.modulecore.ModuleCoreNature</nature>  
  66.                 </additionalProjectnatures>  
  67.                 <classpathContainers>  
  68.                     <classpathContainer>org.eclipse.jdt.launching.JRE_CONTAINER</classpathContainer>  
  69.                 </classpathContainers>  
  70.             </configuration>  
  71.         </plugin>  
  72.         <plugin>  
  73.             <groupId>org.apache.maven.plugins</groupId>  
  74.             <artifactId>maven-war-plugin</artifactId>  
  75.             <version>2.1-beta-1</version>  
  76.             <configuration>  
  77.                 <warName>webapp</warName>  
  78.             </configuration>  
  79.         </plugin>  
  80.     </plugins>  
  81. </build>  

    此时,更新一下Maven依赖,它们就都自动下载到本地了,到这个过程结束,我们就可以在Eclipse中配置Debug运行了。配置很简单,如下。 
 
    这是Debug模式运行,Run模式下是一样的,用Debug模式可以在Eclipse中断点运行程序,非常便于调试。下面我们就让它跑起来吧。运行命令是jetty:run,Base directory配置是:${workspace_loc:/应用名},启动调试,看到如下信息,Jetty就成功启动了。 
 
    这里我们使用了80端口,配置方式在pom.xml中,上面的代码已经体现了。在浏览器中访问地址如下:http://localhost/helloworld,之后,我们就看到了效果。 
 
    本文系作者本人的实践和探索,希望对使用者有用,欢迎交流。 
(全篇完)

这篇关于maven学习笔记【配置参考】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145732

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于