css – Cocoa webview UserAgent“webkit-legacy”问题

I solved this. Look at the selected answer below!

我一直在努力寻找什么导致OSX Cocoa应用程序的WebView与Safari不同的行为.事实证明,用户代理是不同的(很明显的),而我正在访问的网站不知道如何处理.

令人惊讶的是,这是https://messenger.com(facebook chat).

问题是它不会在屏幕上显示图片.它加载,但它实际上不显示.看看这个..

如果您看到我编号为“2”的区域,则只会看到空格.我没有检查出来.这只是空的

所以这是我原来的问题链接:Simple Swift Cocoa app with WebKit: Upload picture doesn’t work

我解决了第一个问题(谢谢答案:D),但第二个问题仍然存在.

  1. Shared picture does not show up – I labeled as 2 in the picture.
    • again,from other browsers or released apps,it shows the pictures that I shared with participants like below. (of course I censored the pictures)
      07003

要调试这个,我打开了检查元素,我发现了这一点.

<body class=" webkit-legacy webkit mac x1 body_textalign Locale_en_US _z4_" dir="ltr">

当我从Safari加载完全相同的页面时,我会看到:

<body class="safari webkit mac x1 body_textalign Locale_en_US _z4_" dir="ltr">

所以我决定从我的应用程序的WebView替换该行,并且中提琴!有用!所以…

TLDR:每次加载视图时,该如何使其工作?

我试图找到一些方法来设置我的用户代理到Safari,但我不能得到这个工作.有什么建议吗

解决方法

我创建了简单的示例应用程序并修复了此问题.我提供了与Safari相同的用户代理.之后,共享照片按预期工作.
- (void)applicationDidFinishLaunching:(NSNotification *)aNotification {
    self.webView.customUserAgent = @"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5) AppleWebKit/601.2.7 (KHTML,like Gecko) Version/9.0.1 Safari/601.2.7";
    self.webView.mainFrameURL = @"https://messenger.com";
}

之后,我比较用户代理:

原始WebView用户代理:Mozilla / 5.0(Macintosh; Intel Mac OS X 10_10_5)AppleWebKit / 600.8.9(KHTML,如Gecko)

Safari用户代理:Mozilla / 5.0(Macintosh; Intel Mac OS X 10_10_5)AppleWebKit / 601.2.7(KHTML,像Gecko)Version / 9.0.1 Safari / 601.2.7

所以,看起来我只需要更改User Agent的最后一部分.像那样:

- (void)applicationDidFinishLaunching:(NSNotification *)aNotification {
    self.webView.applicationNameForUserAgent = @"Safari/601.2.7";
    self.webView.mainFrameURL = @"https://messenger.com";
}

使用此代码,“共享照片”也可以使用.不幸的是,它不适用于我尝试过的其他applicationNameForUserAgent值.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


css的bordercolor属性怎么使用
CSS中contain属性的作用和语法
深入学习响应式布局框架:适合初学者到专家的详尽指南
CSS3选择器优先级规则
margin-top用法
选择最适合您的响应式布局框架:综合评估不同工具
使用CSS中的content属性
设计一个无缝适应不同屏幕尺寸的网站
如何处理CSS样式的层叠问题
探究最佳响应式布局框架:竞争激烈!
学习基本数据类型的快速入门:掌握常用操作技巧
CSS中float布局介绍
一同探讨响应式布局的益处
掌握响应式设计的益处,让网页在不同设备上展现完美适配!
可能导致CSS加载失败的原因有哪些?
各种基本数据类型的全面操作指南
CSS3选择器是否用于设计界面结构?
响应式布局优化移动设备适配的策略与实用技巧
伪元素怎么清除浮动
利用CSS响应式布局创作独特网页设计的设计技巧