Исключение NullPointerException при работе в Google Play, но не от Android Studio

У меня большая проблема, я не знаю, что происходит, я загрузил приложение в Play Store, потому что когда я запускал его на эмуляторе или даже на своем реальном устройстве, он не разбивался, но теперь, когда я загружаю он из Google Play говорит:

java.lang.NullPointerException: 
  at com..onBindViewHolder (ChooseCard.java)
  or                     .onCreateViewHolder (ChooseCard.java)
  at com..onBindViewHolder (ChooseCard.java)
  or                     .onCreateViewHolder (ChooseCard.java)
  at com.firebase.ui.database.FirebaseRecyclerAdapter.getItemCount (FirebaseRecyclerAdapter.java)
  or                     .onBindViewHolder (FirebaseRecyclerAdapter.java)
  or                     .onChildChanged (FirebaseRecyclerAdapter.java)
  or                     .onError (FirebaseRecyclerAdapter.java)
  at com.yarolegovich.discretescrollview.InfiniteScrollAdapter.access$100 (InfiniteScrollAdapter.java)
  or                     .getItemCount (InfiniteScrollAdapter.java)
  or                     .getItemViewType (InfiniteScrollAdapter.java)
  or                     .onAttachedToRecyclerView (InfiniteScrollAdapter.java)
  or                     .onBindViewHolder (InfiniteScrollAdapter.java)
  or                     .onCreateViewHolder (InfiniteScrollAdapter.java)
  or                     .wrap (InfiniteScrollAdapter.java)

Это были дни с этой проблемой, и я не могу это узнать, не могли бы вы мне дать руку?

Там мои реализации build.gradle

implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support.constraint:constraint-layout:1.1.0'
implementation 'com.android.support:design:27.1.1'
implementation 'com.intuit.sdp:sdp-android:1.0.4'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation 'com.android.support:cardview-v7:27.1.1'
implementation 'com.google.firebase:firebase-core:15.0.0'
implementation 'com.google.firebase:firebase-auth:15.0.0'
implementation 'com.google.android.gms:play-services-auth:15.0.0'
implementation 'com.google.firebase:firebase-database:15.0.0'
implementation 'com.anjlab.android.iab.v3:library:1.0.44'
implementation 'com.firebaseui:firebase-ui-database:3.3.1'
implementation 'com.onesignal:OneSignal:3.7.1'
implementation 'com.yarolegovich:discrete-scrollview:1.3.2'
implementation 'com.pranavpandey.android:dynamic-toasts:0.9.0'
implementation 'pl.droidsonroids.gif:android-gif-drawable:1.2.11'
implementation 'com.google.android.gms:play-services-analytics:15.0.0'
.....
 dependencies {
        classpath 'com.android.tools.build:gradle:3.1.2'
        classpath 'com.google.gms:google-services:3.2.1'

редактировать

Я обновил свое приложение в Google Play, и ничего не происходит, все еще сбой в одной и той же Activity, теперь я знаю, что делать, чтобы отладить это, проблема заключается в том, когда я загружаю приложение из Google Play на эмуляторе (даже в новом эмулятор не сбой) и на моем реальном устройстве.

Как сказал @Marcos Vascondelos, я сделал Build> Genereate Signed APK> получил приложение-release.apk, установив его на свое устройство, и проблема в том, что я не могу войти в систему, он идет по этому методу:

 @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        // Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
        if (requestCode == RC_SIGN_IN) {
            Task<GoogleSignInAccount> task = GoogleSignIn.getSignedInAccountFromIntent(data);
            try {
                // Google Sign In was successful, authenticate with Firebase
                GoogleSignInAccount account = task.getResult(ApiException.class);
                firebaseAuthWithGoogle(account);
            } catch (ApiException e) {
                // Google Sign In failed, update UI appropriately
                Log.w(TAG, "Google sign in failed", e.getCause());
                Toast with e.getCause is null
            }
        }
    }

Если вы хотите посмотреть, как я могу войти, чтобы не помещать больше кода на этот вопрос, я надел этот GitHubGist

Я читал, что это могут быть проблемы с SHA-1, но я не знаю, почему на эмуляторе все в порядке, устройство в порядке, игра Google в порядке, но если я устанавливаю.apk прямо, он говорит null.

ПОСЛЕДНИЕ ИЗМЕНЕНИЯ

Я вижу, что проблема заключается не в вызове Firebase, а в заполнении списка, я имею в виду, что продукты пойманы правильно, но когда я пытаюсь поместить в список, это то, где он падает

Адаптер FirebaseRecyclerOptions выглядит так:

 final FirebaseRecyclerOptions< CardPOJO > options =
                    new FirebaseRecyclerOptions.Builder< CardPOJO >()
                            .setQuery(products_ref, CardPOJO.class)
                            .build();



            adapter = new   FirebaseRecyclerAdapter< CardPOJO, CardHolder>(options) {
                @Override
                public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                    //inflate the single recycler view layout(item)
                    View view = LayoutInflater.from(parent.getContext())
                            .inflate(R.layout.card_product, parent, false);
                    final CardHolder cardViewHolder = new CardHolder(view);
                    return cardViewHolder;
                }



                @Override
                public void onDataChanged() {
                    super.onDataChanged();
                    if(progressDialog!=null)progressDialog.dismiss();initViews();
                }


                @Override
                protected void onBindViewHolder(final CardHolder holder, int position, final CardPOJO model) {
                    holder.itemView.setSelected(0== position); ////where you are in the list
                    holder.getLayoutPosition();
                    switch (model.getState()){
                        case "free":
                            holder.card_image.setImageResource();
                            break;
                        case "not_free":
                            if(userOwnsProduct(model.getProduct_id())){
                                holder.card_image.setImageResource();
                            }
                            else{
                                holder.card_image.setImageResource();
                            }

                            break;
                        default:
                            break;
                    }
                    holder.view.setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            if(model.getState().equals("free")){
                                //normal stuff1

                            }
                            else{
                                if (!readyToPurchase) {
                                    DynamicToast.makeError(mContext,"Problems with Google Play",Toast.LENGTH_SHORT).show();
                                    return;
                                }
                                root_ref.child("PurchasedProducts").child(currentUser).addValueEventListener(new ValueEventListener() {
                                    @Override
                                    public void onDataChange(DataSnapshot dataSnapshot) {
                                        if(dataSnapshot.hasChild(model.getProduct_id())){
                                            //Normal stuff
                                        }
                                        else{
                                            bp.purchase((Activity) mContext,model.getProduct_id());
                                        }
                                    }

                                    @Override
                                    public void onCancelled(DatabaseError databaseError) {

                                    }
                                });

                            }

                        }
                    });


                }

            };
            adapter.startListening();



            infiniteAdapter = InfiniteScrollAdapter.wrap(adapter);
            itemPicker.setAdapter(infiniteAdapter);
            //.setItemTransitionTimeMillis(DiscreteScrollViewOptions.getTransitionTime());
            itemPicker.setItemTransformer(new ScaleTransformer.Builder()
                    .setMinScale(0.5f)
                    .build());

Ответы

Ответ 1

Проблема заключалась в использовании Proguard, я не использовал @Keep для своих классов pojo, поэтому при попытке сериализации класса с firebase данных firebase не находил атрибуты, потому что они были запутаны.

Ответ 2

Помните, всегда проверяйте, является ли компонент нулевым или нет. Затем выполните свой код. пример:

if ("your_component" != null){
//your code
}

Ответ 3

Кажется, вы пробовали почти все, что я мог придумать. Это может быть проблема с SHA-1. Попробуйте это:

  • Во-первых, проверьте, действительно ли существует доступ к вашему дочернему элементу (т.е. не null)
  • Попробуйте проверить, действительно ли у вас есть доступ для добавления продуктов. Кроме того, проверьте правила Firebase.
  • Попробуйте добавить продукт с разными типами пользователей (если ваше приложение содержит разные типы пользователей).

Ответ 4

Хорошо, вот оно! Я видел код, в котором аномалия, возможно, игнорируется, например, в верхнем конце apis. В простых словах для api 23 и> 23, как получение контекста с помощью ViewGroup Parent в области viewHolder! это не проблема, но на небольших устройствах api я думаю, что это будет проблемой!

поэтому попробуйте эту надежду, это поможет!

Возможно, я вижу, что с этой точки зрения надеюсь, что это поможет

public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                                //inflate the single recycler view layout(item)
                           //  !!!!!!!!!!!!! **the issue is here**! !!!!!!!!!!!!!!!
                                View view = LayoutInflater.from(parent.getContext())
                                        .inflate(R.layout.card_product, parent, false);
                                final CardHolder cardViewHolder = new CardHolder(view);
                                return cardViewHolder;
                            }

У вас нет правильной настройки вашего макета! Получение контекста, подобного этому, возможно, является причиной NULL POINTER EXCEPTION в этом классе! Существует простой способ сделать это! например, получить контекст активности, взяв его с помощью конструктора адаптера при создании экземпляра.

вот пример!

public class yourActivity extends AppCompatActivity{
   YourAdapter mAdapter; 
/// lets say you are setting it up in android ONCREATE Method
@override
public void OnCreate(....){
...........

mAdapter(data,design,YourActivity.this);
 //here this will be the context going in your adapter simple

}

}

В своем конструкторе адаптера вы можете хранить его в глобальной переменной, например,

public class YourAdapter extends RECYCLERView.Adapter......{
Context mContext;
public YourAdapter(Data data, int design,Context mContext)
this.mContext = mContext;
}
//and now you can access without any stress about context null exception 
   public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                            //inflate the single recycler view layout(item)
                            View view = LayoutInflater.from(mContext)
                                    .inflate(R.layout.card_product, parent, false);
                            final CardHolder cardViewHolder = new CardHolder(view);
                            return cardViewHolder;
                        }

ПЕРВАЯ АНОМАЛИЯ раскрывается и разрешается с помощью приведенного выше кода. второй, который я надеялся, подобен этому

Вы пытаетесь использовать RecyclerView, но не предоставляете его SubClass для хранения представлений!

Когда мы делаем адаптер для просмотра в ресайклере, они должны обладать подклассом для ViewHolder, чтобы сделать просто переработку для нас. основная работа этого подкласса заключается в том, чтобы удерживать Views и findThem, используя их идентификаторы

для типичного примера попробуйте эту ссылку, которую я нашел! кредит идет на git writer.