How to get the email address of the current logged-in user?

后端 未结 3 1208
悲&欢浪女
悲&欢浪女 2020-12-17 21:12

I\'m new to VBA and trying to get an automated word document working. At the moment there is a Button in the document that which upon pressing, will fire off an email with t

相关标签:
3条回答
  • 2020-12-17 21:24

    It all depends on the definition of "the current user address".

    1. The address of the primary account in Outlook can be retrieved from Appication.Session.CurrentUser (returns Recipient object). Use Recipient.Address property. Note however that for an Exchange account (Recipient.AddressEntry.Type == "EX") you will receive an EX type address. To retrieve the SMTP address, use Recipient.AddressEntry.GetExchangeUser().PrimarySmtpAddress. Be prepared to handle nulls/exceptions in case of errors. This is what you most likely need in your particular case.

      On the Extended MAPI level (C++ or Delphi), use IMAPISession::QueryIdentity (you can test it in OutlookSpy - click IMAPISession button, then QueryIdentity). You can then read the PR_ADDRTYPE property ("EX" vs "SMTP") and PR_EMAIL_ADDRESS (when PR_ADDRTYPE = "SMTP") or (in case of Exchange) PR_SMTP_ADDRESS (not guaranteed to be present) and PR_EMS_AB_PROXY_ADDRESSES (multivalued property will Exchange addresses, including all proxy (alias) addresses).

    2. In case of multiple accounts in the profile, an email can be sent or received through multiple accounts. In that case use MailItem.SendUsingAccount (returns Account object, can be null - in that case use Application.Session.CurentUser). This is valid both for received, sent or emails being composed (Application.ActiveInspector.CurrentItem or Application.ActiveExplorer.ActiveInlineResponse).

    3. All accounts in a given profile can be accessed using the Namespace.Accounts collection (Application.Session.Accounts). Account's address can be accessed using Account.SmtpAddress property. Note that the Outlook Object Model only exposes mail accounts. Some store accounts (such as PST) are not in the collection since they do not have an intrinsic user identity even if some other accounts (such as POP3/SMTP) can deliver to that store. If you want to access all accounts, you can use Redemption and its RDOSession.Accounts collection (RDOAccounts object).

      On the Extended MAPI level, the accounts are exposed through the IOlkAccountManager interface. You can play with it in OutlookSpy if you click the IOlkAccountManager button.

    4. In case of delegate Exchange stores, the store owner is not exposed through the Outlook Object Model. You can either use Extended MAPI (note that the PR_MAILBOX_OWNER_ENTRYID property is only exposed by the online store, it is not available in a cached store). You can parse the Exchange store entry id and extract the EX type address from it. You can then construct the GAL object entry id given the EX address. You can also access the store owner using Redemption and its RDOExchangeMailboxStore object and its Owner property.

    0 讨论(0)
  • 2020-12-17 21:28

    Usually, the email address is the name assigned to Outlook Mail Folders.
    So try this:

    '~~> add these lines to your code
    Dim olNS As Outlook.NameSpace
    Dim olFol AS Outlook.Folder
    
    Set olNS = OL.GetNamespace("MAPI")
    Set olFol = olNS.GetDefaultFolder(olFolderInbox)
    
    MsgBox olFol.Parent.Name '~~> most cases contains the email address
    

    This is assuming your are using Early Bind with the object reference properly set.
    Another way to access such info is directly use Namespace properties.

    MsgBox olNS.Accounts.Item(1).DisplayName '~~> usually email address
    MsgBox olNS.Accounts.Item(1).SmtpAddress '~~> email address
    MsgBox olNS.Accounts.Item(1).UserName '~~> displays the user name
    

    I hope any of the above somehow helps.

    0 讨论(0)
  • 2020-12-17 21:28

    This answer is for Late Binding so you don't need to have reference libraries. Place the following code in a module:

        Dim OL As Object, olAllUsers As Object, oExchUser As Object, oentry As Object, myitem As Object
        Dim User As String
    
        Set OL = CreateObject("outlook.application")
        Set olAllUsers = OL.Session.AddressLists.Item("All Users").AddressEntries
    
        User = OL.Session.CurrentUser.Name
    
        Set oentry = olAllUsers.Item(User)
    
        Set oExchUser = oentry.GetExchangeUser()
    
        msgbox oExchUser.PrimarySmtpAddress
    
    0 讨论(0)
提交回复
热议问题