-[UIThreadSafeNode canPerformAction:withSender:]:認識されないセレクターがインスタンスに送信されました


9

iOSアプリでこのクラッシュに直面しています。

Fatal Exception: NSInvalidArgumentException
0  CoreFoundation                 0x1b9079c30 __exceptionPreprocess
1  libobjc.A.dylib                0x1b8d940c8 objc_exception_throw
2  CoreFoundation                 0x1b8f77fc0 -[NSOrderedSet initWithSet:copyItems:]
3  CoreFoundation                 0x1b907e3d4 ___forwarding___
4  CoreFoundation                 0x1b9080570 _CF_forwarding_prep_0
5  UIKitCore                      0x1bcf33444 -[UIKeyboardImpl deleteForwardAndNotify:]
6  UIKitCore                      0x1bcf39154 __57-[UIKeyboardImpl acceptPredictiveInput:executionContext:]_block_invoke
7  UIKitCore                      0x1bcf5b0c8 -[UIKeyboardTaskExecutionContext returnExecutionToParentWithInfo:]
8  UIKitCore                      0x1bcf366ec __100-[UIKeyboardImpl addWordTerminator:afterSpace:afterAcceptingCandidate:elapsedTime:executionContext:]_block_invoke
9  UIKitCore                      0x1bcf5b0c8 -[UIKeyboardTaskExecutionContext returnExecutionToParentWithInfo:]
10 UIKitCore                      0x1bcf2bdc0 __55-[UIKeyboardImpl handleKeyboardInput:executionContext:]_block_invoke_2
11 UIKitCore                      0x1bcf5cd70 -[UIKeyboardTaskEntry execute:]
12 UIKitCore                      0x1bcf5b6d4 -[UIKeyboardTaskQueue continueExecutionOnMainThread]
13 libobjc.A.dylib                0x1b8d8faf0 -[NSObject performSelector:withObject:]
14 Foundation                     0x1b946ec10 __NSThreadPerformPerform
15 CoreFoundation                 0x1b8ff5260 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__
16 CoreFoundation                 0x1b8ff51b4 __CFRunLoopDoSource0
17 CoreFoundation                 0x1b8ff4920 __CFRunLoopDoSources0
18 CoreFoundation                 0x1b8fef7ec __CFRunLoopRun
19 CoreFoundation                 0x1b8fef098 CFRunLoopRunSpecific
20 GraphicsServices               0x1c3159534 GSEventRunModal
21 UIKitCore                      0x1bd10f7ac UIApplicationMain
22 Haraj                          0x102fc6058 main + 15 (main.m:15)
23 libdyld.dylib                  0x1b8e6ef30 <redacted>

これまでに100件を超えるクラッシュが報告されています。これは、iOS 12およびiOS 13でのみ発生します。

これがどのように発生し、どのように再現するのかわかりません。

スタックトレースにアプリのコードが表示されません。

ここに完全なクラッシュレポートをアップロードしました

任意の助けをいただければ幸いです。

回答:


10

これは、iOSのテキストエントリ「http://www.openradar.me/15114422」の「転送削除」に関連する古代のバグの退行のようです

新しい「スワイプしてタイプする」キーボードが原因で、それは後退したと思います。

修正するには2つのオプションがあります。

  1. 非推奨のUIWebViewをWKWebViewにアップグレードします。
  2. Hackyソリューション:UIThreadSafeNode実行時に不足しているセレクターを挿入します。

不足しているセレクターを挿入する方法のコード例を次に示します。

BOOL canPerformAction(id withSender) {
    return false;
} 

- (void)viewDidLoad {
   [super viewDidLoad];

   Class class = NSClassFromString(@"UIThreadSafeNode");
   class_addMethod(class, @selector(canPerformAction:withSender:), (IMP)canPerformAction, "@@:");
}

メソッドの挿入は、AppDelegateのように、一度だけロードされる場所に置く必要があります。

必要な場合の完全なサンプルプロジェクトは次のとおりです。https//github.com/elliotfiske/UIWebView-TextEntry-CrashFix/tree/master

再現方法:

UIWebViewでテキスト入力フォームを作成し、いくつかの単語を入力して、カーソルを文の真ん中の単語の正確な終わりに移動します。

次に、予測テキストの提案のいずれかを選択します。動作中のバグをここで確認してください:クラッシュ再現の画面記録


2
WKWebViewを使用しています。私はあなたのハッキングソリューションが好きです。うまくいくことを願っています!:)
Abdullah Umer

iOS13.2.2開発者ベータ版のUIWebViewでクラッシュを再現できません
harshith7823
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.