У меня есть сценарий PowerShell, который проверяет хранилище сертификатов на предмет истекающих сертификатов. Эти результаты будут отображаться в интерфейсе командной строки. Я хочу изменить этот сценарий для отправки результатов вывода в теле письма по электронной почте. Я знаю, как отправить электронное письмо через PowerShell с помощью сообщения send-mailmessage CmdLet, но я не уверен, как получить результаты скрипта и отправить их по электронной почте ...
Вот сценарий:
param([int]$InNumberOfDays=180,[switch]$ExcludeAutoEnroll)
function WriteCertInfo($cert)
{
#just a lot of code to get the fields into an object
$certObj = "" | Select RequesterName,RequestType,ExpirationDate,CommonName,EnrollmentFlags
$RequesterName=$cert -match "Requester Name:.*Request Type:"
$startLength="Requester Name:".Length
$lineLength=$matches[0].Length -("Request Type:".Length + $startLength)
$OutRequesterName=$matches[0].SubString($startLength,$lineLength)
$certObj.RequesterName=$OutRequesterName
$RequestType=$cert -match "Request Type:.*Certificate Expiration Date:"
$startLength="Request Type:".Length
$lineLength=$matches[0].Length - ("Certificate Expiration Date:".Length + $startLength)
$OutRequestType=$matches[0].SubString($startLength,$lineLength)
$certObj.RequestType=$OutRequestType
$ExpirationDate = $cert -match "Certificate Expiration Date:.*Issued Common Name:"
$startLength="Certificate Expiration Date:".Length
$lineLength=$matches[0].Length - ("Issued Common Name:".Length + $startLength)
$OutExpirationDate=$matches[0].SubString($startLength,$lineLength)
$certObj.ExpirationDate=$OutExpirationDate
$IssuedCommonName= $cert -match "Issued Common Name:.*Template Enrollment Flags:"
$startLength="Issued Common Name:".Length
$lineLength=$matches[0].Length - ("Template Enrollment Flags:".Length + $startLength)
$OutCommonName=$matches[0].SubString($startLength,$lineLength)
$certObj.CommonName=$OutCommonName
$EnrollmentFlags= $cert -match "Template Enrollment Flags:.*"
$startLength="Template Enrollment Flags:".Length
$lineLength=$matches[0].Length - ($startLength)
$OutEnrollmentFlags=$matches[0].SubString($startLength,$lineLength)
$certObj.EnrollmentFlags=$OutEnrollmentFlags
if($ExcludeAutoEnroll)
{
if(($OutEnrollmentFlags -match "CT_FLAG_AUTO_ENROLLMENT") -eq $false)
{
$script:CertToList+=$certObj
}
}
else
{
$script:CertToList+=$certObj
}
}
$CertToList=@()
$today=Get-Date
$endperiod=$today.AddDays($InNumberOfDays)
$tester=certutil -view -restrict "NotAfter>=$today,NotAfter<=$endperiod" -out
"RequestID,RequesterName,RequestType,NotAfter,CommonName,EnrollmentFlags"
$arr=$tester -match "Row \d*:"
$numberOfCerts=$arr.length
$line=[string]::join(" ",$tester)
for($certNo=0;$certNo -lt $numberOfCerts;$certNo=$certNo+1)
{
$r1=$arr[$certNo]
if($certNo -ne ($numberOfCerts-1))
{
$r2=$arr[$certNo+1]
}
else
{
$r2="Maximum Row Index"
}
$isFound=$line -match "$r1 .* $r2"
$NumberOfChars=$matches[0].Length - $r2.Length
$thisCert=$matches[0].SubString(0,$NumberOfChars)
WriteCertInfo($thisCert)
}
$CertToList
Итак, вы уже выполнили сложную часть создания своего списка в $CertToList
. Вы, вероятно, слишком долго думаете, как написать электронное письмо, и именно это вас сбивает с толку. Помните, что Powershell упрощает вашу жизнь. Если это кажется слишком сложным, вероятно, есть более простой способ сделать это. В любом случае вам нужно выяснить следующие переменные и добавить их в свой код:
$smtpServer = "server.domain.com"
$smtpFrom = "emailfrom@address.com"
$smtpTo = "emailto@address.com"
$messageSubject = "The subject line of the email"
Затем добавьте эту строку в самый конец вашего кода:
Send-MailMessage -From "$smtpFrom" -To "$smtpTo" -Subject "$messageSubject" -Body "$($CertToList)" -SMTPServer "$smtpServer"
Вы заметите, что я заметил ваш $CertToList
переменная особым образом. Я сделал это, чтобы Powershell точно знала, что $ CertToList - это переменная, и помещала ее содержимое в тело. Теперь вы можете сделать тело как хотите, вы можете сделать что-нибудь вроде:
-Body "This email contains the cert list: `n`n $($CertToList)"
Поскольку форматирование вывода в приглашении PowerShell происходит, когда вы фактически выводите $CertToList
, и вас это здесь не интересует, вы можете создать структуру HTML для представления вывода в почтовом сообщении.
Обновить Поскольку вы хотите встроить встроенное вложение в виде изображения, нам придется самостоятельно создавать и отправлять электронную почту, а не полагаться на Send-MailMessage
:
# Smtp details as outlined by Colyn1337
$smtpServer = "server.domain.com"
$smtpFrom = "emailfrom@address.com"
$smtpTo = "emailto@address.com"
$messageSubject = "The subject line of the email"
# Set up an SmtpClient for sending the message
$smtpClient = New-Object Net.Mail.SmtpClient
$smtpClient.Host = $smtpServer
# Create the MailMessage you want to send
$mailMessage = New-Object Net.Mail.MailMessage
$mailMessage.From = $smtpFrom
$mailMessage.To.Add($smtpTo)
$mailMessage.Subject = $messageSubject
# Create the html content for the mail
# Add embedded image resource to HTML
$htmlReport = "<image src=cid:DangeRussLogo>"
# And then the table with your data
$htmlReport += "<table>"
$htmlReport += "`n"
$htmlReport += "<tr>"
$htmlReport += "<th>RequestID</th>"
$htmlReport += "<th>RequesterName</th>"
$htmlReport += "<th>RequestType</th>"
$htmlReport += "<th>NotAfter</th>"
$htmlReport += "<th>CommonName</th>"
$htmlReport += "<th>EnrollmentFlags</th>"
$htmlReport += "</tr>"
$htmlReport += "`n"
foreach($cert in $CertToList)
{
$htmlReport += "<tr>"
$htmlReport += "<td>$($cert.RequestID)</td>"
$htmlReport += "<td>$($cert.RequesterName)</td>"
$htmlReport += "<td>$($cert.RequestType)</td>"
$htmlReport += "<td>$($cert.NotAfter)</td>"
$htmlReport += "<td>$($cert.CommonName)</td>"
$htmlReport += "<td>$($cert.EnrollmentFlags)</td>"
$htmlReport += "</tr>"
$htmlReport += "`n"
}
$htmlReport += "</table>"
# Now create an AlternateView from the HTML contents
$messageBody = [Net.Mail.AlternateView]::CreateAlternateViewFromString($htmlReport, 'text/html')
# Create a Linked Resource from the logo image
$imageMimeType = New-Object System.Net.Mime.ContentType("image/png")
$embeddedImage = New-Object Net.Mail.LinkedResource("C:\Users\DangeRuss\logo.png", $imageMimeType)
$embeddedImage.ContentId = "DangeRussLogo"
# Add the resource to the HTML view
$messageBody.LinkedResources.Add($embeddedImage)
# Add the HTML view to the MailMessage
$mailMessage.AlternateViews.Add($messageBody)
# And finally send the message
$smtpClient.Send($mailMessage)
Если вы хотите использовать .jpeg
или .jpg
файл вместо PNG, измените MimeType с «image / png» на «image / jpeg».