質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.35%

  • Xcode

    4327questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • iOS

    4172questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • Objective-C

    1206questions

    Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

  • WebKit

    28questions

    WebKitはAppleのSafariとAndroid, iOS, RIM Blackberry, SymbianとWebOSを含むインストール済みのモバイルブラウザの動力となっているオープンソースのウェブブラウザエンジンです。

WKWebViewでサーバからの応答がなかった場合に、エラー処理をする

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 547

salud

score 93

WKWebViewに指定したURLが存在しなかったとき、以下のようなエラーがコンソールに表示されました。

Could not signal service com.apple.WebKit.WebContent: 113: Could not find specified service
Could not signal service com.apple.WebKit.WebContent: 113: Could not find specified service
Could not signal service com.apple.WebKit.WebContent: 113: Could not find specified service
...

このとき、WKWebViewは、真っ白な状態です。

エラーであると判断したとき、メッセージを出すなど処理をしたいです。
そこで、以下のdidFailProvisionalNavigationが呼ばれるのではないかと考え、こう記述したのですが、このときコンソールには何も出力されませんでした。

- (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(WKNavigation *)navigation withError:(NSError *)error
{
    NSLog(@"didFailProvisionalNavigation");
}

何か良い方法はありませんでしょうか?
よろしくお願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+2

自分の環境で試してみましたが、didFailProvisionalNavigationが呼ばれました。
URL = "@"http://teratailsitumon.com""

ちなみにself.webView.navigationDelegate = self;は設定してますよね?

swift初心者:[Could not signal service com.apple.WebKit.Networking: 113: Could not find specified service]の対処方法のような記事を見つけましたが参考になりますかね? どのようなURLにアクセスしているかわからないので、同じ状況が再現できませんでした。

- (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(WKNavigation *)navigation withError:(NSError *)error {
    NSLog(@"Error: %@ %@", error, [error userInfo]);
}
  • Log
2018-05-18 06:57:51.806786+0900 WKw[4133:1898333] Error: Error Domain=NSURLErrorDomain Code=-1003 "A server with the specified hostname could not be found." UserInfo={_kCFStreamErrorCodeKey=8, NSUnderlyingError=0x1c024e8e0 {Error Domain=kCFErrorDomainCFNetwork Code=-1003 "(null)" UserInfo={_kCFStreamErrorCodeKey=8, _kCFStreamErrorDomainKey=12}}, NSLocalizedDescription=A server with the specified hostname could not be found., _WKRecoveryAttempterErrorKey=<WKReloadFrameErrorRecoveryAttempter: 0x1c02220c0>, NSErrorFailingURLStringKey=http://teratailsitumon.com/, NSErrorFailingURLKey=http://teratailsitumon.com/, _kCFStreamErrorDomainKey=12} {
    NSErrorFailingURLKey = "http://teratailsitumon.com/";
    NSErrorFailingURLStringKey = "http://teratailsitumon.com/";
    NSLocalizedDescription = "A server with the specified hostname could not be found.";
    NSUnderlyingError = "Error Domain=kCFErrorDomainCFNetwork Code=-1003 \"(null)\" UserInfo={_kCFStreamErrorCodeKey=8, _kCFStreamErrorDomainKey=12}";
    "_WKRecoveryAttempterErrorKey" = "<WKReloadFrameErrorRecoveryAttempter: 0x1c02220c0>";
    "_kCFStreamErrorCodeKey" = 8;
    "_kCFStreamErrorDomainKey" = 12;
}

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/18 09:05

    早朝からご回答、ありがとうございます!

    `self.webView.navigationDelegate = self;`は設定してます。

    また、パーセントエンコードも実施しておりますが、
    ユーザが意図せず、サーバに文字化けしたファイルをアップする可能性がありまして、
    リンクが正常に機能せず、また、真っ白なページが表示され続ける事が起こっておりました。

    キャンセル

  • 2018/05/18 09:29

    didFinish のハンドラは呼ばれてますか?Delegateのハンドラはいっぱいあるのでそのうちのどれかは呼ばれているのでしょうか?

    こちらでも再現できれば解決できるかもですが、何か試せるURL等あれば教えてください。

    キャンセル

  • 2018/05/18 10:02

    すみません。URLはローカルな為、試していただくことはできませんが、、
    didFinishNavigation が呼ばれてしまっている事が分かりました!

    Safariでは、「http://teratailsitumon.com」が「サーバが見つかりません」だったのに対して、私のサイトでは、「サーバに接続できません」と表示されていました。

    この、ページが表示されない場合に処理をするのは不可能なのでしょうか?

    キャンセル

  • 2018/05/18 13:20

    didFinishNavigationが呼ばれているということはページの読み込みが完了したということですね。

    あとはWeb側がどのような処理を確認したほうが良いと思います。

    // 参考1 他の質問 👇
    https://teratail.com/questions/121129

    あと他のハンドラで- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler { は呼ばれていないですか?

    // 呼ばれているのであればステータスコード等確認してみてください。
    // 参考2 👇
    https://stackoverflow.com/questions/32936168/wkwebview-catch-http-error-codes

    キャンセル

  • 2018/05/18 14:48

    ありがとうございます。
    decidePolicyForNavigationResponseからNSHTTPURLResponseでステータスコード:404が取得できました!!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Xcode

    4327questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • iOS

    4172questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • Objective-C

    1206questions

    Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

  • WebKit

    28questions

    WebKitはAppleのSafariとAndroid, iOS, RIM Blackberry, SymbianとWebOSを含むインストール済みのモバイルブラウザの動力となっているオープンソースのウェブブラウザエンジンです。