终端开发

Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 iMac上 Xcode 相关设置及常见问题 iOS开发 -- 首次使用Xcode运行iOS项目代码 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 gradle相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

标签

android 46

Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

发布开源代码到jcenter

「 开发工具 」 ——  2019年05月14日

在平时的开发中,经常会写一些通用的代码,为了方便自己后续使用,也为了方便更多的人,大都会选择发布到github或者jcenter等一些开源库。

这篇文章从头开始介绍怎么把开源代码发布到jcenter,并在项目中使用。包括注册账号,发布,发布后使用以及发布中一些常见的问题。

代码准备

为了方便介绍,选择通过一款早期开源的项目来介绍。

  • 项目地址:

    https://github.com/bihe0832/Android-HttpURLConnection

  • 文件结构

      ├── README.md
      │
      ├── advanced:com.bihe0832:http-advanced 源码
      │
      ├── app:Demo 源码
      │
      ├── common:com.bihe0832:http-common 源码
      │
      └── utils:com.bihe0832:utils 源码
    
  • 补充说明

    接下来我们将会介绍怎么把utilscommonadvanced发布到jcenter并在Demo中引用

注册账号

官网地址:

注册账号并创建仓库:

  • 注册账号

    打开官网首页,点击下图中红框中的Sign Up Here

    填写邮箱等信息,创建账号

    账号创建以后,会自动给使用的邮箱发送一封确认邮件,前往邮箱验证账号。

  • 创建仓库

    由于目前我们发布的大部分开源项目都是maven格式的,因此我们先新建一个maven的源码仓库。点击下图中的Add New Repository

    如下图填写仓库信息以后,点击create以后,仓库即可创建成功,这里name选择maven是因为我们后面发布脚本使用了第三方插件,需要按照他的规范设置。

  • 获取API Key

    API Key 主要是在发布代码时使用,因此我们提前获取好,按下图提示点击右上角的用户名,然后点击Edit Profile

    进入编辑页以后,按照下图提示,复制API Key到剪贴板

发布代码库并使用

配置发布插件

  • 在根目录添加发布插件的相关依赖

      buildscript {  
          repositories {  
              jcenter()  
          }  
          dependencies {  
              classpath 'com.novoda:bintray-release:0.9.1'  
          }  
      }   
    
      allprojects {  
          repositories {  
              jcenter()  
          }  
      }
    
  • 在需要发布的module添加开源库相关的配置

      //应用发布使用的插件
      apply plugin: 'com.novoda.bintray-release' 
    
      //添加发布相关的配置 
      publish {  
        userOrg = 'bihe0832' //用户名  
        groupId = 'com.bihe0832.test'//代码库路径  
        artifactId = 'utils-demo'//项目名称  
        publishVersion = '1.0.1'//版本号  
        desc = 'the base utils for zixie'//项目描述
        website = 'https://github.com/bihe0832/Android-HttpURLConnection'//项目对应网站 
      }
    

    按照上面的配置发布的插件,在最终被引用时,形式为:api 'com.bihe0832.test:utils-demo:1.0.0'

提交代码

在项目根目录运行下面的命令:

./gradlew clean build bintrayUpload -PbintrayUser=USERNAME -PbintrayKey=API_KEY  -PdryRun=false

其中:USERNAME为登录用用户名,API_KEY为上面提到的API Key,具体事例如下:

➜  Android-HttpURLConnection git:(master)  ./gradlew clean build bintrayUpload -PbintrayUser=bihe0832 -PbintrayKey=d***d  -PdryRun=false
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=1g; support was removed in 8.0
Starting a Gradle Daemon (subsequent builds will be faster)

> Configure project :utils

> Task :utils:lint
Ran lint on variant release: 0 issues found
Ran lint on variant debug: 0 issues found

……

> Task :utils:bintrayUpload
Uploading to https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-sources.jar...
Uploaded to 'https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-sources.jar'.
Uploading to https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-javadoc.jar...
Uploaded to 'https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-javadoc.jar'.
Uploading to https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0.aar...
Uploaded to 'https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0.aar'.
Uploading to https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0.pom...
Uploaded to 'https://api.bintray.com/content/bihe0832/maven/utils-sdsd/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0.pom'.

Deprecated Gradle features were used in this build, making it incompatible with Gradle 5.0.
Use '--warning-mode all' to show the individual deprecation warnings.
See https://docs.gradle.org/4.10.1/userguide/command_line_interface.html#sec:command_line_warnings

BUILD SUCCESSFUL in 22s
56 actionable tasks: 53 executed, 3 up-to-date
➜  Android-HttpURLConnection git:(master) ✗

此时我们的代码就已经成功提交到了bintray.com,在maven的页面已经可以查到,此时其实已经可以在代码中使用:

引用项目

此时其实我们的项目已经可以在代码中使用

在根目录添加开源库仓库的相关依赖,对应的url在上图的右上角:

buildscript {  
    repositories {  
        maven { url "https://dl.bintray.com/bihe0832/maven" }
    }  
}   

allprojects {  
    repositories {  
        maven { url "https://dl.bintray.com/bihe0832/maven" }
    }  
}

在对应项目添加依赖,具体的依赖方法可以参考上图左下角:

compile 'com.bihe0832.test:utils-demo:1.0.0'

发布到jcenter

可以看到上面虽然我们已经可以使用了,但是其实是发布到一个自己的私有仓库,但是日常开发中我们使用的库都是发布到jcenter,接下来就把我们的仓库同步到jcenter

如下图,进入项目以后,点击右上角的actions,然后选择 Add to Jcenter

在弹框中输入简单的项目介绍即可,接下来就是短暂的等待,一般几个小时内就可以收到jcenter的回复。之后就可以将上面的引用开源库仓库的相关依赖的地址修改为jcenter了,如下:

buildscript {  
    repositories {  
        jcenter()
    }  
}   

allprojects {  
    repositories {  
        jcenter()
    }  
}

常见问题:

  1. 界面不一致:

    很多人表示看到的教程等等上面的图都是下面的版本,发现和自己登录以后并不一致,这是因为bintray改版了,可以通过点击下面红框中的按钮在新旧两种风格中切换。

  2. 提交代码报错,提示:HTTP/1.1 401 Unauthorized [message:This resource requires authentication]

    请检查执行./gradlew clean build bintrayUpload -PbintrayUser=USERNAME -PbintrayKey=API_KEY -PdryRun=false时使用的用户名和API Key是否正确,一般是因为这个原因。

  3. 提交代码报错,提示:HTTP/1.1 409 Conflict [message:Unable to upload files: An artifact with the path ‘com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-sources.jar’ already exists]

    错误事例:

     * What went wrong:
     Execution failed for task ':utils:bintrayUpload'.
     > Could not upload to 'https://api.bintray.com/content/bihe0832/maven/utils-demo/1.0.0/com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-sources.jar': HTTP/1.1 409 Conflict [message:Unable to upload files: An artifact with the path 'com/bihe0832/test/utils-demo/1.0.0/utils-demo-1.0.0-sources.jar' already exists]
    
     * Try:
     Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
    
     * Get more help at https://help.gradle.org
    
     Deprecated Gradle features were used in this build, making it incompatible with Gradle 5.0.
     Use '--warning-mode all' to show the individual deprecation warnings.
     See https://docs.gradle.org/4.10.1/userguide/command_line_interface.html#sec:command_line_warnings
    
     BUILD FAILED in 7s
     56 actionable tasks: 53 executed, 3 up-to-date
    

    这种问题很明显,远程已经存在当前版本,升级版本号以后重试即可

  4. 发布到jcenter失败,提示:The version control XXX returns 404.

    这种问题一般是因为不是自动创建的代码库,而是在提交代码之前已经手动创建了代码库,然后VCS填写错误,如下图:

    修改为项目对应的正确的版本控制地址即可。


赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!