8

MFMessageComposeViewController のインスタンスに画像を添付することで、ユーザーが画像を選択して友人に送信できるアプリがあります。MFMCVC ビューで [送信] を押した後、しばらくは期待どおりに動作します。画像付きのメッセージが受信者に正常に送信されるか、ネイティブの iMessage クライアントでメッセージの横に「メッセージが失敗しました」というラベルが表示されます (ただし、どちらの場合も、画像ネイティブ クライアントで表示されます)。ただし、送信を押してから約半分の時間 (iOS 7 を実行している iPhone 4 の場合) に発生するバグがあります。メッセージは――愛着もすべても――消え去り、二度と見られることはありません。受信者はメッセージ受信せず、iMessage の送信者のメッセージ チャネルには表示されません。

APIは非常にシンプルで、別のデモアプリhttps://github.com/timcour/mf-message-compose-でバグを確実に再現できたため、これはAppleのMFMessageComposeViewController自体のバグであると確信しています。失敗-demo.git

- (void)displaySMSComposerSheet
{
    MFMessageComposeViewController *picker = [[MFMessageComposeViewController alloc] init];
    picker.messageComposeDelegate = self;

    NSData *data = [_imageDataCache objectForKey:[_imageURLs objectAtIndex:_currentIndex]];
    [picker addAttachmentData:data
               typeIdentifier:(NSString *)kUTTypeGIF
                     filename:@"share.gif"];
    if (![self.recipientTextField.text isEqualToString:@""]) {
        picker.recipients = [NSArray arrayWithObject:self.recipientTextField.text];
    }
    picker.body = [NSString stringWithFormat:@"image: %i", _currentIndex];

    [self presentViewController:picker animated:YES completion:NULL];
}

かなりの数の成功例と失敗例で UI を観察したところ、OS にストレスがかかっているために構成ビューで競合状態が悪化しているように見えます。メモリまたは CPU ストレス (またはその両方) であるかどうかはわかりません。いずれの場合でも、送信が成功すると、連絡先を選択した直後にメッセージ チャネルの内容にそれぞれの会話の内容が取り込まれ、新しいメッセージが末尾に追加されます。しかし、バグが表面化してメッセージが消えると、通常、会話の以前のメッセージは、送信ボタンが押された後にのみ表示され、新しいメッセージは表示されません。これが実際に競合状態である場合、コンポーザ VC のメッセージ フェッチ メカニズムと-viewDidLoad.

誰かがこれに遭遇したことがありますか、および/または回避策を知っていますか? Apple にバグ レポートを提出する予定ですが、Apple からの修正を待つことを含まない解決策を見つけたいと考えています。

ノート:

  • メッセージは iPhone 4 と iPhone 5s で最も頻繁に消失しますが、iPod touch 第 5 世代 (すべて iOS 7.0.2 を実行) ではめったに消失しません。

  • このバグは、iPhone 4 のhttps://github.com/timcour/mf-message-compose-fail-demo.gitアプリを使用して、できるだけ早く同じ人に 20 枚の画像を送信することで、最も簡単に再現できます。

  • 別の (おそらく関連する) バグがあります。MFMCVC ビューで連絡先の電子メール アドレスの入力を選択した後、VC は iMessage と MMS のどちらを送信するかを決定します。テスト中に、受信者の iMessage アカウントに電話番号が関連付けられていないにもかかわらず、誤った判断を下し、メッセージを MMS として送信しようとすることがありました。これにより、送信者には正常に送信されたように見えるメッセージが送信されましたが、実際には宛先に到達できませんでした。

  • これは、多くのユーザーが Apple に不満を漏らしている「iMessage がメッセージの送信に失敗する」バグではないようです。

アップデート:

メッセージが消えて送信に失敗したときにログに記録されるスタック トレースを次に示します。

Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] ****** Failed to complete all history queries in a blocking request: (
        "********-****-****-****-************"
    )
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 1   IMFoundation                        0x0000000193acb948 IMLogBacktraceToDepth + 80
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 2   IMCore                              0x00000001939d1df8 _NSStringFromIMMessageError + 22604
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 3   IMCore                              0x00000001939c7670 IMPersonStatusComparator + 261116
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 4   ChatKit                             0x00000001923c96b8 <redacted> + 240
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 5   ChatKit                             0x00000001923933b0 <redacted> + 88
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 6   ChatKit                             0x000000019237cb70 <redacted> + 996
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 7   ChatKit                             0x0000000192414cdc <redacted> + 76
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 8   Foundation                          0x000000018e8c0834 __NSFireDelayedPerform + 392
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 9   CoreFoundation                      0x000000018dd1768c <redacted> + 28
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 10  CoreFoundation                      0x000000018dd172fc <redacted> + 804
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 11  CoreFoundation                      0x000000018dd15024 <redacted> + 1324
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 12  CoreFoundation                      0x000000018dc55b78 CFRunLoopRunSpecific + 452
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 13  GraphicsServices                    0x0000000193677830 GSEventRunModal + 168
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 14  UIKit                               0x0000000190c9305c UIApplicationMain + 1156
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 15  MessagesViewService                 0x000000010009bd80 MessagesViewService + 15744
Oct 21 12:09:17 Davids-iPhone MessagesViewService[2680] <Warning>: [Warning] 16  libdyld.dylib                       0x000000019a25baa0 <redacted> + 4
Oct 21 12:09:20 Davids-iPhone SpringBoard[16] <Warning>: LICreateIconForImage passed NULL CGImageRef image
4

2 に答える 2

1

あなたの問題は、ピッカーへの強い参照がないことです。それを ivar にし、ピッカーが作業を完全に完了したら nil にします。

于 2013-10-19T12:25:49.207 に答える
0

時刻と日付が正しく設定されていることを確認してください。エミュレーターをダウンロードするように変更し、後で元に戻すのを忘れました。その後、私のメッセージは消え始めました。時間を修正した後、問題は修正されました。乾杯

于 2013-11-13T03:13:03.080 に答える