问题描述
我有一个库项目,其中包含一个仅用于库类和视图的模块.我一直在互联网上搜索如何在 jcenter 中分发它以用作 gradle 依赖项,但没有任何效果.
虽然这还没有完成,我如何在其他项目中使用这个模块?
ps:我在 windows 10 上使用 android studio.
网上的很多教程和指导已经过时或者很难理解.我自己刚刚学会了如何做到这一点,所以我添加了希望对您来说是一个快速百家乐凯发k8的解决方案的内容.它包括以下几点
- 从您的 android 库开始
- 设置 bintray 帐户
- 编辑项目的 gradle 文件
- 将您的项目上传到 bintray
- 将其链接到 jcenter
在 jcenter 中分发 android 库以在 gradle 中使用-百家乐凯发k8
现在您可能已经建立了一个库.为了这个示例,我在 android studio 中创建了一个包含一个 demo-app 应用程序模块和一个 my-library 库模块的新项目.
下面是同时使用 project 和 android 视图的样子:
bintray 托管 jcenter 存储库.
将存储库命名为 maven.(不过,如果您想将多个库项目组合在一起,您可以将其命名为其他名称.如果这样做,您还需要在下面的 gradle 文件中更改 bintrayrepo 名称.)
选择 maven 作为存储库类型.
您可以根据需要添加说明.然后点击创建.这就是我们现在在 bintray 中需要做的所有事情.
我将尽可能地进行剪切和粘贴,但不要忘记编辑必要的部分.您无需对演示应用模块的 build.gradle 文件进行任何操作,只需对项目和库的 gradle 文件进行操作即可.
项目构建.gradle
将 bintray 和 mavin 插件添加到您的项目 build.gradle 文件中.这是我的整个文件:
buildscript {存储库{中心()}依赖{类路径'com.android.tools.build:gradle:2.3.2'//添加这些行(将它们更新为最新版本)类路径'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.7.3'类路径'com.github.dcendents:android-maven-gradle-plugin:1.5'}}所有项目{存储库{中心()}}任务清理(类型:删除){删除 rootproject.builddir}
打开终端并转到项目的根文件夹.或者只使用 android studio 中的终端.
输入以下命令
./gradlew install./gradlew bintray上传
如果一切设置正确,它应该将您的库上传到 bintray.如果失败,请谷歌百家乐凯发k8的解决方案.(我第一次尝试时必须更新我的 jdk.)
转到您在 bintray 中的帐户,您应该会看到在您的存储库下输入的库.
在您的 bintray 库中,有一个 添加到 jcenter 按钮.
点击它并发送您的请求.如果您获得批准(需要一两天时间),那么您的库将成为 jcenter 的一部分,世界各地的开发人员只需在应用程序 build.gradlebuild.gradle 中添加一行即可将您的库添加到他们的项目中code> 依赖块.
依赖项{编译 'com.example:my-library:1.0.0'}
恭喜!
- 您可能想要添加 pgp 加密,尤其是当您将其链接到 maven central 时.(不过,jcenter 已将 maven central 替换为 android studio 中的默认设置.)请参阅 本教程 寻求帮助.但也从 bintray 阅读此.
您最终会希望将新版本添加到您的 bintray/jcenter 库中.请参阅此答案了解如何操作.
- 如何分发您的通过 android studio 中的 jcenter 和 maven central 拥有自己的 android 库
- 创建和发布 android 库
i have a library project with a module that is just for library classes and views. i've been searching over the internet how to distribute it in jcenter to use as a gradle dependency but nothing works.
while this isn't done yet, how can i use this module in others projects?
ps: i use android studio on windows 10.
many of the tutorials and directions online are out of date or are very hard to follow. i just learned how to do this myself, so i am adding what will hopefully be a quick solution for you. it includes the following points
- start with your android library
- set up a bintray account
- edit your project's gradle files
- upload your project to bintray
- link it to jcenter
by now you probably already have a library set up. for the sake of this example i made a new project with one demo-app application module and one my-library library module in android studio.
here is what it looks like using both the project and android views:
bintray hosts the jcenter repositories. go to bintray and set up a free account.
after you sign in click add new repository
name the repository maven. (you can call it something else, though, if you want to group several library projects together. if you do you will also need to change the bintrayrepo name in the gradle file below.)
chose maven as the repository type.
you can add a description if you want. then click create. that's all we need to do in bintray for now.
i'm going to make this as cut-and-paste as possible, but don't forget to edit the necessary parts. you don't need to do anything with the demo app module's build.gradle file, only the gradle files for the project and the library.
project build.gradle
add the bintray and mavin plugins to your project build.gradle file. here is my whole file:
buildscript { repositories { jcenter() } dependencies { classpath 'com.android.tools.build:gradle:2.3.2' // add these lines (update them to whatever the newest version is) classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.7.3' classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5' } } allprojects { repositories { jcenter() } } task clean(type: delete) { delete rootproject.builddir }
the newest version for bintray is here and maven is here.
library build.gradle
edit everything you need to in the ext block below.
apply plugin: 'com.android.library' // change all of these as necessary ext { bintrayrepo = 'maven' // this is the same as whatever you called your repository in bintray bintrayname = 'my-library' // your bintray package name. i am calling it the same as my library name. publishedgroupid = 'com.example' libraryname = 'my-library' artifact = 'my-library' // i'm calling it the same as my library name librarydescription = 'an example library to make your programming life easy' siteurl = 'https://github.com/example/my-library' giturl = 'https://github.com/example/my-library.git' libraryversion = '1.0.0' developerid = 'myid' // maven plugin uses this. i don't know if it needs to be anything special. developername = 'my name' developeremail = 'myemail@example.com' licensename = 'the mit license (mit)' licenseurl = 'http://www.51sjk.com/upload/articles/1/0/340/340558_20221230120530018.jpg' alllicenses = ["mit"] } // this next section is your normal gradle settings // there is nothing special that you need to change here // related to bintray. keep scrolling down. android { compilesdkversion 25 buildtoolsversion "25.0.2" defaultconfig { minsdkversion 9 targetsdkversion 25 versioncode 1 versionname "1.0" testinstrumentationrunner "android.support.test.runner.androidjunitrunner" } buildtypes { release { minifyenabled false proguardfiles getdefaultproguardfile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { compile filetree(dir: 'libs', include: ['*.jar']) androidtestcompile('com.android.support.test.espresso:espresso-core:2.2.2', { exclude group: 'com.android.support', module: 'support-annotations' }) compile 'com.android.support:appcompat-v7:25.3.1' testcompile 'junit:junit:4.12' } // maven section // you shouldn't need to change anything. it just uses the // values you set above. apply plugin: 'com.github.dcendents.android-maven' group = publishedgroupid // maven group id for the artifact install { repositories.maveninstaller { // this generates pom.xml with proper parameters pom { project { packaging 'aar' groupid publishedgroupid artifactid artifact // add your description here name libraryname description librarydescription url siteurl // set your license licenses { license { name licensename url licenseurl } } developers { developer { id developerid name developername email developeremail } } scm { connection giturl developerconnection giturl url siteurl } } } } } // bintray section // as long as you add bintray.user and bintray.apikey to the local.properties // file, you shouldn't have to change anything here. the reason you // don't just write them here is so that they won't be publicly visible // in github or wherever your source control is. apply plugin: 'com.jfrog.bintray' version = libraryversion if (project.hasproperty("android")) { // android libraries task sourcesjar(type: jar) { classifier = 'sources' from android.sourcesets.main.java.srcdirs } task javadoc(type: javadoc) { source = android.sourcesets.main.java.srcdirs classpath = project.files(android.getbootclasspath().join(file.pathseparator)) } } else { // java libraries task sourcesjar(type: jar, dependson: classes) { classifier = 'sources' from sourcesets.main.allsource } } task javadocjar(type: jar, dependson: javadoc) { classifier = 'javadoc' from javadoc.destinationdir } artifacts { archives javadocjar archives 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 { repo = bintrayrepo name = bintrayname desc = librarydescription websiteurl = siteurl vcsurl = giturl licenses = alllicenses publish = true publicdownloadnumbers = true version { desc = librarydescription gpg { // optional gpg encryption. default is false. sign = false //passphrase = properties.getproperty("bintray.gpg.password") } } } }
local.properties
the library build.gradle file above referenced some values in the local.properties file. we need to add those now. this file is located in the root of your project. it should be included in .gitignore. (if it isn't then add it.) the point of putting your username, api key, and encryption password here is so that it won't be publicly visible in version control.
## this file is automatically generated by android studio. # do not modify this file -- your changes will be erased! # # this file should *not* be checked into version control systems, # as it contains information specific to your local configuration. # # location of the sdk. this is only used by gradle. # for customization when using a version control system, please read the # header note. sdk.dir=/home/yonghu/android/sdk # add these lines (but change the values according to your situation) bintray.user=myusername bintray.apikey=1f2598794a54553ba68859bb0bf4c31ff6e71746
there is a warning about not modifying this file but it seems to work well anyway. here is how you get the values:
- bintray.user: this is your bintray username.
- bintray.apikey: go to edit profile in the bintray menu and choose api key. copy it from here.
open a terminal and go to your project's root folder. or just use the terminal in android studio.
enter the following commands
./gradlew install ./gradlew bintrayupload
if everything is set up right it should upload your library to bintray. if it fails then google the solution. (i had to update my jdk the first time i tried.)
go to your account in bintray and you should see the library entered under your repository.
in your library in bintray there is an add to jcenter button.
click it and send your request. if you are approved (which takes a day or two), then your library will be a part of jcenter and developers around the world can add your library to their projects simply by adding one line to the app build.gradle dependencies block.
dependencies { compile 'com.example:my-library:1.0.0' }
congratulations!
- you may want to add pgp encryption, especially if you are linking it to maven central. (jcenter has replaced maven central as the default in android studio, though.) see this tutorial for help with that. but also read this from bintray.
you will eventually want to add a new version to your bintray/jcenter library. see this answer to directions on how to do it.
- how to distribute your own android library through jcenter and maven central from android studio
- creating and publishing an android library