这里是引用
AndroidStudio常见问题
如何解决Unsupported major.minor version 52.0问题?
运行./gradlew :PandaAndroidDemo:release出现如下错误:
FAILURE: Build failed with an exception.
* Where:
Build file '/Users/shitianci/work/Lab/panda.android/PandaAndroidDemo/build.gradle' line: 1
* What went wrong:
A problem occurred evaluating project ':PandaAndroidDemo'.
> java.lang.UnsupportedClassVersionError: com/android/build/gradle/AppPlugin : Unsupported major.minor version 52.0
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
直接点击 run按钮 或者 Build→Generate Build APK 却运行正常。
这里面有两个问题:
为什么出现Unsupported major.minor version 52.0?
为什么gradle命令和android studio按钮运行结果不一样?
问题一:为什么出现Unsupported major.minor version 52.0?
在网上找了一圈,最后在stackoverflow找到了本质原因
You get this error because a Java 7 VM tries to load a class compiled for Java 8
Java 8 has the class file version 52.0 but a Java 7 VM can only load class files up to version 51.0
In your case the Java 7 VM is your gradle build and the class is com.android.build.gradle.AppPlugin
简单来说,就是java的编译环境版本太低,java 8 class file的版本是52,Java 7虚拟机只能支持到51。所以需要升级到java 8 vm才行。
问题二:为什么gradle命令和android studio按钮运行结果不一样?
从问题1来看,肯定Android Studio按钮调用的是java 8 vm,所以查找一下系统配置,最终在Project Structure找到了如下设置:
Android Studio 2.2.2使用了自带的JDK环境,其地址为
/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home
而gradle命令的执行环境是在gradle.properties配置的,其指向为:
org.gradle.java.home=/Library/Java/JavaVirtualMachines/jdk1.7.0_71.jdk/Contents/home
将其修改为:
org.gradle.java.home=/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home
INSTALL_PARSE_FAILED_NO_CERTIFICATES安装问题
Android studio
更新到25后打包问题,打包后的应用安装提示:INSTALL_PARSE_FAILED_NO_CERTIFICATES
Android N 引入一项新的应用签名方案 APK Signature Scheme v2,它能提供更快的应用安装时间和更多针对未授权
APK 文件更改的保护。 在默认情况下,Android Studio 2.2 和 Android Gradle 2.2 插件会使用 APK
Signature Scheme v2 和传统签名方案来签署您的应用。
脏的解决方式:使用v1打包
INSTALL FAILED CONFLICTING PROVIDER问题完美解决方案
在安装Android应用时出现INSTALL FAILED CONFLICTING PROVIDER问题,是不是感觉很抓狂呢,下面就跟大家分享一下出现这个问题的原因及解决方案。
问题原因:
在Android中authority要求必须是唯一的,比如你在定义一个provider时需要为它指定一个唯一的authority。如果你在安装一个带有provider的应用时,系统会检查当前已安装应用的authority是否和你要安装应用的authority相同,如果相同则会弹出上述警告,并且安装失败。
解决方案
在定义provider是,使用软编码的形式,如下:
<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:grantUriPermissions="true"
android:exported="false">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>
上述代码中通过${applicationId}.fileprovider的形式来指定provider的authorities,所以该provider的authorities会根据applicationId的不同而不同,从而避免了authorities的冲突问题。
那么如何使用刚才定义的authorities呢?
我们在定义authorities是采用了applicationId+fileprovider的形式,在获取authorities的时候,我们就可以通过包名+fileprovider来获取,代码如下:
public final static String getFileProviderName(Context context){
return context.getPackageName()+".fileprovider";
}