一、签名:
-
生成签名文件
-
通过cmd.exe获取SHA1值和MD5值
二、Structure配置:
-
Properties属性
-
Signing签名
-
Flavors(多样性,多渠道)
-
Build Types构建类型
-
Dependencies(依赖)
<<签名--生成密钥和签名文件>>
1.点击菜单栏中的Build的,选中Generate Signed APK,并点击。弹出窗体,如下图
3.点击Create new…按钮,创建一个签名文件。选择keystore保存的路径,填写keystore和key密码。ketstore密码和key密码在后面会用到。其他信息不是很重要,按实际情况写就好。
4.点击ok按钮。可以看到,重要的信息都显示在这里了,点击next
5.在Build Type类型选择release,点击Finish,release是发布版本用的签名文件,选择debug是debug用的签名文件。
android studio 2.3 签名时添加签名版本Signature Versions:V1 V2 二者区别
V1:可对签名后的文件,作适当修改,并重新压缩。
V2:不能对签名后的 APK作任何修改,包括 zipalign。因为它是针对字节进行的签名,所以任何改动都会影响最终结果。
勾选V2就可能导致在Android7.0以下的设备无法安装【 INSTALL_PARSE_FAILED_NO_CERTIFICATES】。所以只要打包的时候勾选V1就好了,或者选择 V1和 V2。如果使用运行是自带签名配置在自定义签名中配置------v2SigningEnabled false-----
<<签名--获取SHA1值和MD5值>>
1、第一步黑窗口进入jdk bin目录
2、输入keytool.exe -list -v -keystore C:\Users\Administrator\Desktop\demo.jks(jks的绝对路径)
<<Structure--Properties属性>>
-
Complie Sdk Version: Android的编译版本
-
Build Tools Version : 构建版本
-
Library Repostitory :当前的Module的仓库源
这里可以定义一个地址,一个本地路径,或者是jcenter()和mavenCentral().
填写任何一个仓库,AS会自动下载对应的仓库,如果你随便填写一个,会提示你无法连接到该仓库.
填写mavenCentral后你会在app.gradle的文件中看见
repositories {
mavenCentral()
}
-
Ignore Assets Pattern:打包时候要忽略的文件(AAPT的属性,AAPT为Android打包工具)很少用到
-
Incremental Dex :dex增量编译
android studio默认是关闭的 false,选择true ,打开后会加快编译
对应的gradle的文件中看见
dexOptions {
incremental true
preDexLibraries true
maxProcessCount 8
javaMaxHeapSize "2048m"
}
加快編譯
-
preDexLibraries
声明是否预先编译依赖库,从而加快构建速度,实质是通过延时清除已生成的依赖库的构建文件,从而提高构建速度,根据使用情况合理配置。
-
maxProcessCount
设置进程运行过程中可以使用的最大线程数。默认值为4。
-
javaMaxHeapSize
设置DEX编译器的最大堆大小,堆或者栈都是用于存放暂时不用的垃圾,当内存不足时,垃圾回收机制会清除过时的缓存,堆大小决定垃圾清除的频率,影响着构建的速度
-
Source Compatibility:资源版本
-
Target Compatibility:目标版本
两个都选了1.7,可以看到增加了如下代码:
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
<<Structure--Signing签名>>配置签名信息
点击ok,对应的gradle的文件中看见
signingConfigs {
test {
keyAlias 'demo'
keyPassword '123456'
storeFile file('C:/Users/Administrator/Desktop/demo.jks')
storePassword '123456'
}
}
signingConfigs 的作用会在后面介绍
<<Structure--Flavors(多样性,多渠道)>>
-
Name:Flaveor的名字
-
Min Sdk Version:向下兼容的SDK版本
-
Application Id:包名
-
Proguard File:混淆文件
-
Signig Config:签名文件名.
签名的文件信息在前一个选项卡Signing中设置.在这里选择
-
Target Sdk Version:目标SDK版本
-
Test Instrumentation Runner:Test Runner
-
Test Application Id:测试时的ID
-
Version Code:Module版本Version Name:Module版本名称
对应的gradle的文件中看见
defaultConfig {
applicationId "com.hedan.appgradledemo"
minSdkVersion 15
targetSdkVersion 25
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
signingConfig signingConfigs.test
}
<<Structure--Build Types构建类型>>
-
Name:Build Type名称
-
Debugable:是否可以调试
-
Jin Debuggable:是否可以调试JNI
-
Signing Config:签名信息
-
Renderscript Debuggale:是否使用RenderScript
-
Renderscript Optim Level:Rendescript版本.
-
Minify Enabled:是否去除无用的资源
-
Pseudo Locales Enaled:是否支持本地化整理
-
Proguard File:混淆,去重文件路径
-
Application Id Suffix:App id后缀
-
Version Name Suffix:版本名称后缀
-
Zip Align Enabled:是否支持Zip Align
对应的gradle的文件中看见
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
texttype {
debuggable false
jniDebuggable false
signingConfig signingConfigs.test
minifyEnabled true
zipAlignEnabled true
}
}
<<Structure--Dependencies(依赖)>>
-
在这里添加添加jar包,library等.
-
1.表示添加用系统的library,例如v7,v4包.
-
2.添加jar包(注意这个jar包必须在当前的Module)
-
3.添加一个Module(这个工程是AS A Libray)
对应的gradle的文件中看见
dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
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.2.0'
compile 'com.android.support.constraint:constraint-layout:1.0.2'
testCompile 'junit:junit:4.12'
}
引入依赖包你不知道的秘密
dependencies {
compile project(":mylibrary")
compile files('libs/zxing.jar')
compile fileTree(include: ['*.jar'], dir: 'libs')
compile 'com.android.support:appcompat-v7:25.1.0'
compile group: 'com.android.support', name: 'appcompat-v7', version: '25.1.0'
}
可以看到Android Studio引入依赖项的方式分为上述四种,按顺序依次称为:1、模块依赖项,2、本地二进制依赖项,3、本地二进制依赖项,4、远程二进制依赖项,5、远程二进制依赖项
-
compile project(':mylibrary')
声明了一个名为mylibrary的本地 Android 库模块作为依赖项,并要求构建系统在构建应用时编译并包含该本地模块。
-
compile files('libs/zxing.jar')和compile fileTree(dir: 'libs', include: ['*.jar'])
都称为本地依赖项,告诉构建系统在编译类路径和最终的应用软件包中包含 app/libs/ 目录内的指定或全部 JAR 文件。如果您有模块需要本地二进制依赖项,请将这些依赖项的 JAR 文件复制到项目内部的 /libs 中。
-
compile 'com.android.support:appcompat-v7:25.1.0'和compile group: 'com.android.support', name: 'appcompat-v7', version: '25.1.0'
都称为远程二进制依赖项,通过指定其 JCenter 坐标,针对 Android 支持库的 25.1.0 版本声明了一个依赖项。默认情况下,Android Studio 会将项目配置为使用顶级构建文件中的 JCenter 存储区。当您将项目与构建配置文件同步时,Gradle 会自动从 JCenter 中抽取依赖项。或者,您也可以通过使用 SDK 管理器下载和安装特定的依赖项。
-
第五种可以清楚看出每一节表示的含义,在Android Studio引入远程二进制依赖项,通常的做法是在Library Dependency窗口中搜索,搜索到最新版本的依赖项,如果想要引入低版本的,那该怎么办呢?如果先前不了解远程二进制依赖项的含义,可能想不到修改version的办法,现在就变得很简单了。