Ionic app崩溃与braintree插件 - java.lang.NoSuchMethodError:没有静态方法getFont

时间:2018-01-15 11:11:59

标签: android cordova ionic-framework paypal braintree

我目前正在尝试将PayPal集成到App版本中,使用Ionic框架设置在cordova之上运行。我正在使用[离子本机braintree插件] [1]进行集成。应用程序在我的手机上构建并运行良好,初始化方法也可以工作,但每次调用presentDropInPaymentUI()方法时它都会崩溃。对于这一点,如果我在支付或不支付的情况下这样做是无关紧要的。

按下应用程序中的按钮后会调用以下代码,并将其崩溃:

public payWithPayPal(): void {
    const BRAINTREE_TOKEN = 'abc';

    const paymentOptions: PaymentUIOptions = {
        amount: '14.99',
        primaryDescription: 'Your product or service (per /item, /month, /week, etc)',
    };


    this.braintree.initialize(BRAINTREE_TOKEN)
        .then(() => console.log("Did it!"))
        .then(() => this.braintree.presentDropInPaymentUI(paymentOptions))
        .then((result:PaymentUIResult) => {
            if (result.userCancelled) {
                console.log("User cancelled payment dialog.");
            } else {
                console.log("User successfully completed payment!");
                console.log("Payment Nonce: " + result.nonce);
                console.log("Payment Result.", result);
            }
        })
        .catch((error: string) => console.error(error));

}

它与Ionics页面上的示例代码完全相同,我只是删除了applepay的东西并添加了一个控制台输出以确保正确的初始化。这是我每次调用时得到的错误:调用DIPInPayMentUI:

FATAL EXCEPTION: main
                                                                    Process: de.findlunch.findlunch, PID: 31043
                                                                    java.lang.NoSuchMethodError: No static method getFont(Landroid/content/Context;ILandroid/util/TypedValue;ILandroid/widget/TextView;)Landroid/graphics/Typeface; in class Landroid/support/v4/content/res/ResourcesCompat; or its super classes (declaration of 'android.support.v4.content.res.ResourcesCompat' appears in /data/app/de.appname.appname/base.apk)
                                                                        at android.support.v7.widget.TintTypedArray.getFont(TintTypedArray.java:119)
                                                                        at android.support.v7.widget.AppCompatTextHelper.updateTypefaceAndStyle(AppCompatTextHelper.java:208)
                                                                        at android.support.v7.widget.AppCompatTextHelper.loadFromAttributes(AppCompatTextHelper.java:110)
                                                                        at android.support.v7.widget.AppCompatTextHelperV17.loadFromAttributes(AppCompatTextHelperV17.java:38)
                                                                        at android.support.v7.widget.AppCompatTextView.<init>(AppCompatTextView.java:81)
                                                                        at android.support.v7.widget.AppCompatTextView.<init>(AppCompatTextView.java:71)
                                                                        at android.support.v7.app.AppCompatViewInflater.createView(AppCompatViewInflater.java:103)
                                                                        at android.support.v7.app.AppCompatDelegateImplV9.createView(AppCompatDelegateImplV9.java:1024)
                                                                        at android.support.v7.app.AppCompatDelegateImplV9.onCreateView(AppCompatDelegateImplV9.java:1081)
                                                                        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java)
                                                                        at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287)
                                                                        at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139)
                                                                        at com.braintreepayments.api.dropin.DropInActivity.onCreate(DropInActivity.java:88)
                                                                        at android.app.Activity.performCreate(Activity.java)
                                                                        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java)
                                                                        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java)
                                                                        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java)
                                                                        at android.app.ActivityThread.-wrap12(ActivityThread.java)
                                                                        at android.app.ActivityThread$H.handleMessage(ActivityThread.java)
                                                                        at android.os.Handler.dispatchMessage(Handler.java)
                                                                        at android.os.Looper.loop(Looper.java)
                                                                        at android.app.ActivityThread.main(ActivityThread.java)
                                                                        at java.lang.reflect.Method.invoke(Native Method)
                                                                        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java)
                                                                        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java)

这是离子信息给我的:

cli packages: (/usr/local/lib/node_modules)

@ionic/cli-utils  : 1.19.0
ionic (Ionic CLI) : 3.19.0

全球套餐:

cordova (Cordova CLI) : 8.0.0 

本地包裹:

@ionic/app-scripts : 1.3.12
Cordova Platforms  : android 6.4.0
Ionic Framework    : ionic-angular 3.0.1

系统:

Android SDK Tools : 26.1.1
Node              : v6.11.4
npm               : 5.6.0 
OS                : Linux 4.13

环境变量:

ANDROID_HOME : /home/leo/Android/Sdk

其他:

backend : pro

每次搜索都让我更新了我的sdktools / buildtools,但它们是最新版本(或者至少是android studio所说的)。似乎以前没有人对这个特定的插件有这个问题。在我的config.xml中,Targetsdk也设置为26。

如何解决这个问题的任何帮助,或者更好的集成braintree的方法都将非常感谢!

这也是我第一次在这里提问,所以如果我犯了任何错误,请随时告诉我!

1 个答案:

答案 0 :(得分:1)

哇,我没有看到这个感觉很糟糕。

好的,所以你说得对,插件崩溃了,原因就在于新的Android SDK版本。基本上,您正在使用的其他插件,它们导入的android.support版本以及braintree drop-in UI所需的android.support版本之间存在相当大的冲突。

我已经对我的仓库进行了一些修改,以减轻这种情况: https://github.com/engineerapart/cordova-plugin-braintree

您可能还需要一个after_prepare gradle脚本。这不能作为插件的一部分包含在内,因为它是一个强制所有版本的android.support相等的大锤,但是如果你需要它它会帮助你。

https://gist.github.com/codinronan/24e93bb7a8717e13279a43882ab5c4f2

顺便说一句,这是为cordova-android 7,但要使它在cordova-android 6.4上工作,你只需更新它在第48行使用的路径。我建议更新,如果你可以,应用程序性能明显更好