অ্যান্ড্রয়েডের জন্য অ্যালিপসে প্রোগুয়ার্ড সক্ষম করা


112

অ্যান্ড্রয়েডের জন্য প্রোগার্ডে নতুন ডকুমেন্টেশনটি বলেছে যে প্রকল্পের হোম ডিরেক্টরিতে ডিফল্ট.প্রপার্টি ফাইলগুলিতে একটি লাইন যুক্ত করা যায়। যাইহোক, এই ফাইলটি খোলার সময়, আমি শীর্ষে পড়েছি:

# This file is automatically generated by Android Tools. 
# Do not modify this file -- YOUR CHANGES WILL BE ERASED! 

আমি কিছু অনুপস্থিত করছি?

এছাড়াও, কেবলগ্রহ থেকে কোনও প্রোডাক্ট বিল্ডের জন্য প্রোগ্রুয়ার্ড সক্ষম করার কোনও উপায় আছে (অর্থাত, সমাপ্ত পণ্যটি রফতানি করার সময়)?


আমি আপনার বক্তব্যের সাথে একমত যে ডিফল্ট.প্রাপ্তিগুলি প্রতিবার নতুন করে তৈরি করা হবে। সুতরাং, এটি একটি আকর্ষণীয় প্রশ্ন
আমান আলম

আপনার লিগির উত্তরটি গ্রহণ করা উচিত, NeTeInStEiN আর ধরে না এবং নতুন ব্যবহারকারীকে বিভ্রান্ত করে।
গৌরব আগরওয়াল

2
আমি উত্তরটি আপ টু ডেট হতে পরিবর্তন করেছি।
neteinstein

নতুন ইনস্টলেশনগুলির জন্য, লিগির উত্তরটি এখনও নিউটেনস্টাইনের চেয়ে পরিষ্কার। সর্বাধিক গুরুত্বপূর্ণভাবে, এটি দেখায় proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt , আপনার যদি কোনও নির্দিষ্ট প্রকল্পের জন্য কাস্টম সেটিংস প্রয়োজন হয়।
নির্মাতা

উত্তর:


76

কেবলমাত্র একটি ফলোআপ কারণ আমি একই জিনিসটি অনুসন্ধান করছিলাম - এবং উত্তরগুলি পুরানো হয়েছে - ইদানীং বেস প্রগুয়ার্ড কনফিগারেশনটি এখানে এসডিকে দির-এ রয়েছে - সুতরাং আপনাকে কেবল এটি আপনার প্রকল্পের মধ্যে রেখে দিতে হবে p

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt

আপনি যদি প্রকল্প-নির্দিষ্ট পরিবর্তন করতে চান তবে একটি প্রগর্ড-প্রজেক্ট.txt তৈরি করুন এবং লাইনটি এতে পরিবর্তন করুন:

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt 

আমার প্রকল্পটি দেখে (r20-এ, তবে পূর্বের প্রকাশে উত্পন্ন) এটি উপরোক্ত পদ্ধতির মিশ্রণ ব্যবহার করে বলে মনে হচ্ছে:
টম

26
এখনও বেশ বিভ্রান্তিকর কারণ প্রকল্প.প্রোপার্টিগুলিও বলেছে # এই ফাইলটি অ্যান্ড্রয়েড সরঞ্জাম দ্বারা স্বয়ংক্রিয়ভাবে উত্পন্ন। # এই ফাইলটি সংশোধন করবেন না - আপনার পরিবর্তনগুলি ক্ষয় করা হবে!
টড পেইটন

12
"আপনাকে কেবল এটি আপনার প্রকল্পের মধ্যে রাখতে হবে rop এই লাইনটি প্রজেক্টে রয়েছে rop শুধু এটি মন্তব্য।
ব্রজ

113

Android SDK (r20 বা উচ্চতর)

প্রোজেক্ট.প্রোপার্টিগুলিতে রেফার করা পূর্বনির্ধারিত অগ্রগতি.কনফিগটি পরীক্ষা করে দেখুন

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt

আরও তথ্য: http://proguard.sourceforge.net/manual/exferences.html# androidapplication

গ্রেডলে:

buildTypes {
 release {
            minifyEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

            ...
  }
 }

এখানে আপনি যে অগ্রণী "ডিফল্ট" ফাইলটি আপডেট করে চলেছি তা পরীক্ষা করতে পারেন: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (r19 বা তার চেয়ে কম)

আপনি এটি ডিফল্টরূপে যোগ করতে পারেন rop আমি এখন পর্যন্ত কোনও সমস্যা না করে ম্যানুয়ালি যুক্ত করছি।

আপনি যদি লাইনটি যুক্ত করেন:

proguard.config=proguard.cfg

যেমনটি বলা হয়েছে এটি স্বাক্ষরিত অ্যাপ্লিকেশন রফতানি করার সময় কেবলমাত্র প্রোগার্ড ব্যবহার করবে (অ্যান্ড্রয়েড সরঞ্জামগুলি => স্বাক্ষরিত অ্যাপ্লিকেশন রফতানি করুন)

যদি আপনি অ্যান্ড্রয়েড ২.৩ এর আগে এসডিকে দিয়ে প্রকল্পটি শুরু করেন তবে proguard.cfgফাইলটি তৈরি হবে না ( default.properties২.৩> এর পাশে)।

এর স্বয়ংক্রিয় তৈরি সক্ষম করতে, কেবল অ্যান্ড্রয়েড ২.৩ এর এসডিকে আপডেট করুন এবং বিদ্যমান উত্সগুলি (যা বর্তমানে আপনার প্রকল্পের উত্স যা) দিয়ে একটি নতুন প্রকল্প তৈরি করুন।

স্বয়ংক্রিয়ভাবে proguard.cfgফিল তৈরি হবে।

যদি এখনও হয় তবে আপনি নিজে এটি তৈরি করতে চান এটিতে এটি থাকা উচিত:

-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontwarn android.support.**
-verbose

-dontoptimize
-dontpreverify


-keepattributes *Annotation* 
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * extends android.content.ContentProvider
-keep public class com.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.app.Fragment

-keepclasseswithmembernames class * {
    native <methods>;
}

-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}

-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}

 -keepclassmembers public class * extends android.view.View {
  void set*(***);
  *** get*();
 }

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

-keepclassmembers class **.R$* {
  public static <fields>;
}

আমি মনে করি আমি উপরের সমস্ত প্রশ্নের উত্তর দিয়েছি।

আপডেট :

লাইনের ব্যাখ্যার দ্বারা একটি লাইন:

#Use 5 step of optimization 
#-optimizationpasses 5

#When not preverifing in a case-insensitive filing system, such as Windows. This tool will unpack your processed jars,(if using windows you should then use):
-dontusemixedcaseclassnames

#Specifies not to ignore non-public library classes. As of version 4.5, this is the default setting
-dontskipnonpubliclibraryclasses

# 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
-dontpreverify

-dontwarn android.support.**

#Specifies to write out some more information during processing. If the program terminates with an exception, this option will print out the entire stack trace, instead of just the exception message.
-verbose

#The -optimizations option disables some arithmetic simplifications that Dalvik 1.0 and 1.5 can't handle. Note that the Dalvik VM also can't handle aggressive overloading (of static fields).
#To understand or change this check http://proguard.sourceforge.net/index.html#/manual/optimizations.html
#-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

# 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.

#To repackage classes on a single package
#-repackageclasses ''

#Uncomment if using annotations to keep them.
#-keepattributes *Annotation*

#Keep classes that are referenced on the AndroidManifest
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-keep public class * extends android.app.Service
-keep public class * extends android.content.BroadcastReceiver
-keep public class * extends android.content.ContentProvider
-keep public class * extends android.app.backup.BackupAgentHelper
-keep public class * extends android.preference.Preference
-keep public class com.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
#Compatibility library 
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.app.Fragment

#To maintain custom components names that are used on layouts XML.
#Uncomment if having any problem with the approach below
#-keep public class custom.components.package.and.name.**

# keep setters in Views so that animations can still work.
# see http://proguard.sourceforge.net/manual/examples.html#beans
 -keepclassmembers public class * extends android.view.View {
  void set*(***);
  *** get*();
}

#To remove debug logs:
-assumenosideeffects class android.util.Log {
    public static *** d(...);
    public static *** v(...);
    public static *** w(...);
}

#To avoid changing names of methods invoked on layout's onClick.
# Uncomment and add specific method names if using onClick on layouts
#-keepclassmembers class * {
# public void onClickButton(android.view.View);
#}

#Maintain java native methods 
-keepclasseswithmembernames class * {
    native <methods>;
}


#To maintain custom components names that are used on layouts XML:
-keep public class * extends android.view.View {
    public <init>(android.content.Context);
}
-keep public class * extends android.view.View {
    public <init>(android.content.Context, android.util.AttributeSet);
}
-keep public class * extends android.view.View {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}

#Maintain enums
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

#To keep parcelable classes (to serialize - deserialize objects to sent through Intents)
-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

#Keep the R
-keepclassmembers class **.R$* {
    public static <fields>;
}

###### ADDITIONAL OPTIONS NOT USED NORMALLY

#To keep callback calls. Uncomment if using any
#http://proguard.sourceforge.net/index.html#/manual/examples.html#callback
#-keep class mypackage.MyCallbackClass {
#   void myCallbackMethod(java.lang.String);
#}

#Uncomment if using Serializable 
#-keepclassmembers class * implements java.io.Serializable {
#    private static final java.io.ObjectStreamField[] serialPersistentFields;
#    private void writeObject(java.io.ObjectOutputStream);
#    private void readObject(java.io.ObjectInputStream);
#    java.lang.Object writeReplace();
#    java.lang.Object readResolve();
#}

আপডেট 2:

এর পরিবর্তে সর্বাধিক সাম্প্রতিক এডিটি / প্রগার্ড ব্যবহার -keepclasseswithmembersকরুন-keepclasseswithmembernames


1
@ নেটটিআইনস্টিআইএন আমি এসডিকে ১ ((অ্যান্ড্রয়েড x.০) আপডেট করেছি, লাইনটি যুক্ত করেছি proguard.config=proguard.cfgতবে প্রগুয়ার্ড.সিএফজি ফাইলটি কোথাও দেখা যায় না ... একাধিকবার রফতানি করা সত্ত্বেও, গ্রহনটি পুনরায় চালু করা ইত্যাদি কোনও ধারণা কেন? এবং কিভাবে এটি ঠিক করবেন? ধন্যবাদ।
বিল দ্য এপিকে

1
@ নিউটইনস্টেআইএন কিছু মনে করবেন না। দেখা যাচ্ছে যে আমার নিজের তৈরি করা উচিত ছিল।
বিল এপিকে

@ নেটটিইনস্টেআইএন আমি যখন একটি প্রকল্প তৈরি করি, যদিও এটির নির্ধারিত লক্ষ্য অ্যান্ড্রয়েড 1.1, আমি স্বয়ংক্রিয়ভাবে তৈরি হওয়া প্রগুয়ার্ড.সি.পি. ফাইলটি পেয়েছি ।
hasanghaforian

1
@ নিউটইনস্টিআইএন আশ্চর্যজনক মানুষ ... আপনার সময় এবং প্রচেষ্টার সত্যই প্রশংসা করুন, চিয়ার্স !!
সুইফটবয়

1
@ ব্যবহারকারী31231234124 আপনি জিজ্ঞাসা করা তথ্য যুক্ত করেছে।
neteinstein

10

কমপক্ষে এডিটি 16 হিসাবে, আপনি প্রকৃতপক্ষে লাইনটি যুক্ত করতে পারেন project.properties, এবং এটি সংরক্ষণ করা হবে। আপনি লক্ষ্য এসডিকে সংস্করণটি পরিবর্তন করতে চেষ্টা করতে পারেন এবং এটি project.propertiesঅনুসারে আপডেট করা হয়েছে তবে যুক্ত লাইনটি এখনও আছে। সুতরাং, আমি মনে করি সতর্কতাটি কেবল খারাপভাবে বলা হয়েছে; এর অর্থ হ'ল ফাইলের সেটিংস যেমন targetপ্রকল্পের সেটিংসের পরিবর্তে উল্টানো হবে, তার বিপরীতে নয়।


4

প্রোগুয়ার্ড কনফিগারেশনে পরিবর্তনগুলি এডিটি সংস্করণ 17 দিয়ে আসে came মনে রাখবেন যে বিদ্যমান প্রকল্পগুলি অপরিবর্তিত থাকবে এবং এটিকে এবং আরও নতুন এডিটি সংস্করণগুলিতে অন্তর্ভুক্ত নতুন নিয়ম সেট ছাড়াই এগুলি রেখে যাবে। উপরের লিগি দ্বারা ইতিমধ্যে উল্লিখিত নতুন কনফিগারেশন বিন্যাসের জন্য প্রাসঙ্গিক ডকটি এখানে উপলব্ধ: -

http://tools.android.com/recent/proguardimprovements "দ্বিতীয়ত, আমরা পথ কনফিগারেশন ফাইল পরিচালনা করা হয় পরিবর্তন করেছি।"


3

build.propertiesউল্লিখিত হিসাবে আপনি লাইনটি যুক্ত করতে পারেন default.properties


Build.properties কোথায়? নাকি আমার এটি তৈরি করা দরকার?
টেড হপ

এটি প্রকল্প ডিরেক্টরিতে রয়েছে ডিফল্টের পরেও। প্রপার্টি (অন্তত অ্যান্ড্রয়েড এসডিকে আর 8 সহ)।
এরিক লাফোর্টুন

এটি যেখানে এটি সন্ধান করছিল, তবে আমার কোনও প্রকল্পে এ জাতীয় ফাইল নেই। আমি সর্বশেষতম প্লাগইন ব্যবহার করছি এবং এটি পরীক্ষা করার জন্য মাত্র একটি স্তর 8 প্রকল্প তৈরি করেছি।
টেড হপ

4
দেখা যাচ্ছে যে build.properties ব্যবহার করা কেবল পিঁপড়া তৈরির জন্য কাজ করে, গ্রহচিত্র তৈরির জন্য নয়।
টেড হপ

2016 এ অ্যান্ড্রয়েড স্টুডিও বাল্ডে বিল্ড.প্রপ্রেটিস কোথায়?
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.