iOS 13.4でWKWebViewがクラッシュするときはWebKitへのリンクを追加

このブログ用に作っているサンプルアプリで、WKWebViewを使っているものがあります。先日、Xcodeを11.4にアップデートしたところ、このアプリがクラッシュするようになってしまいました。

対応方法などを記事にまとめました。

目次

結論

結論を先に書くと、WebKit.frameworkのリンクを追加することで修正されました。詳細を記事にまとめました。

症状と対応方法

発生している症状をまとめると次の通りです。

  1. iPhone 11 (13.4) シミュレータでアプリを起動しようとすると、クラッシュする。
  2. iPhone 11 (13.2.2) シミュレータでアプリを起動すると、クラッシュせずに正常に動作する。

クラッシュログ

クラッシュログが出力されているので、見てみました。

2020-03-27 11:13:19.558831+0900 EmbedWebBrowser[2025:60003] *** Terminating app due to uncaught exception 'NSInvalidUnarchiveOperationException', reason: 'Could not instantiate class named WKWebView because no class named WKWebView was found; the class needs to be defined in source code or linked in from a library (ensure the class is part of the correct target)'
*** First throw call stack:

... 以下省略

長いので、コールスタックの部分は省略します。また、重要なメッセージはこれです。

reason: 'Could not instantiate class named WKWebView because no class named WKWebView was found;

つまり、WKWebViewが見つからないためにクラッシュしています。WKWebViewWebKit.frameworkに入っているので、WebKit.frameworkのリンク追加で修正できそうです。

修正方法

次のように操作します。

(1) ターゲットの設定を開き、Generalタブを表示する。

(2) 「Frameworks, Libraries, and Embedded Content」の「+」ボタンをクリックする。

(3) WebKit.frameworkを選択して、「Add」ボタンをクリックする。

WebKit.frameworkへのリンクが追加され、今度は起動できるようになるはずです。試してみると、クラッシュせずに起動でき、サイトを表示することもできました。

iOS 13.2.2までは起動できていた理由

XcodeというかLLVMには、フレームワークへの自動リンク機能があります。SwiftのimportやObjective-Cの#importで必要なフレームワークに自動的にリンクする機能です。

この機能は、ビルド設定で有効化できます。Xcode 11で作ったプロジェクトではデフォルトで有効になっており、サンプルアプリのプロジェクトでも有効になっています。

この機能により、iOS 13.2.2までは起動できていたはずです。しかし、iOS 13.4では明示的なリンクが必要でした。自動リンク機能は、Clang/LLVMのModules機能により実現されていたはずなので、WebKit.frameworkのビルド時にオプションが無効になっているのではないかと思われます。

https://clang.llvm.org/docs/Modules.html

実機での動作

この問題はWebKit.frameworkを明示的にリンクすれば回避できますが、既にリリースされているアプリは大丈夫なのだろうかと心配されます。

実機での動作も確認してみましたが、同様に明示的なリンクを追加していない場合にはクラッシュしてしまいました。

試した環境は以下の通りです。

  • iPhone Xs + iOS 13.4

他のフレームワークでもクラッシュしてしまうものを見つけたときは、明示的なリンク追加を試してみましょう。

著書紹介

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

この記事を書いた人

Akira Hayashi (林 晃)のアバター Akira Hayashi (林 晃) Representative(代表), Software Engineer(ソフトウェアエンジニア)

アールケー開発代表。Appleプラットフォーム向けの開発を専門としているソフトウェアエンジニア。ソフトウェアの受託開発、技術書執筆、技術指導・セミナー講師。note, Medium, LinkedIn
-
Representative of RK Kaihatsu. Software Engineer Specializing in Development for the Apple Platform. Specializing in contract software development, technical writing, and serving as a tech workshop lecturer. note, Medium, LinkedIn

目次