Android打包Jar包并添加混淆

最近公司有个项目,需要我们提供底层的读写卡SDK卡(基于掌机和基于蓝牙读卡器的SDK),开发难度上算简单,但是需要打包成Jar库,以及源码不公开。由于Android是开源的,目前也没有能找到更好的方案,所以只能在打包Jar库的时候添加混淆这一个方式能实现客户的需求了。(如果有大神有其他更好的方式,请务必给我留言,哈哈哈哈)。

  • 创建一个Android Lib类库。

​​​​​​​

  • 在类库中编写代码。
  • 在lib库的gradle中的android下添加以下代码:
//配置jar包的指令
def SDK_BASENAME = "cardServer_bete";//生成的jar包的名称
    def SDK_VERSION = "_v1.0.3";//生成的jar包的版本号
    def sdkDestinationPath = "build/outputs/jar/";//jar存放的路径
    def zipFile = file('build/intermediates/bundles/release/classes.jar')
    task deleteBuild(type: Delete) {
        //每次生成前,都先删除之前的jar包
        delete sdkDestinationPath + SDK_BASENAME + SDK_VERSION + ".jar"
    }
    //生成jar包的指令
    task makeJar(type: Jar) {
        from zipTree(zipFile)
        from fileTree(dir: 'src/main', includes: ['assets/**']) // 打包assets目录下的所有文件
        baseName = SDK_BASENAME + SDK_VERSION
        destinationDir = file(sdkDestinationPath)
    }
    makeJar.dependsOn(deleteBuild, build)
  • 在gradle中开启混淆开关,并在proguard-rules.pro(注意要选择你需要混淆的库的文件哦)添加你需要的混淆规则。混淆规则较多,主要是三方不可混淆,你需要公开出去的API不可混淆等等,具体可以自行百度或者参考如下:


###########################以下是AndroidStudio自带的混淆配置协议###############################
# 表示混淆时不使用大小写混合类名
-dontusemixedcaseclassnames
# 表示不跳过library中的非public的类
-dontskipnonpubliclibraryclasses
# 打印混淆的详细信息
-verbose
# Optimization is turned off by default. Dex does not like code run
# through the ProGuard optimize and preverify steps (and performs some
# of these optimizations on its own).
-dontoptimize
# 表示不进行校验,这个校验作用 在java平台上的
-dontpreverify
# Note that if you want to enable optimization, you cannot just
# include optimization flags in your own project configuration file;
# instead you will need to point to the
# "proguard-android-optimize.txt" file instead of this one from your
# project.properties file.
#使用注解需要添加
-keepattributes *Annotation*
-keep public class com.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
# For native methods, see http://proguard.sourceforge.net/manual/examples.html#native
#指定不混淆所有的JNI方法
-keepclasseswithmembernames class * {
native <methods>;
}
# keep setters in Views so that animations can still work.
# see http://proguard.sourceforge.net/manual/examples.html#beans
#所有View的子类及其子类的get、set方法都不进行混淆
-keepclassmembers public class * extends android.view.View {
void set*(***);
*** get*();
}
# We want to keep methods in Activity that could be used in the XML attribute onClick
# 不混淆Activity中参数类型为View的所有方法
-keepclassmembers class * extends android.app.Activity {
public void *(android.view.View);
}
# For enumeration classes, see http://proguard.sourceforge.net/manual/examples.html#enumerations
# 不混淆Enum类型的指定方法
-keepclassmembers enum * {
public static **[] values();
public static ** valueOf(java.lang.String);
}
# 不混淆Parcelable和它的子类,还有Creator成员变量
-keepclassmembers class * implements android.os.Parcelable {
public static final android.os.Parcelable$Creator CREATOR;
}
# 不混淆R类里及其所有内部static类中的所有static变量字段
-keepclassmembers class **.R$* {
public static <fields>;
}
# The support library contains references to newer platform versions.
# Don't warn about those in case this app is linking against an older
# platform version. We know about them, and they are safe.
# 不提示兼容库的错误警告
-dontwarn android.support.**
# Understand the @Keep support annotation.
-keep class android.support.annotation.Keep
-keep @android.support.annotation.Keep class * {*;}
-keepclasseswithmembers class * {
@android.support.annotation.Keep <methods>;
}
-keepclasseswithmembers class * {
@android.support.annotation.Keep <fields>;
}
-keepclasseswithmembers class * {
@android.support.annotation.Keep <init>(...);
}
###########################以下是需要手动的混淆配置协议###############################
#-libraryjars "C:\Program Files\Java\jre1.8.0_151\lib\rt.jar"
#-libraryjars "C:\Users\admin\AppData\Local\Android\sdk\platforms\android-26\android.jar"
# 注意:以上两个路径需要将以上路径是自己jar包的位置,需要根据自己情况进行修改,如果报重复配置的错误,注释掉即可
#代码迭代优化的次数,默认5
-optimizationpasses 5
#混淆时不会产生形形色色的类名
-dontusemixedcaseclassnames
#忽略警告
-ignorewarnings
#以下是不需要混淆的文件(具体某个类或者某个包都不需要混淆)
-keep class com.lu.cardserver.cardManager.** { *; }
-keep class com.lu.cardserver.model.** { *; }
-keep class com.lu.cardserver.dataFormat.model.**{ *; }
-keep class com.lu.cardserver.dataFormat.type.**{ *; }
-keep class com.lu.cardserver.app.** { *; }

  • 最后一步,在Android studioh中的Terminal输入gradlew makeJar,回车即可。打包,打包显示成功以后,去你在第三步中设置的路径下去取Jar即可。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Android Java SDK打包可以通过使用Android SDK中的ant脚本来实现。首先,需要将Java代码编译成.class文件,然后将这些.class文件打包成.jar文件。为了保证安全性,还可以对.jar文件进行混淆处理。\[1\] 使用ant打包APK及依赖的最佳解决办法是,在Android工程下生成build.xml文件,然后执行ant命令中的"target"参数来进行打包。如果有依赖库工程,需要在每个库工程目录下生成build.xml文件,并在主工程下执行ant命令来打包。如果需要自定义脚本,可以在生成的build.xml文件中进行编写。\[2\] 如果需要将资源文件也打包进SDK中,可以采用以下几种方法:使用软链接法、使用字符串或使用public资源。这些方法可以避免在提供资源文件给商户时出现R文件中id的问题。具体的实现方法可以参考相关文档和教程。\[3\] 总结来说,Android Java SDK打包可以通过使用ant脚本来实现,将Java代码编译成.class文件并打包成.jar文件。同时,可以对.jar文件进行混淆处理。如果需要打包资源文件,可以采用不同的方法来处理。 #### 引用[.reference_title] - *1* *2* *3* [android打包SDK(括资源)和APK全总结](https://blog.csdn.net/weixin_34549315/article/details/117342063)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值