NSInvalidUnarchiveOperationException으로 인한 iOS11 WKWebview 충돌
ObjectiveC를 사용하여 하나의 뷰 컨트롤러 / 뷰가있는 iOS 11을 대상으로하는 SingleView 앱을 개발 중입니다. 뷰 상단의 Main.storyboard에서 WebKit View (WKWebView)를 떨어 뜨 렸습니다.
시뮬레이터와 iOS 11.0.1을 실행하는 iPhone 6 모두에서 충돌이 발생합니다.
포착되지 않은 예외 'NSInvalidUnarchiveOperationException'으로 인해 앱 종료, 이유 : 'WKWebView라는 클래스를 인스턴스화 할 수 없습니다.'
작동하려면 다른 것이 필요합니까? 스토리 보드에서 깨어 나면 WKWebView를 인스턴스화 할 수없는 것 같습니다.
그 외 세부 사항:
- Xcode 버전 9.0 9A235
- 스토리 보드에서 WKWebView를 제거하면 충돌이 사라집니다.
- App Base SDK-최신 iOS (iOS 11) 배포 대상 11.0
- WebView (deprecated)-UIWebView를 사용하면 작동합니다.
- 수동으로 인스턴스화하지 않았습니다.
크래시 스택 :
2017-11-06 18:38:27.765519+0200 XYZZMap[15689:1093338] *** Terminating app due to uncaught exception 'NSInvalidUnarchiveOperationException', reason: 'Could not instantiate class named WKWebView'
*** First throw call stack:
(
0 CoreFoundation 0x00000001056d01cb __exceptionPreprocess + 171
1 libobjc.A.dylib 0x0000000105032f41 objc_exception_throw + 48
2 CoreFoundation 0x0000000105744b95 +[NSException raise:format:] + 197
3 UIKit 0x000000010692d2c0 UINibDecoderDecodeObjectForValue + 323
4 UIKit 0x000000010692d5db UINibDecoderDecodeObjectForValue + 1118
5 UIKit 0x000000010692d172 -[UINibDecoder decodeObjectForKey:] + 89
6 UIKit 0x00000001062f866b -[UIView initWithCoder:] + 969
7 UIKit 0x000000010692d43d UINibDecoderDecodeObjectForValue + 704
8 UIKit 0x000000010692d172 -[UINibDecoder decodeObjectForKey:] + 89
9 UIKit 0x00000001066dd1a7 -[UIRuntimeConnection initWithCoder:] + 178
10 UIKit 0x000000010692d43d UINibDecoderDecodeObjectForValue + 704
11 UIKit 0x000000010692d5db UINibDecoderDecodeObjectForValue + 1118
12 UIKit 0x000000010692d172 -[UINibDecoder decodeObjectForKey:] + 89
13 UIKit 0x00000001066dc3a4 -[UINib instantiateWithOwner:options:] + 1262
14 UIKit 0x00000001063f8d07 -[UIViewController _loadViewFromNibNamed:bundle:] + 383
15 UIKit 0x00000001063f9610 -[UIViewController loadView] + 177
16 UIKit 0x00000001063f9941 -[UIViewController loadViewIfRequired] + 195
17 UIKit 0x00000001063fa19e -[UIViewController view] + 27
18 UIKit 0x00000001062cdd17 -[UIWindow addRootViewControllerViewIfPossible] + 122
19 UIKit 0x00000001062ce41f -[UIWindow _setHidden:forced:] + 294
20 UIKit 0x00000001062e12bf -[UIWindow makeKeyAndVisible] + 42
21 UIKit 0x0000000106255015 -[UIApplication _callInitializationDelegatesForMainScene:transitionContext:] + 4711
22 UIKit 0x000000010625a245 -[UIApplication _runWithMainScene:transitionContext:completion:] + 1720
23 UIKit 0x0000000106615c6c __111-[__UICanvasLifecycleMonitor_Compatability _scheduleFirstCommitForScene:transition:firstActivation:completion:]_block_invoke + 924
24 UIKit 0x00000001069e33ef +[_UICanvas _enqueuePostSettingUpdateTransactionBlock:] + 153
25 UIKit 0x0000000106615865 -[__UICanvasLifecycleMonitor_Compatability _scheduleFirstCommitForScene:transition:firstActivation:completion:] + 249
26 UIKit 0x00000001066160c3 -[__UICanvasLifecycleMonitor_Compatability activateEventsOnly:withContext:completion:] + 668
27 UIKit 0x0000000106f73c11 __82-[_UIApplicationCanvas _transitionLifecycleStateWithTransitionContext:completion:]_block_invoke + 262
28 UIKit 0x0000000106f73aca -[_UIApplicationCanvas _transitionLifecycleStateWithTransitionContext:completion:] + 444
29 UIKit 0x0000000106c61b9c __125-[_UICanvasLifecycleSettingsDiffAction performActionsForCanvas:withUpdatedScene:settingsDiff:fromSettings:transitionContext:]_block_invoke + 420
30 UIKit 0x0000000106e5cc3e _performActionsWithDelayForTransitionContext + 100
31 UIKit 0x0000000106c61998 -[_UICanvasLifecycleSettingsDiffAction performActionsForCanvas:withUpdatedScene:settingsDiff:fromSettings:transitionContext:] + 231
32 UIKit 0x00000001069e2a4c -[_UICanvas scene:didUpdateWithDiff:transitionContext:completion:] + 392
33 UIKit 0x0000000106258ac6 -[UIApplication workspace:didCreateScene:withTransitionContext:completion:] + 523
34 UIKit 0x0000000106821523 -[UIApplicationSceneClientAgent scene:didInitializeWithEvent:completion:] + 369
35 FrontBoardServices 0x000000010b539158 -[FBSSceneImpl _didCreateWithTransitionContext:completion:] + 338
36 FrontBoardServices 0x000000010b541c4d __56-[FBSWorkspace client:handleCreateScene:withCompletion:]_block_invoke_2 + 235
37 libdispatch.dylib 0x00000001096b643c _dispatch_client_callout + 8
38 libdispatch.dylib 0x00000001096bbaf4 _dispatch_block_invoke_direct + 592
39 FrontBoardServices 0x000000010b56d672 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 24
40 FrontBoardServices 0x000000010b56d328 -[FBSSerialQueue _performNext] + 464
41 FrontBoardServices 0x000000010b56d897 -[FBSSerialQueue _performNextFromRunLoopSource] + 45
42 CoreFoundation 0x00000001056732b1 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
43 CoreFoundation 0x0000000105712d31 __CFRunLoopDoSource0 + 81
44 CoreFoundation 0x0000000105657c19 __CFRunLoopDoSources0 + 185
45 CoreFoundation 0x00000001056571ff __CFRunLoopRun + 1279
46 CoreFoundation 0x0000000105656a89 CFRunLoopRunSpecific + 409
47 GraphicsServices 0x000000010be609c6 GSEventRunModal + 62
48 UIKit 0x000000010625bd30 UIApplicationMain + 159
49 XYZZMap 0x00000001047274bf main + 111
50 libdyld.dylib 0x0000000109732d81 start + 1
51 ??? 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
감사!
펜촉 / 스토리 보드를로드 할 때 NSInvalidUnarchiveOperationException은 펜촉 / 스토리 보드에 런타임이 이해하지 못하는 개체가 있음을 의미합니다. 이는 이러한 종류의 개체를 정의하는 프레임 워크가 없기 때문입니다.
따라서이 경우 앱이 스토리 보드에서 디코딩 될 때 WKWebView가 무엇인지 이해하도록 앱 대상을 WebKit 프레임 워크에 연결해야합니다.
다음은 올바르게 구성된 경우 앱 대상의 빌드 단계를 보여주는 스크린 샷입니다.
Target-> General-> Linked framework and libraries-> 아래 + 기호 클릭-> webKit.Framwork 검색-> 추가를 선택합니다.
WKWebView
코드에서 UIWebView
인스턴스 가있을 수있는 동안 스토리 보드에 인스턴스 가 있는지 확인
저도 같은 문제에 직면했습니다.
WKWebView를 Outlet으로 선언하지 않고
시뮬레이터에서 실행하는 동안이 오류가 발생했습니다.
아울렛을 추가 한 후 잘 작동했습니다.
도움이 되었기를 바랍니다 :)
'programing' 카테고리의 다른 글
커밋을 위해 준비되지 않은 github 변경 사항 (0) | 2021.01.16 |
---|---|
Knowntype 특성과 함께 사용되는 클래스에서 Obsolete 특성을 사용할 때 컴파일러 경고를 무시하는 방법 (0) | 2021.01.16 |
16 자의 영숫자 문자열을 효율적으로 생성 (0) | 2021.01.16 |
Android는 갤러리에서 ImageView로 이미지 가져 오기 (0) | 2021.01.16 |
C #에서 null 값을 int로 설정하는 방법은 무엇입니까? (0) | 2021.01.16 |