Maven实战:Pom.xml详解

什么是pom?
    pom作为项目对象模型。通过xml表示maven项目,使用pom.xml来实现。主要描述了项目:包括配置文件;开发者需要遵循的规则,缺陷管理系统,组织和licenses,项目的url,项目的依赖性,以及其他所有的项目相关因素。

<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.0http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><!-- 基本配置 --><groupId>...</groupId><artifactId>...</artifactId><version>...</version><packaging>...</packaging><!-- 依赖配置 --><dependencies>...</dependencies><parent>...</parent><dependencyManagement>...</dependencyManagement><modules>...</modules><properties>...</properties><!-- 构建配置 --><build>...</build><reporting>...</reporting><!-- 项目信息 --><name>...</name><description>...</description><url>...</url><inceptionYear>...</inceptionYear><licenses>...</licenses><organization>...</organization><developers>...</developers><contributors>...</contributors><!-- 环境设置 --><issueManagement>...</issueManagement><ciManagement>...</ciManagement><mailingLists>...</mailingLists><scm>...</scm><prerequisites>...</prerequisites><repositories>...</repositories><pluginRepositories>...</pluginRepositories><distributionManagement>...</distributionManagement><profiles>...</profiles>
</project>

基本配置

  • modelVersion:pom模型版本,maven2和3只能为4.0.0
  • groupId:组ID,maven用于定位
  • artifactId:在组中的唯一ID用于定位
  • version:项目版本
  • packaging:项目打包方式,有以下值:pom, jar, maven-plugin, ejb, war, ear, rar, par

依赖配置

parent

用于确定父项目的坐标。

<parent><groupId>com.learnPro</groupId><artifactId>SIP-parent</artifactId><relativePath></relativePath><version>0.0.1-SNAPSHOT</version>
</parent>
  • groupId:父项目的构件标识符
  • artifactId:父项目的唯一标识符
  • relativePath:Maven首先在当前项目的找父项目的pom,然后在文件系统的这个位置(relativePath),然后在本地仓库,再在远程仓库找。
  • version:父项目的版本

modules

有些maven项目会做成多模块的,这个标签用于指定当前项目所包含的所有模块。之后对这个项目进行的maven操作,会让所有子模块也进行相同操作。

<modules><module>com-a</><module>com-b</><module>com-c</>
</>

properties

用于定义pom常量

<properties><java.version>1.7</java.version>
</properties>

上面这个常量可以在pom文件的任意地方通过${java.version}来引用

dependencies

项目相关依赖配置,如果在父项目写的依赖,会被子项目引用,一般父项目会将子项目公用的依赖引入(将在之后详细讲解)

<dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency>
</dependencies>

这边依赖和中央仓库中的一致,就可以引入对应的jar

dependencyManagement

配置写法同dependencies

<dependencyManagement><dependencies>.....</dependencies>
</dependencyManagement>

在父模块中定义后,子模块不会直接使用对应依赖,但是在使用相同依赖的时候可以不加版本号:

父项目:
<dependencyManagement><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency></dependencies>
</dependencyManagement>子项目:<dependency><groupId>junit</groupId><artifactId>junit</artifactId>
</dependency>

这样的好处是,父项目统一了版本,而且子项目可以在需要的时候才引用对应的依赖

构建配置

build

用于配置项目构建相关信息

<build>    <!--该元素设置了项目源码目录,当构建项目的时候,构建系统会编译目录里的源码。该路径是相对于pom.xml的相对路径。-->    <sourceDirectory/>    <!--该元素设置了项目脚本源码目录,该目录和源码目录不同:绝大多数情况下,该目录下的内容 会被拷贝到输出目录(因为脚本是被解释的,而不是被编译的)。-->    <scriptSourceDirectory/>    <!--该元素设置了项目单元测试使用的源码目录,当测试项目的时候,构建系统会编译目录里的源码。该路径是相对于pom.xml的相对路径。-->    <testSourceDirectory/>    <!--被编译过的应用程序class文件存放的目录。-->    <outputDirectory/>    <!--被编译过的测试class文件存放的目录。-->    <testOutputDirectory/>    <!--使用来自该项目的一系列构建扩展-->    <extensions>    <!--描述使用到的构建扩展。-->    <extension>    <!--构建扩展的groupId-->    <groupId/>    <!--构建扩展的artifactId-->    <artifactId/>    <!--构建扩展的版本-->    <version/>    </extension>    </extensions>    <!--当项目没有规定目标(Maven2 叫做阶段)时的默认值-->    <defaultGoal/>    <!--这个元素描述了项目相关的所有资源路径列表,例如和项目相关的属性文件,这些资源被包含在最终的打包文件里。-->    <resources>    <!--这个元素描述了项目相关或测试相关的所有资源路径-->    <resource>    <!-- 描述了资源的目标路径。该路径相对target/classes目录(例如${project.build.outputDirectory})。举个例 子,如果你想资源在特定的包里(org.apache.maven.messages),你就必须该元素设置为org/apache/maven /messages。然而,如果你只是想把资源放到源码目录结构里,就不需要该配置。-->    <targetPath/>    <!--是否使用参数值代替参数名。参数值取自properties元素或者文件里配置的属性,文件在filters元素里列出。-->    <filtering/>    <!--描述存放资源的目录,该路径相对POM路径-->    <directory/>    <!--包含的模式列表,例如**/*.xml.-->    <includes/>    <!--排除的模式列表,例如**/*.xml-->    <excludes/>    </resource>    </resources>    <!--这个元素描述了单元测试相关的所有资源路径,例如和单元测试相关的属性文件。-->    <testResources>    <!--这个元素描述了测试相关的所有资源路径,参见build/resources/resource元素的说明-->    <testResource>    <targetPath/><filtering/><directory/><includes/><excludes/>    </testResource>    </testResources>    <!--构建产生的所有文件存放的目录-->    <directory/>    <!--产生的构件的文件名,默认值是${artifactId}-${version}。-->    <finalName/>    <!--当filtering开关打开时,使用到的过滤器属性文件列表-->    <filters/>    <!--子项目可以引用的默认插件信息。该插件配置项直到被引用时才会被解析或绑定到生命周期。给定插件的任何本地配置都会覆盖这里的配置-->    <pluginManagement>    <!--使用的插件列表 。-->    <plugins>    <!--plugin元素包含描述插件所需要的信息。-->    <plugin>    <!--插件在仓库里的group ID-->    <groupId/>    <!--插件在仓库里的artifact ID-->    <artifactId/>    <!--被使用的插件的版本(或版本范围)-->    <version/>    <!--是否从该插件下载Maven扩展(例如打包和类型处理器),由于性能原因,只有在真需要下载时,该元素才被设置成enabled。-->    <extensions/>    <!--在构建生命周期中执行一组目标的配置。每个目标可能有不同的配置。-->    <executions>    <!--execution元素包含了插件执行需要的信息-->    <execution>    <!--执行目标的标识符,用于标识构建过程中的目标,或者匹配继承过程中需要合并的执行目标-->    <id/>    <!--绑定了目标的构建生命周期阶段,如果省略,目标会被绑定到源数据里配置的默认阶段-->    <phase/>    <!--配置的执行目标-->    <goals/>    <!--配置是否被传播到子POM-->    <inherited/>    <!--作为DOM对象的配置-->    <configuration/>    </execution>    </executions>    <!--项目引入插件所需要的额外依赖-->    <dependencies>    <!--参见dependencies/dependency元素-->    <dependency>    ......    </dependency>    </dependencies>         <!--任何配置是否被传播到子项目-->    <inherited/>    <!--作为DOM对象的配置-->    <configuration/>    </plugin>    </plugins>    </pluginManagement>    <!--使用的插件列表-->    <plugins>    <!--参见build/pluginManagement/plugins/plugin元素-->    <plugin>    <groupId/><artifactId/><version/><extensions/>    <executions>    <execution>    <id/><phase/><goals/><inherited/><configuration/>    </execution>    </executions>    <dependencies>    <!--参见dependencies/dependency元素-->    <dependency>    ......    </dependency>    </dependencies>    <goals/><inherited/><configuration/>    </plugin>    </plugins>    </build>

reporting

该元素描述使用报表插件产生报表的规范。当用户执行“mvn site”,这些报表就会运行。 在页面导航栏能看到所有报表的链接。

<reporting>    <!--true,则,网站不包括默认的报表。这包括“项目信息”菜单中的报表。-->    <excludeDefaults/>    <!--所有产生的报表存放到哪里。默认值是${project.build.directory}/site。-->    <outputDirectory/>    <!--使用的报表插件和他们的配置。-->    <plugins>    <!--plugin元素包含描述报表插件需要的信息-->    <plugin>    <!--报表插件在仓库里的group ID-->    <groupId/>    <!--报表插件在仓库里的artifact ID-->    <artifactId/>    <!--被使用的报表插件的版本(或版本范围)-->    <version/>    <!--任何配置是否被传播到子项目-->    <inherited/>    <!--报表插件的配置-->    <configuration/>    <!--一组报表的多重规范,每个规范可能有不同的配置。一个规范(报表集)对应一个执行目标 。例如,有1,2345678,9个报表。12,5构成A报表集,对应一个执行目标。25,8构成B报表集,对应另一个执行目标-->    <reportSets>    <!--表示报表的一个集合,以及产生该集合的配置-->    <reportSet>    <!--报表集合的唯一标识符,POM继承时用到-->    <id/>    <!--产生报表集合时,被使用的报表的配置-->    <configuration/>    <!--配置是否被继承到子POMs-->    <inherited/>    <!--这个集合里使用到哪些报表-->    <reports/>    </reportSet>    </reportSets>    </plugin>    </plugins>    </reporting>

项目信息

  • name:给用户提供更为友好的项目名
  • description:项目描述,maven文档中保存
  • url:主页的URL,maven文档中保存
  • inceptionYear:项目创建年份,4位数字。当产生版权信息时需要使用这个值
  • licenses:该元素描述了项目所有License列表。 应该只列出该项目的license列表,不要列出依赖项目的 license列表。如果列出多个license,用户可以选择它们中的一个而不是接受所有license。(如下)
<license>    <!--license用于法律上的名称-->    <name>...</name>     <!--官方的license正文页面的URL-->    <url>....</url><!--项目分发的主要方式:repo,可以从Maven库下载 manual, 用户必须手动下载和安装依赖-->    <distribution>repo</distribution>     <!--关于license的补充信息-->    <comments>....</comments>     
</license> 
  • organization:1.name 组织名 2.url 组织主页url
  • developers:项目开发人员列表(如下)
  • contributors:项目其他贡献者列表,同developers
<developers>  <!--某个开发者信息--><developer>  <!--开发者的唯一标识符--><id>....</id>  <!--开发者的全名--><name>...</name>  <!--开发者的email--><email>...</email>  <!--开发者的主页--><url>...<url/><!--开发者在项目中的角色--><roles>  <role>Java Dev</role>  <role>Web UI</role>  </roles> <!--开发者所属组织--> <organization>sun</organization>  <!--开发者所属组织的URL--><organizationUrl>...</organizationUrl>  <!--开发者属性,如即时消息如何处理等--><properties><!-- 和主标签中的properties一样,可以随意定义子标签 --></properties> <!--开发者所在时区, -11到12范围内的整数。--> <timezone>-5</timezone>  </developer>  
</developers>  

环境设置

issueManagement

目的问题管理系统(Bugzilla, Jira, Scarab)的名称和URL

<issueManagement><system>Bugzilla</system><url>http://127.0.0.1/bugzilla/</url>
</issueManagement>
  • system:系统类型
  • url:路径

ciManagement

项目的持续集成信息

<ciManagement><system>continuum</system><url>http://127.0.0.1:8080/continuum</url><notifiers><notifier><type>mail</type><sendOnError>true</sendOnError><sendOnFailure>true</sendOnFailure><sendOnSuccess>false</sendOnSuccess><sendOnWarning>false</sendOnWarning><address>continuum@127.0.0.1</address><configuration></configuration></notifier></notifiers>
</ciManagement>
    • system:持续集成系统的名字
    • url:持续集成系统的URL
    • notifiers:构建完成时,需要通知的开发者/用户的配置项。包括被通知者信息和通知条件(错误,失败,成功,警告)
      • type:通知方式
      • sendOnError:错误时是否通知
      • sendOnFailure:失败时是否通知
      • sendOnSuccess:成功时是否通知
      • sendOnWarning:警告时是否通知
      • address:通知发送到的地址
      • configuration:扩展项

mailingLists

项目相关邮件列表信息

  <mailingLists><mailingList><name>User List</name><subscribe>user-subscribe@127.0.0.1</subscribe><unsubscribe>user-unsubscribe@127.0.0.1</unsubscribe><post>user@127.0.0.1</post><archive>http://127.0.0.1/user/</archive><otherArchives><otherArchive>http://base.google.com/base/1/127.0.0.1</otherArchive></otherArchives></mailingList>.....</mailingLists>
  • subscribe, unsubscribe: 订阅邮件(取消订阅)的地址或链接,如果是邮件地址,创建文档时,mailto: 链接会被自动创建
  • archive:浏览邮件信息的URL
  • post:接收邮件的地址

scm

允许你配置你的代码库,供Maven web站点和其它插件使用

  <scm><connection>scm:svn:http://127.0.0.1/svn/my-project</connection><developerConnection>scm:svn:https://127.0.0.1/svn/my-project</developerConnection><tag>HEAD</tag><url>http://127.0.0.1/websvn/my-project</url></scm>
  • connection, developerConnection:这两个表示我们如何连接到maven的版本库。connection只提供读,developerConnection将提供写的请求
    • 写法如:scm:[provider]:[provider_specific]
    • 如果连接到CVS仓库,可以配置如下:scm:cvs:pserver:127.0.0.1:/cvs/root:my-project
  • tag:项目标签,默认HEAD
  • url:共有仓库路径

prerequisites

项目构建的前提

<prerequisites><maven>2.0.6</maven>
</prerequisites>

repositories,pluginRepositories

依赖和扩展的远程仓库列表,同上篇文章,setting.xml配置中介绍的。

  <repositories><repository><releases><enabled>false</enabled><updatePolicy>always</updatePolicy><checksumPolicy>warn</checksumPolicy></releases><snapshots><enabled>true</enabled><updatePolicy>never</updatePolicy><checksumPolicy>fail</checksumPolicy></snapshots><id>codehausSnapshots</id><name>Codehaus Snapshots</name><url>http://snapshots.maven.codehaus.org/maven2</url><layout>default</layout></repository></repositories><pluginRepositories>...</pluginRepositories>
  • releases, snapshots:这是各种构件的策略,release或者snapshot。这两个集合,POM就可以根据独立仓库任意类型的依赖改变策略。如:一个人可能只激活下载snapshot用来开发。
  • enable:true或者false,决定仓库是否对于各自的类型激活(release 或者 snapshot)。
  • updatePolicy: 这个元素决定更新频率。maven将比较本地pom的时间戳(存储在仓库的maven数据文件中)和远程的. 有以下选择: always, daily (默认), interval:X (x是代表分钟的整型) , never.
  • checksumPolicy:当Maven向仓库部署文件的时候,它也部署了相应的校验和文件。可选的为:ignore,fail,warn,或者不正确的校验和。
  • layout:在上面描述仓库的时候,提到他们有统一的布局。Maven 2有它仓库默认布局。然而,Maven 1.x有不同布局。使用这个元素来表明它是default还是legacy。

distributionManagement

它管理的分布在整个构建过程生成的工件和支持文件

  <distributionManagement>...<downloadUrl>http://mojo.codehaus.org/my-project</downloadUrl><status>deployed</status></distributionManagement>
    • downloadUrl: 其他pom可以通过此url的仓库抓取组件
    • status:给出该构件在远程仓库的状态
      • none: 默认
      • converted: 将被早期Maven 2 POM转换过来
      • partner: 这个项目会从合作者仓库同步过来
      • deployed: 从Maven 2或3实例部署
      • verified: 被核实时正确的和最终的

Repository

指定Maven pom从远程下载控件到当前项目的位置和方式,如果snapshotRepository没有被定义则使用repository相关的配置

  <distributionManagement><repository><uniqueVersion>false</uniqueVersion><id>corp1</id><name>Corporate Repository</name><url>scp://repo/maven2</url><layout>default</layout></repository><snapshotRepository><uniqueVersion>true</uniqueVersion><id>propSnap</id><name>Propellors Snapshots</name><url>sftp://propellers.net/maven</url><layout>legacy</layout></snapshotRepository>...</distributionManagement>
  • id, name:仓库的唯一标识
  • uniqueVersion:true或false,指明控件部署的时候是否获取独立的版本号。
  • url:repository元素的核心。指定位置和部署协议发布控件到仓库。
  • layout:布局,default或legacy

Site Distribution

多分布存储库,distributionManagement负责定义如何部署项目的网站和文档。

  <distributionManagement>...<site><id>mojo.website</id><name>Mojo Website</name><url>scp://beaver.codehaus.org/home/projects/mojo/public_html/</url></site>...</distributionManagement>
  • id, name, url: 这些元素与distributionManagement repository中的相同

Relocation

重新部署-项目不是静态的,是活的。他们需要被搬到更合适的地方。如:当你的下个成功的开源项目移到Apache下,重命名为org.apache:my-project:1.0 对你项目更有好处。

  <distributionManagement>...<relocation><groupId>org.apache</groupId><artifactId>my-project</artifactId><version>1.0</version><message>We have moved the Project under Apache</message></relocation>...</distributionManagement>

profiles

profile可以让我们定义一系列的配置信息(插件等),然后指定其激活条件 

    • profile可以让我们定义一系列的配置信息,然后指定其激活条件。
      根据每个profile对应不同的激活条件和配置信息,从而达到不同环境使用不同配置。
    • 例子:通过profile定义jdk1.5以上使用一套配置,jdk1.5以下使用另外一套配置;或者通过操作系统来使用不同的配置信息。
    • settings.xml中定义的properties的值可以在pom.xml中使用。

 

转载于:https://www.cnblogs.com/WangBoBlog/p/7998563.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354474.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Liunx 命令大全

1.ifconfig 用于配置和显示Linux内核中网络接口的网络参数 2.type 用来显示指定命令的类型&#xff0c;判断给出的指令是内部 令还是外部指令 3.man Linux下的帮助指令&#xff0c;通过man指令可以查看Linux 中的指令帮助、配置文件帮助和编程帮助等信息 4.help 用于显示 shell…

如何在Hibernate Search 5.5.2 / Apache Lucene 5.4.x中处理停用词?

停用词&#xff0c;例如[“ a”&#xff0c;“ an”&#xff0c;“ and”&#xff0c;“ are”&#xff0c;“ as”&#xff0c;“ at”&#xff0c;“ be”&#xff0c;“ but”&#xff0c;“ by”&#xff0c;“ for”&#xff0c;“ if”&#xff0c;“在”&#xff0c;“成…

windows路径操作API函数

路径截断与合并函数 PathRemoveArgs 去除路径的参数 PathRemoveBackslash 去除路径最后的反斜杠“\” PathAddBackslash 在路径最后加上反斜杠“\” PathRemoveBlanks 去除路径前后的空格 PathAddExtension 在文件路径后面加上扩展名 PathRemoveExtensio…

docker安装问题

1、卸载docker重装 将所有含docker的文件找出来 find / -name ‘docker’ 或cd到根目录后搜索&#xff1a; find -name ‘docker 删除搜索的文件或目录&#xff1a; rm -rf … 删除全部的docker有关文件命令 rm -rf $(find -name ‘docker’) 2、安装docker 安装依赖 su…

【BZOJ1814】Ural 1519 Formula 1 插头DP

【BZOJ1814】Ural 1519 Formula 1 题意&#xff1a;一个 m * n 的棋盘,有的格子存在障碍,求经过所有非障碍格子的哈密顿回路个数。(n,m<12) 题解&#xff1a;插头DP板子题&#xff0c;刷板子&#xff0c;附带题解链接。 如何存放状态呢&#xff1f;可以采用hash&#xff0c;…

docker-compose安装问题

&#xff08;一&#xff09;docker-compose安装超时 1、设置一个timeout pip install --default-timeout100 docker-compos2、下载到本地 docker_compose-1.27.0-py2.py3-none-any.whl首先去下载&#xff1a;https://pypi.org/project/docker-compose/#files 然后用xftp上传…

java更改包名称_更改Java包名称如何改变我的系统架构

java更改包名称即使只是少量更改角度&#xff0c;也可能对您如何使用系统产生深远影响。 假设您正在用Java编写Web应用程序。 在系统中&#xff0c;您处理订单&#xff0c;客户和产品。 作为一个Web应用程序&#xff0c;您的类包括诸如Controller&#xff0c;PersonRepository&…

linux系统界面光标不见了---木有了

直接在界面输入命令 echo -e “\033[?25l” 隐藏光标 echo -e “\033[?25h” 显示光标

Java----前端验证之验证码额实现

验证码是常用的登录验证方式之一,最大的作用就是保证安全,验证码的生成在java中实现的方式有很多种,比如后台生成传输到前端页面,在前台直接生成进行验证,下面写一个最简单实现验证码验证登录的例子. 生成验证码: 验证码验证逻辑: From表单登录: 没错,就这么的简单.在scripts生…

使用Spring Boot隔离集成测试和模拟依赖项

集成测试可能很慢且不可靠&#xff0c;因为它们依赖于系统中过多的组件。 在某种程度上&#xff0c;这是不可避免的&#xff1a;这里的集成测试是为了验证系统的每个部分如何与其他内部或外部组件一起玩。 但是&#xff0c;我们可以通过仅分解所需的依赖关系而不是整个系统来改…

CSS浏览器兼容性问题

CSS浏览器兼容性问题 1、浏览器CSS样式初始化 最简单的初始化方法就是&#xff1a;使用通配符&#xff08;*&#xff09;&#xff0c;重置所有的初始样式。 *{margin: 0;padding: 0; } /* 10px1rem */ html {overflow-y:scroll;font-size:62.5%; } a{text-decoration:none; …

Ubuntu 16.04下使用Wine安装Xshell 4和Xftp 4

说明&#xff1a; 1、使用的Wine版本是深度出品&#xff08;Deepin&#xff09;&#xff0c;已经精简了很多没用的配置&#xff0c;使启动能非常快&#xff0c;占用资源小。 2、由于Xshell 5的C库无法在这个Wine版本运行&#xff0c;即使升级官方原版的2版本也无法解决&#xf…

字符串反序输出字符串

Console.Write("请输入一个字符串&#xff1a;"); string str Console.ReadLine(); string reverse "";//用于存放反序后的字符串 for (int i str.Length - 1; i > 0; i--) {   reverse str[i]; } Console.WriteLine(reverse":串符字个一入输…

centos8服务器创建新用户并指定该用户只能打开某个目录文件

ssh -V来查看openssh的版本 需求&#xff1a;sftp组&#xff0c;用户mysftp&#xff0c;该用户不能使用ssh&#xff0c;且sftp登录后只能在自己的主目录下操作&#xff0c;不能访问其他目录 1、创建sftp组 groupadd sftp2、创建一个sftp用户&#xff0c;名为mysftp useradd …

[转载]Oracle ltrim() 函数用法

前面有说到过LPAD和RPAD这两个函数用法的文章&#xff0c;今天发现与之相反意义的另外两个函数&#xff0c;那就是LTRIM() RTRIM()。 这次就挑LTRIM() 这一函数来讲讲&#xff1a; 具体的语法格式如下&#xff1a; LTRIM(c1,[,c2]) 【功能】删除左边出现的字符串 【参数】C1 字…

电脑缺失MSVCP110.dll文件

安装某软件显示如下错误。 错误&#xff1a; 原因&#xff1a;电脑缺少MSVCP110.dll系统文件。C:\Windows\System32目录下没有此文件。 解决&#xff1a; 下载vcredist_x64直接双击安装&#xff0c;安装完成后就可以继续安装之前安装不了的软件了。。 这里是我下载的&#…

js正则 匹配 正则表达式

1.由数字、26个英文字母或者下划线组成的字符串: ^[0-9a-zA-Z_]{1,}$2.非负整数&#xff08;正整数 0 &#xff09;: ^/d$3.正整数: ^[0-9]*[1-9][0-9]*$4.非正整数&#xff08;负整数 0&#xff09;&#xff1a; ^((-/d)|(0))$5.负整数 ^-[0-9]*[1-9][0-9]*$6.整数: ^-?…

chromedriver链接

http://npm.taobao.org/mirrors/chromedriver/转载于:https://www.cnblogs.com/shuo1208/p/8023827.html

web csrf java_在Java Web应用程序中阻止CSRF

web csrf java跨站点请求伪造攻击&#xff08;CSRF&#xff09;在Web应用程序中非常常见&#xff0c;如果允许&#xff0c;可能会造成重大危害。 如果您从未听说过CSRF&#xff0c;建议您查看有关它的OWASP页面 。 幸运的是&#xff0c;阻止CSRF攻击非常简单&#xff0c;我将向…

MySQL 安全性知识要点

添加、删除用户 1.添加用户 可以使用CREAT USER语法添加一个或多个用户&#xff0c;并设置相应的密码。 语法格式&#xff1a; CREAT USER user [IDENTIFIED BY [PASSWORD] password] [,user [IDENTIFIED BY [PASSWORD] password] ] ... 其中&#xff0c;user的格式为&…