570

I'm on Android Studio 4.2.2. I created a new project and haven't added anything to the starter code and whenever I click build or run, I get this error:

Installed Build Tools revision 31.0.0 is corrupted. Remove and install again using the SDK Manager.

I've looked at other posts' suggestions, but neither of those solutions worked. Here's what I've tried:

  1. SDK Manager → SDK Tools → check "Show package details", uncheck 31.0.0, and click "Apply" → Uninstall 31.0.0 → check 31.0.0 and reinstall it
  2. In SDK Manager, deselect 31.0.0 and try installing an older version (e.g., I've tried 30.0.3) and update "buildToolsVersion" in build.gradle to the installed version
  3. Went to Project StructureProperties and verified that 31.0.0 is selected for "Build Tools Version" and "Compiled SDK Version"
  4. Manually remove the stuff in the build-tools folder; i.e., rm -rf /path/to/android/sdk/build-tools/31.0.0 (it doesn't end in "-rc" like some other posts have described)
  5. Restart Android Studio
  6. Reinstall Android Studio

I'm an Android noob just trying to set up a Hello, World! project, and it really shouldn't be this hard.

9
  • I would add to this that I can't seem to downgrade to Build Tools 30.0 which would be my go-to solution to an issue like this. Jul 15, 2021 at 3:17
  • 55
    Figured it out, uncheck "Show Package Details" and then you can select a lower version. If you're not building for android 12 (and you probably aren't yet), you can uncheck "31.0.0" and check "30.0.3". After that, go into the build.gradle in your app and change buildToolsVersion "31.0.0" to buildToolsVersion "30.0.3" Jul 15, 2021 at 3:21
  • 44
    So the real problem is 31.0.0 is actually corrupted Jul 16, 2021 at 5:20
  • 7
    that is weird because I did a fresh installation of android studio and got the same problem
    – gzinho
    Jul 16, 2021 at 23:27
  • 1
    Use the latest Android Studio Beta, it will solve this issue. Also, if you're still here OP, please don't flag a workaround as correct answer, but rather the actual solution.
    – joe1806772
    Jul 28, 2021 at 12:52

41 Answers 41

1479

First of all, I faced this issue in Android Studio 4.2.2 and you do not need to downgrade the SDK build tool from 31 to 30 or change compile SDK version.

The main problem is the two files missing in SDK build tool 31 that are:

  1. dx.bat
  2. dx.jar

The solution is that these files are named d8 in the file location so changing their name to dx will solve the error.

The steps are below.

For Windows

  1. go to the location

     "C:\Users\user\AppData\Local\Android\Sdk\build-tools\31.0.0"
    
  2. find a file named d8.bat. This is a Windows batch file.

  3. rename d8.bat to dx.bat.

  4. in the folder lib ("C:\Users\user\AppData\Local\Android\Sdk\build-tools\31.0.0\lib")

  5. rename d8.jar to dx.jar

Remember AppData is a hidden folder. Turn on hidden items to see the AppData folder.

For macOS or Linux

Run the following in the Terminal:

# change below to your Android SDK path
cd ~/Library/Android/sdk/build-tools/31.0.0 \
  && mv d8 dx \
  && cd lib  \
  && mv d8.jar dx.jar

Now run your project.

17
  • 35
    Dug too deep to find an answer that doesn't require me to downgrade the API level. Instead of copying these files, I've created symlinks. This can be easily done from a command line: mklink %ANDROID_HOME%\build-tools\31.0.0\dx.bat %ANDROID_HOME%\build-tools\31.0.0\d8.bat && mklink %ANDROID_HOME%\build-tools\31.0.0\lib\dx.jar %ANDROID_HOME%\build-tools\31.0.0\lib\d8.jar. It's still a workaround though, but the cleanest one.
    – itachi
    Jul 19, 2021 at 9:09
  • 71
    This should be the accepted answer. On Mac: cd ~/Library/Android/sdk/build-tools/31.0.0 && mv d8 dx && cd lib && mv d8.jar dx.jar. Jul 28, 2021 at 1:17
  • 11
    cd $ANDROID_HOME/build-tools/31.0.0; ln -s d8 dx; ln -s lib/d8.jar lib/dx.jar;
    – Joost
    Sep 9, 2021 at 13:08
  • 4
    Unfortunately no longer seems to work on Mac (Studio 2020.3.1 patch 2). There's only the d8 file, and renaming it to dx had no effect. There's no d8.jar file in that location.
    – Oscar
    Sep 24, 2021 at 2:52
  • 4
    wtf Android/Google, this is such a silly issue and you have so many well-paid engineers—I shouldn't have to ask, but why is this silliness still causing anyone grief?!
    – LyrePyre
    Feb 9, 2023 at 3:34
129

The same problem was encountered and solved with a few line changes.

Check the Project code panel, and go to Gradle Scriptsbuild.gradle file,

  1. Change three places from 31 to 30: compileSdkVersion, buildToolsVersion, and targetSdkVersion
  2. You'll notice a lightbulb hit occurring on modified lines. Click and choose sync [to version 30]. Android Studio will automatically download BuildTool V30 and change project settings.

Now run the app. It works for me.

5
  • 2
    If we are downgrading the build tools, it will work accepted but will not work with 31.0.0 Jul 17, 2021 at 7:21
  • 44
    Your answer is fine as a workaround. But it does not solve the actual problem if you have to work with SDK31 and build tools 31.0.0. In build tools 31.0.0, the following files "dx.bat" and "libs/dx.jar" are missing. The latest working build tools version was 31.0.0-rc4. To solve the problem in build tools 31.0.0, just copy the mentioned files from 31.0.0-rc4. However, even this is nothing more than a workaround. But at least this lets you work with build tools 31.0.0.
    – gal
    Jul 18, 2021 at 10:49
  • @gal Everything works all good on local, but my CI seems to be complaining that it Failed to find Build Tools revision 31.0.0-rc4
    – CyberShark
    Aug 1, 2021 at 13:48
  • 1
    @CyberShark That makes sense. If you work with other developers who all have to build the same project, then all of them need a working environment. So if you made a hack by copying the files "dx.bat" and "libs/dx.jar" from another build tools folder to build tools 31.0.0, then all others who work in the team must do the same. At the end, it's Google who should fix it in the next build tools version.
    – gal
    Aug 2, 2021 at 15:08
  • This does not answer the question, it only provides a probably unacceptable tradeoff. Look at the highest voted answer for the working solution. Sep 7, 2021 at 22:05
65

The point is not to downgrade target API level, but to build exactly for API level 31 to prepare and test an app for Android 12!

It looks like DX is removed from SDK in favor of D8.

It looks like that Android Gradle plugin 4.x is not aware of that.

At the moment I see only two solutions:

  1. To stay with AGP 4.x, one should copy DX from 30.0.3 to 31.0.0
  2. Upgrade AGP to 7.x
3
  • 11
    To clarify, it appears (from my testing) that Build Tools 31 and up are incompatible with AGP 4.x and below. With AGP 4.x, stay with Build Tools 30.0.3 (it seems to build with SDK 31 fine). Once you have upgraded to AGP 7.x (and Gradle 7), you can use Build Tools 31 or 32 without any issues.
    – big_m
    Dec 14, 2021 at 14:14
  • Unfortunately, upgrading AppCompat to 1.4 requires to compile against API 31. Dec 21, 2021 at 7:56
  • 1
    I have AGP 7.2.1 and had the same issue which was resolved with file renaming :-(
    – hanzolo
    Jun 29, 2022 at 17:07
59

The solution for Mac is pretty similar to Windows, yet not fully conclusive from reading the Windows solution. The paths and file names are different, but the problem is basically the same.

  • Open the terminal application and type the commands below
  • Hit Enter after every command line you type to execute the command
  • Type cd /Users/admin/Library/Android/sdk/build-tools/
  • Attention: Your user directory name may be different from "admin"
  • Navigate to the corresponding version: type cd 31.0.0
  • Type cp d8 dx
  • Type cd lib
  • Type cp d8.jar dx.jar

This fixed my issues on macOS v10.13.6 (High Sierra).

2
  • 4
    that is awesome real solution. this worked for me with macOS Monterey IntelliJ IDEA ultimate API31. Downgrading to lower api is not solution.
    – withoutOne
    Nov 16, 2021 at 19:51
  • 3
    works on ventura as well !, thanks a lot ! Jan 9, 2023 at 9:12
23

After changing these settings, it seems to work fine. I downloaded SDK version 30 from SDK Manager.

android {
    compileSdkVersion 30
    buildToolsVersion "30.0.3"
    defaultConfig {
        applicationId "com.anurag.myapplication"
        minSdkVersion 23
        targetSdkVersion 30
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
1
  • Does not work if dependent library uses 31 or more as minSDK like androidx.appcompat:appcompat:1.6.1 Dec 10, 2023 at 4:38
21

In order to fix the issue, firstly go to the following location:

C:\Users\User\AppData\Local\Android\Sdk\build-tools\31.0.0

Then find the file d8 (Windows batch file) and rename it to dx.

Then go to:

C:\Users\User\AppData\Local\Android\Sdk\build-tools\31.0.0\lib

Then find the file d8 (Executable Jar File) and rename is to dx.

Your problem will be solved now.

0
17

For those who are using Azure DevOps and require things to work with 30.0.3 you need to uninstall version 31.0.0

I added this to my pipeline to make my builds work again.

  - bash: |
      $ANDROID_SDK_ROOT/tools/bin/sdkmanager --uninstall 'build-tools;31.0.0'

The environment variable $ANDROID_SDK_ROOT is in the preset variables

2
14

Version 31.0.0 itself is corrupt, and we need to downgrade to 30.

Steps I followed for the same:

  1. Open project structure → press Ctrl + Alt + Shift + S

  2. Go to Moduleproperties → *Compiled SDK Version: 30 Build Tools Version: 30.0.2

  3. Go to Default ConfigTarget SDK Version: 30

  4. Apply and Close.

  5. Menu ToolsSDK Manager

  6. Uncheck API 31 to uninstall and check Android 11.0(R) to install (30.0.3) in my case.

  7. Apply.

0
13

Change your Gradle build from:

android {
    compileSdkVersion 31
    buildToolsVersion '31.0.0'

    defaultConfig {
        applicationId "com.example.eg"
        minSdkVersion 23
        targetSdkVersion 31
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

to:

android {
    compileSdk 31

    defaultConfig {
        applicationId "com.example.eg"
        minSdk 23
        targetSdk 31
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

This will work.

3
  • Do you meant to say that no need to mention the build tools version here after? Jul 27, 2022 at 11:47
  • yes @ThinkAndCode Aug 10, 2022 at 10:57
  • Then how come Android Studio understands that which build tool version to be used? Aug 10, 2022 at 12:55
11

If you carefully look at the logs you'll see:

Build-tool 31.0.0 is missing DX at path-to-sdk\build-tools\31.0.0\dx.bat

You can try copying it from previous versions, but that won't lend well if you have to tell your entire team to do the same and it still fails on your server pipeline. This happened to me on 31.0.0-rc5 release as well.

2
  • In my case, not only dx.bat, but dx.jar too which placed in /build-tools/lib; Nov 7, 2021 at 8:52
  • build-tools path on MacOS: /Users/username/Library/Android/sdk Nov 7, 2021 at 9:00
9

M1 Macbook solution:

go to Terminal:

Step1 : cd ~/Library/Android/sdk/build-tools/31.0.0

Step2: mv d8 dx

Step3a: cd lib

Step3b: mv d8.jar dx.jar

Step 4: Rebuild your project in Android studio. or simply run your project from android studio

Note if you are running a different version other than 31.0.0 then change the version in the step 1 command line.

7

In file build.gradle (Module: HelloWorld.app):

  • compileSdkVersion 30
  • buildToolsVersion "30.0.0"
  • targetSdkVersion 30

Change the above configuration to this:

Enter image description here

7

I answered this question over here, but I'll copy/paste the answer as it's relevant:


As pointed out in other issues, the problem is that dx (or dx.bat) is no longer available. This was a purposeful change announced in 2018.

Suggested resolutions of renaming d8 to dx or copying it from build tools 30.0.0 will resolve the issue, but dx isn't likely to return. So you'll be stuck patching every build tools installation on every developer's machine going forward.

The more forward-compatible solution is to upgrade your Android Gradle plugin. This isn't as straightforward as just changing the number in Gradle, but I find that Android Studio's upgrade process works well for my projects. If you open your project-level build.gradle file, open up the quick fixes menu from the lightbulb over your

dependencies{
    classpath 'com.android.tools.build:gradle:...'

section. From here, choose to upgrade to the newest possible version (not just 4.x in my case).

Quick fixes menu open. Option to "Invoke Upgrade Assistant for upgrade to 7.1.3" selected

Then I run the upgrade steps for literally everything:

Upgrade assistant window open with all items checked.

My issue was Unity-specific though: I needed to use the system Android SDK rather than the one built in, but Unity itself likes to regenerate these build files and will just grab the newest buildtools it can find. To reduce manual steps and to avoid having to export my project, I instead chose to generate my module-level build.gradle files from my "Player Settings>Publishing Settings" window:

Publishing Setting section open with "Custom Main Gradle Template" and "Custom Launcher Gradle Template" open

Both files will have a line that looks like:

buildToolsVersion '**BUILDTOOLS**'

Which you can replace with:

buildToolsVersion '30.0.0'

From Unity, this lets me build and deploy projects as I had before without modifying the buildtools installation.

7

enter image description here

In many blogs, you will find that the solution is to downgrade to the API 30, however, if you want to experiment with the API 31, downgrading isn't a real solution. Fortunately, there's a way to make the build tools work for API 31. The cause of the corruption of the build tools for API 31 is 2 missing files:

  • dx.bat
  • dx.jar

These files exist however with another name, specifically:

  • d8.bat
  • d8.jar

So the workaround to prevent this exception from appearing is either to copy the mentioned files that exist with the new names or create a symbolic link (shortcut in Windows) and it will magically work. This will work in all the operative systems, however the way to do it will depend of every platform.

Windows You can do this manually or with the command prompt, to create the symlink for dx.bat (remember to replace the SDK directory with yours):

mklink C:\Users\username\AppData\Local\Android\Sdk\build-tools\31.0.0\dx.bat C:\Users\username\AppData\Local\Android\Sdk\build-tools\31.0.0\d8.bat

And the command to create the symlink for dx.jar:

mklink C:\Users\username\AppData\Local\Android\Sdk\build-tools\31.0.0\lib\dx.jar C:\Users\username\AppData\Local\Android\Sdk\build-tools\31.0.0\lib\d8.jar

After copying and renaming the mentioned files or running the previous commands to create the symbolic links (shortcuts), you will have new 2 files in the build-tools and build-tools/lib directory:

enter image description here

MacOS and Linux If you are using MacOS or Linux, running the following command in the terminal will do the trick (it switches to the build tools directory and then moves the d8 to dx and d8.jar to dx.jar):

cd ~/Library/Android/sdk/build-tools/31.0.0 && mv d8 dx && cd lib && mv d8.jar dx.jar

Try to build your project in Android Studio once again and the exception shouldn't appear anymore!

1
  • I tried mklink. it doesn't work.
    – PangoSea
    Apr 25, 2023 at 8:49
6

I downloaded dx.bat file from https://android.googlesource.com/platform/dalvik/+/master/dx/etc/dx.bat.

I put it in \build-tools\31.0.0 and then downloaded the dx.jar file (which was also missing, by the error message I got) from http://www.java2s.com/Code/Jar/d/Downloaddxjar.htm.

I put it into directory \build-tools\31.0.0\lib.

Then it worked.

0
5

I don't have enough reputation for commenting yet, but there is the solution with symbolic links for Windows, and I'd like to add that it works for macOS, too.

That's the command for Mac's terminal:

ln %ANDROID_HOME%/sdk/build-tools/31.0.0/d8 %ANDROID_HOME%/sdk/build-tools/31.0.0/dx && ln %ANDROID_HOME%/sdk/build-tools/31.0.0/lib/d8.jar %ANDROID_HOME%/sdk/build-tools/31.0.0/lib/dx.jar
5

You don't need to specify android.buildToolsVersion from Build Tools 27.0.3 or higher.

Build Tools 27.0.3 or higher. Keep in mind, you no longer need to specify a version for the build tools using the android.buildToolsVersion property—the plugin uses the minimum required version by default.

Source (Developers.Android)

5
  1. In Finder/File explorer, go to Android's build-tools folder. In Mac, it's at /Users/<username>/Library/Android/sdk/build-tools.
  2. Rename d8.exe to dx.exe
  3. Go inside lib folder
  4. Rename d8.jar to dx.jar
4

First of all, guys if you're facing these types of issues you can try the solution where we need to shift 31 to 30. And after that some important steps are required to do: Step:

  1. To open project structure > Press Ctrl+Alt+Shift+S
  2. Open Module > properties > Compiled Sdk Version: 30 Build Tools Version: 30.0.2
  3. Click on Default Config > Target SDK Version: 30

After that, your task is not, in some cases still, you can see this configuration is not accepted, you need to do these steps also:

  1. Go to the top Right area, and click on SDK Manager Icon.

  2. Select Android SDK > image 1 where you need to tick all Android version which you need*

  3. After tick Click OK and then install.

  4. Android SDK > SDK Tool > right down side > show Package detail > tick on 30.0.2 option and then install. image 2 > select 30.0.2

5) Now done click OK install> apply your good to go.

4

To uninstall only Build-Tools 31.0.0 from Android Studio

Navigate to:
Configure -> SDK Manager -> SDK Tools [tab] -> Show Package Details [check box]
click on Android SDK Build-Tools 31
uncheck 31.0.0
and Hit OK

enter image description here

3

I unistalled and installed the 31.0.0 package and still it was showing the error.

I used RC2 build tools and it compiled and ran fine without downgrading to SDK version 30.

In file app/build.gradle:

buildToolsVersion "31.0.0-rc2"
3

My Android Studio Arctic Fox 2020.3.1 Patch 2
with
downloaded Android 12 and Android SDK Build-Tools 31 in Android SDK

working with buildToolsVersion "31.0.0"

build.gradle (Project)

buildscript {
    repositories {
        google()
        mavenCentral()
    }
    dependencies {
        classpath "com.android.tools.build:gradle:7.0.2"
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.5.30"
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

build.gradle (Module)

plugins {
    id 'com.android.application'
    id 'kotlin-android'
}

android {
    compileSdk 31
    buildToolsVersion "31.0.0"

    defaultConfig {
        applicationId "com.example.android12"
        minSdk 21
        targetSdk 31
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
    kotlinOptions {
        jvmTarget = '1.8'
    }
}

dependencies {

    implementation 'androidx.core:core-ktx:1.6.0'
    implementation 'androidx.appcompat:appcompat:1.3.1'
    implementation 'com.google.android.material:material:1.4.0'
    implementation 'androidx.constraintlayout:constraintlayout:2.1.0'
    testImplementation 'junit:junit:4.+'
    androidTestImplementation 'androidx.test.ext:junit:1.1.3'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
}

gradle-wrapper.properties

#Fri Sep 10 13:52:36 ICT 2021
distributionBase=GRADLE_USER_HOME
distributionUrl=https\://services.gradle.org/distributions/gradle-7.0.2-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
3

I was getting the same error for API 33. I tried several solutions answered above but what worked for me was uninstalling all the API and dependencies of version 33.0.0 and reinstalling them back.

It takes some time but it worked. Here's how you can uninstall and install them back in Android Studio - https://stackoverflow.com/a/54851554/7584658

Hope that helps. Thanks

2

Press Ctrl+Alt+Shift+S to open project structure. The select Module from the left.

Open Properties tab and change the followings:
Compiled Sdk Version: 30
Build Tools Version: 30.0.2

After that open Default Config tab and change:
Target SDK Version: 30

2

I unchecked 31 under the SDK Manager, clicked Android 11.0(R) to revert back to 30, and updated the Build Gradle (project) to change compileSdkVersion and targetSdkVersion from 31 to 30.

I also had to update buildToolsVersion to "30.0.2" instead of 30. Now it works.

2

Try to reinstall the SDK 31 again and restart Android Studio, it should work. Otherwise, from the SDK Manager, install the SDK 30 to the System and configure the app build Gradle file as

compileSdkVersion 30
buildToolsVersion "30.0.0"
defaultConfig {
    targetSdkVersion 30
}
2

It's a conflict issue with Android studio and SDK 31.

Convert your build.gradle file like this:

android {
    compileSdkVersion 30
    buildToolsVersion "30.0.3"

    defaultConfig {
        applicationId "com.example.app"
        minSdkVersion 21
        targetSdkVersion 30
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
}
2

There are so many wrong and misleading answers here.

The only thing you should really do is to install the latest Android Studio Beta version if you're using the Beta SDK. With the latest Android Studio Beta comes support for the latest AGP, which correctly supports SDK 31.

2

In build.gradle(Module) file. Change the following settings.

android {
    compileSdkVersion 30
    buildToolsVersion "30.0.0"

    defaultConfig {
        applicationId "com.recycleview.mvvm"
        minSdkVersion 16
        targetSdkVersion 30
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

enter image description here

2

I had this same issue using SDK Build tools 34.0.0. My fix was to update gradle:

gradle-wrapper.properties:

distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-all.zip

android/build.gradle:

       classpath("com.android.tools.build:gradle:7.3.1")

Not the answer you're looking for? Browse other questions tagged or ask your own question.