Я пытаюсь понять, как отображать веб-страницу в моем приложении IOS. Я пытался тщательно следить за той информацией, которую я могу найти. Вот что я использую:
@implementation FirstViewController
- (void)viewDidLoad {
[super viewDidLoad];
self.productURL = @"http://google.com/";
NSURL *url = [NSURL URLWithString:self.productURL];
NSURLRequest *request = [NSURLRequest requestWithURL:url];
_webView = [[WKWebView alloc] initWithFrame:self.view.frame];
[_webView loadRequest:request];
_webView.frame = CGRectMake(self.view.frame.origin.x+50,self.view.frame.origin.y+50, self.view.frame.size.width-100, self.view.frame.size.height-200);
printf("\nReady to add the Subview");
self.view.backgroundColor = [UIColor blueColor];
[self.view addSubview:_webView];
printf("\nSubView has been added");
}
@end
Кадр смещен выше, поэтому я мог раскрасить его и увидеть, что подпредставление будет расположено там. Насколько я понимаю, веб-страница должна появиться в подвиде, но я просто получаю пустую страницу.
Я также добавил словарь NSExceptionDomains в свой Info.plist и добавил google.com со словарем, содержащим NSIncludesSubdomains, для которого установлено значение true, а для NSExceptionAllowsInsecureHTTPLoads установлено значение true, думая, что это может быть проблемой, но безрезультатно. Я пробовал несколько URL-адресов и то же самое.
Как я могу узнать, что происходит, и исправить это?





Я нашел проблему! Очевидно, мне нужно было добавить ключ «Настройки безопасности транспорта приложений» в качестве словаря в мой Info.plist и добавить ключ «Разрешить произвольные загрузки» как верный для этого. Теперь отображается!
Я не мог найти это раньше, но когда я это сделал и добавил, он отлично работал с кодом, как указано выше.
Я знаю, что вы нашли решение. Но здесь я хочу объяснить, что не так с кодом. Код на самом деле в порядке. Проблема в том, что вы пытаетесь открыть небезопасный URL-адрес http://google.com/. Любой URL-адрес, начинающийся с http://, будет заблокирован iOS. Только URL-адрес, начинающийся с https://, будет разрешен без каких-либо «Настройки безопасности транспорта приложения».
В вашем случае у вас фактически есть 2 варианта:
- Add App Transport Security Settings.
- Ensure you only calls https:// URL. You can change https://google.com and it should work without adding any App Transport Security Settings.
Что касается параметров, которые вы добавляете, «Разрешить произвольные загрузки» подходят для тестирования, но вам действительно нужно добавить домены исключений в настройках безопасности транспорта приложений. Таким образом, ваше приложение принимает только связанный URL-адрес, а не ЛЮБОЙ старый URL-адрес, который мог быть открыт путем внедрения вредоносного URL-адреса.
Вероятно, это не проблема, но я бы добавил представление в его супервизор перед загрузкой запроса. У веб-представления нет причин загружать запрос, если оно не установлено ни в одном представлении.