离子应用程序因 Braintree 插件而崩溃 - java.lang.NoSuchMethodError: 没有静态方法 getFont

Posted

技术标签:

【中文标题】离子应用程序因 Braintree 插件而崩溃 - java.lang.NoSuchMethodError: 没有静态方法 getFont【英文标题】:Ionic app crashes with braintree plugin - java.lang.NoSuchMethodError: No static method getFont 【发布时间】:2018-06-24 00:21:25 【问题描述】:

我目前正在尝试使用 Ionic 框架设置将 PayPal 集成到应用程序构建中,以在 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 的东西并添加了一个控制台输出以确保正确初始化。这是我每次调用 presentDropInPayMentUI 时都会遇到的错误:

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 是这样说的)。似乎以前没有人对这个特定插件有过这个问题。 Targetsdk 在我的 config.xml 中也设置为 26。

任何有关如何解决此问题的帮助,或集成 Braintree 的更好方法将不胜感激!

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

【问题讨论】:

【参考方案1】:

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

好吧,你是对的,插件崩溃了,它崩溃的原因是由于新的 Android SDK 版本。本质上,您正在使用的其他插件、它们导入的 android.support 版本和 Braintree 插件 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行使用的路径。如果可以的话,我建议您更新,应用程序性能明显更好.

【讨论】:

以上是关于离子应用程序因 Braintree 插件而崩溃 - java.lang.NoSuchMethodError: 没有静态方法 getFont的主要内容,如果未能解决你的问题,请参考以下文章

Objective-C 插件因大型数组的初始化而崩溃

离子应用程序在另一个HTTP GET中使用HTTP GET崩溃

应用程序因 AVAudioSession privateBeginInterruption 而崩溃

iOS:当应用程序因任何崩溃而退出时,是不是有任何委托方法

Android 应用程序因切换活动而崩溃

为啥这个应用程序会因运行时错误而崩溃?