Sök…


Introduktion

En användbar teknik för Exchange Server-administratörer är att kunna skicka e-postmeddelanden via SMTP från PowerShell. Beroende på vilken version av PowerShell som är installerad på din dator eller server finns det flera sätt att skicka e-post via powershell. Det finns ett inbyggt cmdlet-alternativ som är enkelt och lätt att använda. Den använder cmdlet Send-MailMessage .

parametrar

Parameter detaljer
Bilagor <String []> Sökväg och filnamn på filer som ska bifogas meddelandet. Sökvägar och filnamn kan ledas till Send-MailMessage.
Bcc <String []> E-postadresser som får en kopia av ett e-postmeddelande men inte visas som mottagare i meddelandet. Ange namn (valfritt) och e-postadressen (obligatorisk), till exempel Namn någon@exempel.com eller någon@exempel.com.
Kropp <String_> E-postmeddelandets innehåll.
BodyAsHtml Det indikerar att innehållet är i HTML-format.
Cc <String []> E-postadresser som får en kopia av ett e-postmeddelande. Ange namn (valfritt) och e-postadressen (obligatorisk), till exempel Namn någon@exempel.com eller någon@exempel.com.
Credential Anger ett användarkonto som har behörighet att skicka meddelande från angiven e-postadress. Standard är den aktuella användaren. Ange namn som User eller Domain \ User, eller ange ett PSCredential-objekt.
DeliveryNotificationOption Anger alternativ för leveransavisering för e-postmeddelandet. Flera värden kan anges. Leveransmeddelanden skickas i ett meddelande till adress som anges i parametern Till. Godkända värden: Inga, OnSuccess, OnFailure, Delay, Never.
kodning Kodning för kropp och subjekt. Godkända värden: ASCII, UTF8, UTF7, UTF32, Unicode, BigEndianUnicode, Standard, OEM.
Från E-postadresser som e-postmeddelandet skickas från. Ange namn (valfritt) och e-postadressen (kräver), till exempel Namn någon@exempel.com eller någon@exempel.com.
Hamn Alternativ port på SMTP-servern. Standardvärdet är 25. Tillgängligt från Windows PowerShell 3.0.
Prioritet E-postmeddelandets prioritering. Godkända värden: Normal, Hög, Låg.
SMTPServer Namn på SMTP-servern som skickar e-postmeddelandet. Standardvärde är värdet på $ PSEmailServer-variabeln.
Ämne Ämnet för e-postmeddelandet.
Till E-postadresser som e-postmeddelandet skickas till. Ange namn (valfritt) och e-postadressen (obligatorisk), till exempel Namn någon@exempel.com eller någon@exempel.com
UseSsl Använder SSL-protokollet Secure Sockets Layer för att upprätta en anslutning till fjärrdatorn för att skicka e-post

Enkel skicka e-postmeddelande

Send-MailMessage -From sender@bar.com -Subject "Email Subject" -To receiver@bar.com -SmtpServer smtp.com

Send-MailMessage med fördefinierade parametrar

$parameters = @{
    From = 'from@bar.com'
    To = 'to@bar.com'
    Subject = 'Email Subject'
    Attachments =  @('C:\files\samplefile1.txt','C:\files\samplefile2.txt')
    BCC = 'bcc@bar.com'
    Body = 'Email body'
    BodyAsHTML = $False
    CC = 'cc@bar.com'
    Credential = Get-Credential
    DeliveryNotificationOption = 'onSuccess'
    Encoding = 'UTF8'
    Port = '25'
    Priority = 'High'
    SmtpServer = 'smtp.com'
    UseSSL = $True
}

# Notice: Splatting requires @ instead of $ in front of variable name
Send-MailMessage @parameters

SMTPClient - E-post med .txt-fil i kroppsmeddelande

# Define the txt which will be in the email body
$Txt_File = "c:\file.txt"

function Send_mail {
    #Define Email settings
    $EmailFrom = "source@domain.com"
    $EmailTo = "destination@domain.com"
    $Txt_Body = Get-Content $Txt_File -RAW
    $Body = $Body_Custom + $Txt_Body
    $Subject = "Email Subject"
    $SMTPServer = "smtpserver.domain.com"
    $SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 25) 
    $SMTPClient.EnableSsl = $false
    $SMTPClient.Send($EmailFrom, $EmailTo, $Subject, $Body)

}

$Body_Custom = "This is what contain file.txt : "

Send_mail


Modified text is an extract of the original Stack Overflow Documentation
Licensierat under CC BY-SA 3.0
Inte anslutet till Stack Overflow