2015-09-07 59 views
7

我的項目使用Android NDK,當我構建時,出現上述錯誤。錯誤:執行任務'ndkBuild'失敗。 >進程'命令'Android sdk ndk-bundle/ndk-build.cmd''以非零退出值2完成

  • 我安裝了最新的Java版本的Android NDK和Android SDK
  • 使用Windows 8和Android工作室 我在local.properties

ndk.dir=C\:\\Users\\Jang\\AppData\\Local\\Android\\sdk\\ndk-bundle 
sdk.dir=C\:\\Users\\Jang\\AppData\\Local\\Android\\sdk 

添加SDK和NDK

這是我的build.gradle:

apply plugin: 'com.android.application' 

android { 
    compileSdkVersion 21 
    buildToolsVersion "23.0.0" 

    defaultConfig { 
     applicationId "uk.digitalsquid.netspoofer" 
     minSdkVersion 10 
     targetSdkVersion 21 
    } 

    buildTypes { 
     release { 
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt' 
     } 
    } 

    sourceSets.main.jni.srcDirs = [] 
} 

dependencies { 
    compile 'com.android.support:support-v4:23.0.0' 
    compile 'com.google.android.gms:play-services:7.8.0' 
    compile 'org.jsoup:jsoup:1.8.3' 
    compile project(':androidsupportv4preferencefragment') 
} 

tasks.withType(JavaCompile) { 
    compileTask -> compileTask.dependsOn ndkLibsToJar, ndkBinariesToJar, ndkBinariesToJar16, ndkDataToJar 
} 

task ndkLibsToJar(type: Zip, dependsOn: 'ndkBuild', description: 'Create a JAR of the native libs') { 
    destinationDir new File(buildDir, 'libs') 
    baseName 'ndk-libs' 
    extension 'jar' 
    from(new File(buildDir, 'libs')) { 
     include '**/*.so' 
    } 
    into 'lib/' 
} 


task ndkBinariesToJar(type: Zip, dependsOn: 'ndkBuild', description: 'Create a JAR of the native binaries') { 
    destinationDir new File(buildDir, 'libs') 
    baseName 'ndk-binaries' 
    extension 'jar' 
    from(new File(buildDir, 'libs')) { 
     include '**/arp-scan' 
     include '**/arpspoof' 
     include '**/iptables' 
    } 
    into 'assets/binaries/android-9' 
} 

task ndkBinariesToJar16(type: Zip, dependsOn: 'ndkBuild16', description: 'Create a JAR of the native binaries for Android 16+') { 
    destinationDir new File(buildDir, 'libs') 
    baseName 'ndk-binaries-16' 
    extension 'jar' 
    from(new File(buildDir, 'android-16/libs')) { 
     include '**/arp-scan' 
     include '**/arpspoof' 
     include '**/iptables' 
    } 
    into 'assets/binaries/android-16' 
} 


task ndkDataToJar(type: Zip, dependsOn: 'ndkBuild', description: 'Create a JAR of the native data') { 
    destinationDir new File(buildDir, 'libs') 
    baseName 'ndk-data' 
    extension 'jar' 
    from(new File('src/main/jni/arp-scan')) { 
     include '**/ieee-iab.txt' 
     include '**/ieee-oui.txt' 
     include '**/mac-vendor.txt' 
    } 
    into 'assets/data/' 
} 


task ndkBuild(type: Exec, description: 'Compile JNI source via NDK') { 
    def ndkDir = project.plugins.findPlugin('com.android.application').sdkHandler.getNdkFolder() 
    println(ndkDir) 
    commandLine "$ndkDir/ndk-build.cmd", 
      'NDK_PROJECT_PATH=build', 
      'APP_BUILD_SCRIPT=src/main/jni/Android.mk', 
      'NDK_APPLICATION_MK=src/main/jni/Application.mk', 
      '-j1' 
} 

task ndkBuild16(type: Exec, description: 'Compile JNI source via NDK for Android 16+') { 
    def ndkDir = project.plugins.findPlugin('com.android.application').sdkHandler.getNdkFolder() 
    println(ndkDir) 
    commandLine "$ndkDir/ndk-build.cmd", 
      'NDK_PROJECT_PATH=build/android-16', 
      'APP_BUILD_SCRIPT=src/main/jni/Android.mk', 
      'NDK_APPLICATION_MK=src/main/jni/Application-16.mk', 
      '-j1' 
} 

這是建立日誌:

Information:Gradle tasks [:androidnetspoof:assembleDebug] 
C:\Users\Jang\AppData\Local\Android\sdk\ndk-bundle 
C:\Users\Jang\AppData\Local\Android\sdk\ndk-bundle 
:androidnetspoof:preBuild 
:androidsupportv4preferencefragment:compileLint UP-TO-DATE 
:androidnetspoof:preDebugBuild 
:androidsupportv4preferencefragment:copyReleaseLint UP-TO-DATE 
:androidnetspoof:checkDebugManifest UP-TO-DATE 
:androidsupportv4preferencefragment:preBuild 
:androidnetspoof:preReleaseBuild UP-TO-DATE 
:androidsupportv4preferencefragment:preBuild UP-TO-DATE 
:androidsupportv4preferencefragment:preReleaseBuild 
:androidnetspoof:generateDebugBuildConfig UP-TO-DATE 
:androidsupportv4preferencefragment:checkReleaseManifest 
:androidsupportv4preferencefragment:preDebugAndroidTestBuild UP-TO-DATE 
:androidsupportv4preferencefragment:preDebugBuild UP-TO-DATE 
:androidsupportv4preferencefragment:preDebugUnitTestBuild UP-TO-DATE 
:androidsupportv4preferencefragment:preReleaseUnitTestBuild UP-TO-DATE 
:androidsupportv4preferencefragment:prepareComAndroidSupportSupportV42300Library UP-TO-DATE 
:androidnetspoof:generateDebugAssets UP-TO-DATE 
:androidnetspoof:generateDebugResValues UP-TO-DATE 
:androidsupportv4preferencefragment:preReleaseBuild UP-TO-DATE 
:androidsupportv4preferencefragment:prepareReleaseDependencies 
:androidnetspoof:ndkBuild 
:androidsupportv4preferencefragment:compileReleaseAidl UP-TO-DATE 
:androidsupportv4preferencefragment:compileReleaseRenderscript UP-TO-DATE 
:androidsupportv4preferencefragment:generateReleaseBuildConfig UP-TO-DATE 
:androidsupportv4preferencefragment:generateReleaseAssets UP-TO-DATE 
:androidsupportv4preferencefragment:mergeReleaseAssets UP-TO-DATE 
:androidsupportv4preferencefragment:generateReleaseResValues UP-TO-DATE 
:androidsupportv4preferencefragment:generateReleaseResources UP-TO-DATE 
:androidsupportv4preferencefragment:mergeReleaseResources UP-TO-DATE 
:androidsupportv4preferencefragment:processReleaseManifest UP-TO-DATE 
:androidsupportv4preferencefragment:processReleaseResources UP-TO-DATE 
:androidsupportv4preferencefragment:generateReleaseSources UP-TO-DATE 
:androidsupportv4preferencefragment:processReleaseJavaRes UP-TO-DATE 
:androidsupportv4preferencefragment:compileReleaseJavaWithJavac UP-TO-DATE 
:androidsupportv4preferencefragment:extractReleaseAnnotations UP-TO-DATE 
:androidsupportv4preferencefragment:mergeReleaseProguardFiles UP-TO-DATE 
:androidsupportv4preferencefragment:packageReleaseJar UP-TO-DATE 
:androidsupportv4preferencefragment:compileReleaseNdk UP-TO-DATE 
:androidsupportv4preferencefragment:packageReleaseJniLibs UP-TO-DATE 
:androidsupportv4preferencefragment:packageReleaseLocalJar UP-TO-DATE 
:androidsupportv4preferencefragment:packageReleaseRenderscript UP-TO-DATE 
:androidsupportv4preferencefragment:packageReleaseResources UP-TO-DATE 
:androidsupportv4preferencefragment:bundleRelease UP-TO-DATE 
process_begin: CreateProcess(NULL, realpath obj, ...) failed. 
process_begin: CreateProcess(NULL, realpath obj, ...) failed. 
Warning:warning: overriding commands for target `/extensions/gen_initext.c' 
Warning:warning: ignoring old commands for target `/extensions/gen_initext.c' 
process_begin: CreateProcess(NULL, realpath obj, ...) failed. 
Warning:warning: overriding commands for target `/extensions/gen_initext.c' 
Warning:warning: ignoring old commands for target `/extensions/gen_initext.c' 
process_begin: CreateProcess(NULL, realpath obj, ...) failed. 
Warning:warning: overriding commands for target `/extensions/gen_initext.c' 
Warning:warning: ignoring old commands for target `/extensions/gen_initext.c' 
C:\Users\Jang\AppData\Local\Android\sdk\ndk-bundle\build\core\build-binary.mk 
Warning:(464) warning: overriding commands for target `build/obj/local/armeabi/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: ignoring old commands for target `build/obj/local/armeabi/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: overriding commands for target `build/obj/local/armeabi-v7a/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: ignoring old commands for target `build/obj/local/armeabi-v7a/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: overriding commands for target `build/obj/local/mips/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: ignoring old commands for target `build/obj/local/mips/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: overriding commands for target `build/obj/local/x86/objs/ext/extensions/libipt_standard.o' 
Warning:(464) warning: ignoring old commands for target `build/obj/local/x86/objs/ext/extensions/libipt_standard.o' 
[armeabi] Install  : arp-scan => libs/armeabi/arp-scan 
[armeabi] Install  : arpspoof => libs/armeabi/arpspoof 
mkdir -p /extensions/ 
The syntax of the command is incorrect. 
make.exe: *** [/extensions/gen_initext.c] Error 1 
:androidsupportv4preferencefragment:prepareReleaseDependencies FAILED 
Error:Execution failed for task ':androidnetspoof:ndkBuild'. 
> Process 'command 'C:\Users\Jang\AppData\Local\Android\sdk\ndk-bundle/ndk-build.cmd'' finished with non-zero exit value 2 
+0

您是否嘗試手動構建ndk部件?你也可以發佈你的local.properties? –

+0

這是項目鏈接:https://github.com/w-shackleton/android-netspoof – thefriend

+0

mkdir -p/extensions/ 命令的語法不正確。如果這個mkdir試圖在你的' /'那麼它可能沒有適當的權限。也許這個應用程序爲了工作需要root權限? –

回答

1
  • 確保太this資料庫的內容添加到jni/arp-scan/arp-scan
  • 還要確保this庫中添加內容,以jni/iptables/custom-android-iptables

如果它不工作,改變標誌ndkBuild任務commandLine到-j1,以確保它不會生成並行:發佈構建日誌後

commandLine "$ndkDir/ndk-build.cmd", 
     'NDK_PROJECT_PATH=build', 
     'APP_BUILD_SCRIPT=src/main/jni/Android.mk', 
     'NDK_APPLICATION_MK=src/main/jni/Application.mk', 
     '-j1' 

編輯

發生此錯誤是因爲在生成文件custom-android-iptabes/Android.mk中有一個腳本,它執行mkdir -p /extensions/並且是UNIX based on while I,y,y ou正試圖從Windows構建基於DOS

你需要做的是基礎,翻譯是基於UNIX腳本進入DOS,例如,在這種情況下,mkdir \extenstions\

+0

我已經完成了上述所有事情,但存在錯誤。當我嘗試手動創建ndk部分時,我有prolem:make.exe已停止工作。 – thefriend

+0

嗯,這很奇怪。我已經成功建立了該項目。介意發佈整個build.gradle文件和整個構建日誌? –

+0

檢查編輯 –

0

設置環境變量NDK_TOOLCHAIN_VERSION4.9可以解決問題

enter image description here

相關問題