I need my locally-installed, thick-client application (Qt / C++) to generate a ready-to-be-sent email message on the client's machine:
- This message must contain the contents of a relatively small (15K - 200K) binary file.
- Many of my users will be disconnected at the time this message is generated, so it is possible the email will need to sit in the outbox until a later time.
- This app开发者_JAVA百科lication will run on Windows, Mac OS X, and various Linux distros (official support for Ubuntu/Debian and Fedora), and there is no requirement that specific email clients need to be installed.
I have already tried:
- Opening a
mailto:
link usingQDesktopServices::openUrl()
with theattach
(orattachment
) parameter. But those parameters are not officially part of the protocol, and some clients (notably Outlook) ignore them. - Encoding the file using Base64 and adding it as part of the
body
parameter of amailto:
link. But the length of themailto
link is truncated by some email clients (again, notably Outlook) so this will not work.
Google Picasa achieves this (at least, on Windows; haven't checked other OS's) when you send pictures from within the application. It creates a message with the attachments and some pre-filled text. You can then edit the message and send at your convenience. Any ideas how they are doing this?
You could create an .eml file and open it which should give you the effect you want as long as there is any email client registered in the system to handle files with this extension. I'm sure this is not as universal as the mailto:
scheme but if mailto:
does not work for you I think this could be the second best option to try.
From http://www.coolutils.com/Formats/EML
Since EML files are created to comply with the industry RFC 822 standard, they can be used with most e-mail clients, servers and applications. Besides the Microsoft Outlook Express, EML files can be opened using most e-mail clients, such as Microsoft Outlook, Microsoft Entourage, Mozilla Thunderbird, Apple Mail, and IncrediMail.
Side note
When I click 'E-mail' in Picasa I get dialog where I can choose which application (Thunderbird or Google Mail) I want to send email with. This means Picasa knows specific email client being used to send email and can use custom method, specific to chosen email client, to send email. This is of course just speculation but it might be that Picasa makes user to choose email client because there's no generic way to do what you ask about.
I dont think you are using the correct approach ; use MAPI / C++. I have done this several times both in Outlook / Thunderbird using MAPI/ C++ . You can choose the default email client by querying the registry ; I think thats what all applications do.
Also see the link here http://lists.trolltech.com/qt-interest/2006-02/thread00861-0.html
Some time ago I've began to write a small library for opening the 'default email client' in a platform independent way. It still may need some work, but you can use it as a base if you want: https://github.com/picaschaf/qt-email
精彩评论