0

このチュートリアルを実行しようとしています が、このエラーが発生し続けます:

08-21 14:12:49.599: E/AndroidRuntime(714): java.lang.NoClassDefFoundError: com.akiraapps.LicenseCheck$MyLicenseCheckerCallback

import android.app.Activity;
import android.app.AlertDialog;
import android.app.Dialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.provider.Settings.Secure;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.TextView;

import com.google.android.vending.licensing.AESObfuscator;
import com.google.android.vending.licensing.LicenseChecker;
import com.google.android.vending.licensing.LicenseCheckerCallback;
import com.google.android.vending.licensing.Policy;
import com.google.android.vending.licensing.ServerManagedPolicy;


public class LicenseCheck extends Activity {

    private static final String BASE64_PUBLIC_KEY = "no";

    private static final byte[] SALT = new byte[] { no};

    private TextView mStatusText;
    private Button mCheckLicenseButton;

    private LicenseCheckerCallback mLicenseCheckerCallback;
    private LicenseChecker mChecker;
    // A handler on the UI thread.
    private Handler mHandler;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
        setContentView(R.layout.main);

        mStatusText = (TextView) findViewById(R.id.status_text);
        mCheckLicenseButton = (Button) findViewById(R.id.check_license_button);
        mCheckLicenseButton.setOnClickListener(new View.OnClickListener() {
            public void onClick(View view) {
                doCheck();
            }
        });

        mHandler = new Handler();

        // Try to use more data here. ANDROID_ID is a single point of attack.
        String deviceId = Secure.getString(getContentResolver(), Secure.ANDROID_ID);

        // Library calls this when it's done.
        mLicenseCheckerCallback = new MyLicenseCheckerCallback();
        // Construct the LicenseChecker with a policy.
        mChecker = new LicenseChecker(
            this, new ServerManagedPolicy(this,
                new AESObfuscator(SALT, getPackageName(), deviceId)),
            BASE64_PUBLIC_KEY);
        doCheck();
    }

    protected Dialog onCreateDialog(int id) {
        final boolean bRetry = id == 1;
        return new AlertDialog.Builder(this)
            .setTitle(R.string.unlicensed_dialog_title)
            .setMessage(bRetry ? R.string.unlicensed_dialog_retry_body : R.string.unlicensed_dialog_body)
            .setPositiveButton(bRetry ? R.string.retry_button : R.string.buy_button, new DialogInterface.OnClickListener() {
                boolean mRetry = bRetry;
                public void onClick(DialogInterface dialog, int which) {
                    if ( mRetry ) {
                        doCheck();
                    } else {
                        Intent marketIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(
                                "http://market.android.com/details?id=" + getPackageName()));
                            startActivity(marketIntent);                        
                    }
                }
            })
            .setNegativeButton(R.string.quit_button, new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int which) {
                    finish();
                }
            }).create();
    }

    private void doCheck() {
        mCheckLicenseButton.setEnabled(false);
        setProgressBarIndeterminateVisibility(true);
        mStatusText.setText(R.string.checking_license);
        mChecker.checkAccess(mLicenseCheckerCallback);
    }

    private void displayResult(final String result) {
        mHandler.post(new Runnable() {
            public void run() {
                mStatusText.setText(result);
                setProgressBarIndeterminateVisibility(false);
                mCheckLicenseButton.setEnabled(true);
            }
        });
    }

    private void displayDialog(final boolean showRetry) {
        mHandler.post(new Runnable() {
            public void run() {
                setProgressBarIndeterminateVisibility(false);
                showDialog(showRetry ? 1 : 0);
                mCheckLicenseButton.setEnabled(true);
            }
        });
    }    

    private class MyLicenseCheckerCallback implements LicenseCheckerCallback {
        public void allow(int policyReason) {
            System.out.println("Allow");
            if (isFinishing()) {
                // Don't update UI if Activity is finishing.
                return;
            }
            // Should allow user access.
            displayResult(getString(R.string.allow));
        }

        public void dontAllow(int policyReason) {
            System.out.println("dontAllow");
            if (isFinishing()) {
                // Don't update UI if Activity is finishing.
                return;
            }
            displayResult(getString(R.string.dont_allow));
            // Should not allow access. In most cases, the app should assume
            // the user has access unless it encounters this. If it does,
            // the app should inform the user of their unlicensed ways
            // and then either shut down the app or limit the user to a
            // restricted set of features.
            // In this example, we show a dialog that takes the user to Market.
            // If the reason for the lack of license is that the service is
            // unavailable or there is another problem, we display a
            // retry button on the dialog and a different message.
            displayDialog(policyReason == Policy.RETRY);
        }

        public void applicationError(int errorCode) {
            System.out.println("applicationError");
            if (isFinishing()) {
                // Don't update UI if Activity is finishing.
                return;
            }
            // This is a polite way of saying the developer made a mistake
            // while setting up or calling the license checker library.
            // Please examine the error code and fix the error.
            String result = String.format(getString(R.string.application_error), errorCode);
            displayResult(result);
        }
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        mChecker.onDestroy();
    }

}

LVL をライブラリ プロジェクトとして設定するためのチュートリアルに従っていますが、これらのインポートは問題ないようです。

なぜこのエラーが発生するのですか? 内部クラスが見つからないのはなぜですか? 右クリックして定義を表示すると、内部クラスにジャンプします。

4

3 に答える 3

2

私は同じ問題を抱えていました。

以下の手順で問題を解決しました

  1. 標準ライブラリの例を取る
  2. library.jar ファイルをライブラリ プロジェクトから libs フォルダーにコピーしました
于 2013-08-29T20:47:20.627 に答える
1

したがって、このSO Answerは、libsというフォルダーを作成し、マネージャーでダウンロードしたライセンスパッケージに含まれるライブラリプロジェクトからlibrary.jarファイルをコピーしたことを修正したものです

私が理解していないのは、この回答によると、ADT 20.0.3を使用しているため、これは私のために行われるべきでした

基本的には、私がアンドロイドから直接ダウンロードし、何が間違っていたのかを把握しようとして数時間立ち往生した例に帰着します.

なぜこれが答えなのか、それをより良くする方法がわかっている場合は、答えてください。答えをあなたのものに変更します。

于 2012-08-22T02:02:21.500 に答える
1

まったく同じ例外があり、上記の推奨事項はどれもうまくいきませんでした。

ただし、LVLプロジェクトがライブラリプロジェクトであることを確認することで、私は機能しました(プロジェクトを右クリック->プロパティ-> androidを選択し、「Is Libary」チェックボにチェックを入れます)。

これをアプリケーション プロジェクトに含めるには、これへの他の参照をすべて削除し、変更を適用します。次に、まだそこに移動していない場合は (アプリケーション プロジェクトを右クリック --> プロパティ --> android) に移動し、ライブラリ セクションで [追加] をクリックして LVL プロジェクトを選択します。変更を適用します。わかりました、きれいなプロジェクト。

これが誰かに役立つことを願っています。

于 2014-01-17T09:22:39.700 に答える