Swift 如何使用 MFMessageComposeViewController 在短信中发送 URL

问题描述 投票:0回答:2

如何通过 MFMessageComposeViewController 发送 url?

当您从 Safari 共享网址时,它会显示丰富的链接预览。但是,我只能以纯文本形式传递 url。

这就是我想要实现的目标:

这是我的代码,仅以纯文本形式显示链接:

import MessageUI
class testVC: UIViewController, MFMessageComposeViewControllerDelegate {
    
    override func viewDidAppear(_ animated: Bool) {
        super.viewDidAppear(animated)
        sendText(toPhoneNumber: "1001001000", url: URL(string: "https://stackoverflow.com/questions/ask")!)
    }
    
    func sendText(toPhoneNumber: String?, url: URL) {
        if MFMessageComposeViewController.canSendText() {
            let messageVC = MFMessageComposeViewController()
            messageVC.body = "\(url)"
            if let number = toPhoneNumber {
                messageVC.recipients = [number]
            }
            messageVC.messageComposeDelegate = self
            self.present(messageVC, animated: true, completion: nil)
        } else {print("Cannot send message. Error.")}
    }
    
    func messageComposeViewController(_ controller: MFMessageComposeViewController, didFinishWith result: MessageComposeResult) {
        controller.dismiss(animated: true, completion: nil)
    }
}

如何通过文本发送网址?

swift text message mfmessagecomposeviewcontroller
2个回答
0
投票

也许这个中等博客可以解决问题:)

博客


-1
投票

它是自动的,并且取决于相关网址网页上的元数据。

iOS 和 macOS 中的消息将自动生成内联预览 用于人们发送的链接。默认情况下,这些呈现为灰色气泡显示 页面标题、域名和小图标。通过添加少量 在您的网站页面上打开 Graph 元数据,您可以制作这些 iMessage 通过显示图像和有意义的标题,链接预览看起来很棒。

https://developer.apple.com/library/archive/technotes/tn2444/_index.html

例如,出于测试目的,请在代码中尝试以下 URL:

http://www.apple.com/iphone

您应该得到这样的预览:

网页本身包含图像和标题的元数据。

<meta property="og:title" content="iPhone" />
<meta property="og:image" content="https://www.apple.com/v/iphone/home/t/images/home/og.png?201610171354" />

上面的元数据在预览中添加了标题和图像。没有它,您将无法预览。

您可以通过更新要生成预览的页面的元数据来测试这一点。

如果您要生成预览的网页不在您的控制之下,您的替代方案是:

  1. 请求网页管理员添加元数据
  2. 链接到您可以控制的中间网页,您可以在其中添加元数据,然后重定向到最终页面。

总而言之:您的 iOS 代码不负责生成预览 - 它是实际 URL 的网页上的元数据。

如果此答案解决了您的问题,请将其标记为正确。

© www.soinside.com 2019 - 2024. All rights reserved.