记录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

相关文章

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优