sadegh
sadegh

Reputation: 1642

Ionic build Android error when downloading Gradle

I'm very new to the Ionic framework :)

>npm install -g cordova
>npm install -g ionic
>ionic start test blank
>cd test
>ionic platform add android

When I use '>ionic build android' start download gradle, but I can't download and get an error.

What caused this error and how can I fix it?!

I download Gradle and install it on a PC, but it wants to download again. Can I add Gradle to a project offline?

C:\Users\LENOVO2014\test>ionic build android
running cordova build android
Running command: "C:\Program Files\nodejs\node.exe" C:\Users\LENOVO2014\myApp\ho
oks\after_prepare\010_add_platform_class.js C:\Users\LENOVO2014\myApp
add to body class: platform-android
Running command: C:\Users\LENOVO2014\myApp\platforms\android\cordova\build.bat
ANDROID_HOME=D:\program\Programing\Android\sdk
JAVA_HOME=C:\Program Files\Java\jdk1.8.0_31
Running: C:\Users\LENOVO2014\myApp\platforms\android\gradlew cdvBuildDebug -b C:
\Users\LENOVO2014\myApp\platforms\android\build.gradle -Dorg.gradle.daemon=true
Downloading http://services.gradle.org/distributions/gradle-2.2.1-all.zip
................................................................................
................................................................................
................................................................................
............................................
Exception in thread "main" java.lang.RuntimeException: java.net.SocketException:
 Connection reset
        at org.gradle.wrapper.ExclusiveFileAccessManager.access(ExclusiveFileAcc
essManager.java:78)
        at org.gradle.wrapper.Install.createDist(Install.java:47)
        at org.gradle.wrapper.WrapperExecutor.execute(WrapperExecutor.java:129)
        at org.gradle.wrapper.GradleWrapperMain.main(GradleWrapperMain.java:48)
Caused by: java.net.SocketException: Connection reset
        at java.net.SocketInputStream.read(SocketInputStream.java:189)
        at java.net.SocketInputStream.read(SocketInputStream.java:121)
        at java.io.BufferedInputStream.read1(BufferedInputStream.java:284)
        at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
        at sun.net.www.MeteredStream.read(MeteredStream.java:134)
        at java.io.FilterInputStream.read(FilterInputStream.java:133)
        at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(Http
URLConnection.java:3335)
        at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(Http
URLConnection.java:3328)
        at org.gradle.wrapper.Download.downloadInternal(Download.java:63)
        at org.gradle.wrapper.Download.download(Download.java:45)
        at org.gradle.wrapper.Install$1.call(Install.java:60)
        at org.gradle.wrapper.Install$1.call(Install.java:47)
        at org.gradle.wrapper.ExclusiveFileAccessManager.access(ExclusiveFileAcc
essManager.java:65)
        ... 3 more

C:\Users\LENOVO2014\myApp\platforms\android\cordova\node_modules\q\q.js:126
                    throw e;
                          ^
Error code 1 for command: cmd with args: /s /c "C:\Users\LENOVO2014\myApp\platfo
rms\android\gradlew cdvBuildDebug -b C:\Users\LENOVO2014\myApp\platforms\android
\build.gradle -Dorg.gradle.daemon=true"
ERROR building one of the platforms: Error: C:\Users\LENOVO2014\myApp\platforms\
android\cordova\build.bat: Command failed with exit code 1
You may not have the required environment or OS to build this project
Error: C:\Users\LENOVO2014\myApp\platforms\android\cordova\build.bat: Command fa
iled with exit code 1
    at ChildProcess.whenDone (C:\Users\LENOVO2014\AppData\Roaming\npm\node_modul
es\cordova\node_modules\cordova-lib\src\cordova\superspawn.js:131:23)
    at ChildProcess.emit (events.js:110:17)
    at maybeClose (child_process.js:1015:16)
    at Process.ChildProcess._handle.onexit (child_process.js:1087:5)

Upvotes: 73

Views: 90002

Answers (18)

Gru
Gru

Reputation: 85

I used every thing above but nothing was working and then I did this and boom it worked..!

enter image description here

Here is what I did: 1. open cmd from your project 2. goto https://services.gradle.org/distributions/ click on the version you need , right click and copy link. 3. Once done set the variable : set CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL=https://services.gradle.org/distributions/gradle-2.2.1-all.zip 4. Good to go!

enter image description here

Upvotes: 0

Sachin Mishra
Sachin Mishra

Reputation: 1183

As far as ionic development concern,you will have to modified the distributionURL in GradleBuilder.js with below mentioned URL.

/android/cordova/lib/builders/GradleBuilder.js

var distributionUrl = process.env['CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL'] || 'https://services.gradle.org/distributions/gradle-2.14.1-all.zip';

Upvotes: 0

A.B
A.B

Reputation: 20445

Since the solution posted above needs to include .zip into folder that is about 55MB

You can also force CLI to use Ant instead of gradle during a build with the following command:

cordova build android -- --ant

Upvotes: 52

Somnath
Somnath

Reputation: 406

Download JDK version 8 and remove all existing versions.

And update Ionic.

I hope your problem will be solved.

Upvotes: -3

Navin a.s
Navin a.s

Reputation: 416

This is because of a Gradle error.

Download the file http://services.gradle.org/distributions/gradle-2.14.1-all.zip and extract it in any of directory and set the path by open cmd and enter: setx path (extracted directory)/bin

After that, reopen cmd and check whether Gradle is works or not by issuing gradle -v. It shows the Gradle version output. Now the error is fixed; run ionic build android.

Upvotes: -1

Emad Dehnavi
Emad Dehnavi

Reputation: 3451

I had the same problem, and it was solved with uninstalling build-tools 24, and installing build-tools 23 from SDK Manager.

Upvotes: 3

Theophane Fotso
Theophane Fotso

Reputation: 353

It sounds like Windows Defender or some other antivirus system is messing up with your install. So temporarily deactivate your firewall and re-run the command:

ionic build android (or ios)

At the end you have the message BUILD SUCCESSFUL...

Upvotes: 0

garrettmac
garrettmac

Reputation: 8585

All answers here are all saying the same thing when this could be done easier than the top answer. Updating your Android SDK should fix it, and you can do it with this one line from the terminal:

android update sdk --no-ui --all --filter "extra-android-m2repository"

or

android update sdk --no-ui --filter extra

Also see this repos issue (it's the essentially same problem).

But after you do that rebuild, and it should work.

Upvotes: 0

Jeff Woodard
Jeff Woodard

Reputation: 647

I ran into this issue as our network proxy is blocking the download of the zip file. Here's what I found:

NOTE: this differs from the "accepted" answer in that we aren't modifying Cordova's library directly. This is far less prone to "error" or being overwritten when you run ionic state restore

  1. Download gradle - http://services.gradle.org/distributions/gradle-2.2.1-all.zip

  2. Put this file in platforms/android/gradle. However, if you're integrating this into your build process, you may want to stick it somewhere less volatile and add a step to copy the file into that location.

  3. Set the environment variable CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL to ../gradle-2.2.1-all.zip

    • linux/osx: add export CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL="../gradle-2.2.1-all.zip" to your ~/.bashrc file
    • windows: setx CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL ../gradle-2.2.1-all.zip
  4. Run ionic build android

Upvotes: 25

seaguest
seaguest

Reputation: 2630

There seems to be a problem for the previous solutions. At least none of them worked for me, and I just changed it to:

var distributionUrl = 'http://localhost/gradle-2.2.1-all.zip';

Then it works. I don't know why they all add "distributionUrl=" as follows (this doesn't work for me):

 var distributionUrl = 'distributionUrl=http\\://localhost/gradle-2.2.1-all.zip';

BTW, I am using ionic 2.

Pay attention to the path if you don't want to use localhost. It will automatically add myApp/platforms/android/gradle/wrapper before distributionUrl, for example if you put gradle-2.2.1-all.zip in the myApp/platforms/android/gradle directory, then you need to set:

var distributionUrl = '../gradle-2.2.1-all.zip';

Upvotes: 4

Tapan
Tapan

Reputation: 39

I have faced the same problem recently, and I searched here and there.

Finally for the latest build I found the solution.

After "ionic platform add android" command, go to platforms/android/cordova/lib/builders/GradleBuilder.js

Search for

http\\://services.gradle.org/distributions/gradle-2.2.1-all.zip

and change it to

http\\://downloads.gradle.org/distributions/gradle-2.2.1-all.zip

Upvotes: 3

user5880697
user5880697

Reputation: 101

Cordova 6.0.0 / Visual Studio Code 0.10.6

TL;DR

Manually download http://services.gradle.org/distributions/gradle-2.2.1-all.zip.

Place it in appName\platforms\android\gradle\

set CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL=..\gradle-2.2.1-all.zip

Start code and compile.

Explanation:

GradleBuilder.js sets distributionUrl as follows:

var distributionUrl = process.env['CORDOVA_ANDROID_GRADLE_DISTRIBUTION_URL'] || 'http\://services.gradle.org/distributions/gradle-2.2.1-all.zip';

Script runs in appName\platforms\android\gradle\wrapper

Output is:

Downloading file://appname/platforms/android/gradle/gradle-2.2.1-all.zip

Upvotes: 10

Priyanka
Priyanka

Reputation: 15

Updating the Android platform did the trick for me:

  • Cordova platform update Android
  • Cordova prepare,
  • Cordova compile and finally
  • Cordova build

Upvotes: -1

Lucas Massuh
Lucas Massuh

Reputation: 221

Another option from command line is to run $ export JAVA_OPTS="-Dhttp.proxyHost=proxy-url.com -Dhttp.proxyPort=911 -Dhttps.proxyHost=secure-proxy-url.com -Dhttps.proxyPort=911"before the cordova build command.

Upvotes: 14

Mohsen
Mohsen

Reputation: 4643

I am using Ionic version 1.7.14 and the distributionUrl found in the following file. myApp/platforms/android/cordova/lib/builders/GradleBuilder.js.

I had to point the locally downloaded gradle as specified in this answer.

I had the same problem. I added gradle to my project offline.

After downloading gradle from issued link (here is http://services.gradle.org/distributions/gradle-2.2.1-all.zip) paste it in somewhere likes myApp\platforms\android\gradle\gradle-2.2.1-all.zip and in build.js from myApp\platforms\android\cordova\lib\build.js find this:

var distributionUrl = 'distributionUrl=http\\://services.gradle.org/distributions/gradle-2.2.1-all.zip';

And replace it with your own file's location:

var distributionUrl = 'distributionUrl=../gradle-2.2.1-all.zip';

Upvotes: 109

Ben Morris
Ben Morris

Reputation: 282

If you require to use a proxy on your network then add a gradle.properties file in %USER_HOME%/.gradle with the below but replacing the values with your proxy details. This worked for me.

gradlePropertiesProp=gradlePropertiesValue
sysProp=shouldBeOverWrittenBySysProp   
envProjectProp=shouldBeOverWrittenByEnvProp  
systemProp.system=systemValue    
systemProp.http.proxyHost=myproxy.com    
systemProp.http.proxyPort=8080    
systemProp.http.nonProxyHosts=\*.mydomain.com|localhost   
systemProp.https.proxyHost=myproxy.com    
systemProp.https.proxyPort=8080    
systemProp.https.nonProxyHosts=\*.mydomain.com|localhost

Upvotes: 9

sid1337
sid1337

Reputation: 61

Hi all I had the same issue.

In the platforms\android\cordova\lib\build.js file, I changed

var distributionUrl = 'distributionUrl=http\\://services.gradle.org/distributions/gradle-2.2.1-all.zip';

to

var distributionUrl = 'distributionUrl=http://services.gradle.org/distributions/gradle-2.2.1-all.zip';

and it worked.

Upvotes: 6

wmac
wmac

Reputation: 1063

Alternatively, if you have a web server on your localhost, download and put the gradle (exactly the tested version, i.e. http://downloads.gradle.org/distributions/gradle-2.2.1-all.zip at the time of this post) in the www root and change the platforms\android\cordova\lib\build.js file in your application directory to this one:

 var distributionUrl = 'distributionUrl=http\\://localhost/gradle-2.2.1-all.zip';

Changing the URL to a local file (not an http address) would not work for me under windows and it would complain that the URL has an unknown protocol.

Upvotes: 3

Related Questions