记录Bintray网站发布Library

2024-09-04 17:58

本文主要是介绍记录Bintray网站发布Library,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

记录Bintray网站发布Library

Bintray其实只是一个网站,他们负责维护JCenter这个库,也就是说JCenter库是托管在BIntray网站上的。但是Bintray不只是只有JCenter库。我们也可以在上面创建自己的账号,生成自己的maven仓库。

现在的android studio默认依赖的就是jcenter库,但是老版本的android studio依赖的是mavenCentral库(因为上传库到mavenCentral对大部分开发者来说有点难,所以改成了jcenter)。
我们可以在工程的build.gradle文件下看到

这里写图片描述
默认的依赖库.png

好了 废话不多说、开始上手。


注册账号到Bintray

  • https://bintray.com,首先需要在这个网站上注册一个账号、这里写图片描述
    Paste_Image.png

我这里直接用的github账号登录,但是需要邮箱验证。注意这里不能使用qq邮箱,网易邮箱注册,可以用谷歌邮箱,个人用的是foxmail(qq邮箱的另外一个名字)。

注册成功之后就是这样的:
这里写图片描述
Paste_Image.png

然后我们要创建我们的仓库了,类似与github的仓库。
这里写图片描述
创建仓库.png
然后填写相应的信息就OK了,注意type要选择maven,还要如果你想非你的组织的人可以使用的话,需要选择public。这里写图片描述
Paste_Image.png
然后在仓库里面添加一个包。用于存储我们要发布的jar包。这里写图片描述
Paste_Image.png
然后填写相关信息,如图:
这里写图片描述
Paste_Image.png

完成之后,我们的准备工作就完成了。~

项目编译,发布

首先我们肯是需要一个已经写好的library。项目结构如下:

这里写图片描述
Paste_Image.png

如果没有也没关系,我们可以新建一个library,充分调试后(如果你只是想了解如何发布到bintry上的话,在library写一个测试方法即可),将其作为要发布的jar包。这里写图片描述
Paste_Image.png
好了,重头戏来了,我们要在android stduio中搭建我们的上传环境了。

  • 在本工程的build.gradle文件中添加下面的代码:
  classpath 'com.github.dcendents:android-maven-gradle-plugin:1.4.1'classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.6'  

在文件中的位置如图:注意,这里可能存在版本的问题,如果出现版本不对的话,尝试用最新版。
这里写图片描述
Paste_Image.png

  • 在library项目下添加bintrayUpload.gradle文件,文件内容如下:
apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'
// This is the library version used when deploying the artifact
version = "1.0.1"//这里是你的版本,当你需要上传新的版本到bintry上时,只需要修改这里的版本即可def siteUrl = 'https://git.oschina.net/crazycodeboy/ScanProj'      // 项目的主页
def gitUrl = 'https://git.oschina.net/crazycodeboy/ScanProj.git'   // Git仓库的url
group = "reoger.hut.com.mylibrary"                                        // Maven Group ID for the artifact,一般填你唯一的包名
install {repositories.mavenInstaller {// This generates POM.xml with proper parameterspom {project {packaging 'aar'// Add your description herename 'multi-format 1D/2D barcode image processing use zxing.'url siteUrl// Set your licenselicenses {license {name 'The Apache Software License, Version 2.0'url 'http://www.apache.org/licenses/LICENSE-2.0.txt'}}developers {developer {id 'you id'     //填写的一些基本信息(也可以不填)name 'your name'email 'your email'}}scm {connection gitUrldeveloperConnection gitUrlurl siteUrl}}}}
}
task sourcesJar(type: Jar) {from android.sourceSets.main.java.srcDirsclassifier = 'sources'
}
task javadoc(type: Javadoc) {source = android.sourceSets.main.java.srcDirsclasspath += project.files(android.getBootClasspath().join(File.pathSeparator))
}
task javadocJar(type: Jar, dependsOn: javadoc) {classifier = 'javadoc'from javadoc.destinationDir
}
artifacts {archives javadocJararchives sourcesJar
}
Properties properties = new Properties()
properties.load(project.rootProject.file('local.properties').newDataInputStream())
bintray {user = properties.getProperty("bintray.user")key = properties.getProperty("bintray.apikey")configurations = ['archives']pkg {userOrg ="hut"//这个地方一定要填,一定要填 !!(这里需要修改你申请账号是的组织id)repo = "Maven"//发布到bintray上的仓库名name = "CheckEditText"  //发布到bintray上的包名websiteUrl = siteUrlvcsUrl = gitUrllicenses = ["Apache-2.0"]publish = true}
}
javadoc { //jav doc采用utf-8编码否则会报“GBK的不可映射字符”错误options{encoding "UTF-8"charSet 'UTF-8'}

这里需要对其进行说明:
必改的内容有:
这里写图片描述
Paste_Image.png
userOrg填写你的组织Id,可以在如图的界面找到相信的信息。
这里写图片描述
Paste_Image.png
repo填写你的仓库名,name填写你的包名,可以在如图所示的地方找到相应的信息。
这里写图片描述
Paste_Image.png

  • 填写完毕之后,需要在library的build.gradle文件中添加一句:
apply from: "bintrayUpload.gradle"

最后,我们需要在项目的local.properties填写我们的身份信息。添加下面这两句到我们的目录下:

bintray.user=用户名
bintray.apikey=xxxxxxxxxxxxxxxxxx

用户名可以在这里找到
这里写图片描述
Paste_Image.png
apiKey在这里找:
这里写图片描述
Paste_Image.png
这里写图片描述
Paste_Image.png
好了,上面的工作完成之后,我们离成功已经不太远了。

接下来在termial中输入命令:

gradlew install

如果没有错误的话,会提示BUILD SUCCESSEUL,然后我们在输入:

gradlew bintrayUpload

这里写图片描述
Paste_Image.png
成功!~
去网站上看一看~:
这里写图片描述
Paste_Image.png

添加依赖到项目中

发布之后,我们就可以将他引入到我们的项目中了。

在要引入项目的build.gradle目录下,添加依赖:

maven { url 'https://hut.bintray.com/Maven' }

这里写图片描述
Paste_Image.png
其中的url就是我们的组织地址。
这里写图片描述
Paste_Image.png
然后,在我们要依赖的moudle下,添加我们需要的依赖,例如:
这里写图片描述
Paste_Image.png
这个可以在这里找到:
这里写图片描述
Paste_Image.png
然后就可以使用我们之前写好的功能了~!!。

简单发布写法

-root build.gradle 中的dependencies块中添加如下:

  classpath 'com.novoda:bintray-release:0.5.0'//修改此处版本号为 0.5.0---修改之前是0.3.4

-root build.gradle 中的allprojects中添加如下:

	repositories {jcenter()mavenCentral()}tasks.withType(Javadoc) {options {encoding "UTF-8"charSet 'UTF-8'links "http://docs.oracle.com/javase/7/docs/api"}options.addStringOption('Xdoclint:none', '-quiet')}

这里写图片描述
Paste_Image.png

在要发布的lib module 的build.gradle中加入

apply plugin: 'com.novoda.bintray-release'-如果是项目的要注意下,要将apply plugin: 'com.android.application'
改成apply plugin: 'com.android.library'

这里写图片描述
Paste_Image.png
library的build.gradle中添加

//添加
publish {userOrg = 'xxx'      //bintray 如果有组织就是组织名,反之用户名repoName = 'maven' //仓库名uploadName = 'GameSDK' //项目名groupId = 'com.test'         //compile引用时的第1部分groupIdartifactId = 'game-sdk'     //compile引用时的第2部分项目名publishVersion = '1.0.0'    //compile引用时的第3部分版本号desc = 'This is a game sdk extend library'website = '网站网址或者github地址'licences = ['Apache-2.0']
}生成后的依赖地址:compile 'com.test:game-sdk:1.0.0'
/***注:发布成功后:* 1、在要引入项目的 build.gradle目录下,添加依赖:* repositories {*       maven {*          url 'https://userOrg.bintray.com/maven'*     }//指定自己的maven路径{https://xxxx.bintray.com/maven},在未将library加入的jcenter中前,这是必须的//userOrg 如果有组织就是组织名,反之用户名*  }**  2、在dependencies中添加依赖:*  compile 'com.test:game-sdk:1.0.0'*/

-打包发布时依然可如下写法:

gradlew clean build bintrayUpload -PbintrayUser=用户名 -PbintrayKey=apiKey -PdryRun=false

这篇关于记录Bintray网站发布Library的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

如何关闭Mac的Safari通知? 3招教你关闭Safari浏览器网站通知的技巧

《如何关闭Mac的Safari通知?3招教你关闭Safari浏览器网站通知的技巧》当我们在使用Mac电脑专注做一件事情的时候,总是会被一些消息推送通知所打扰,这时候,我们就希望关闭这些烦人的Mac通... Safari 浏览器的「通知」功能本意是为了方便用户及时获取最新资讯,但很容易被一些网站滥用,导致我们