Batファイルを介してファイルをGmailアカウントに送信し、そのbatファイル内のメール情報を暗号化して、誰かがbatファイルを開いたときにメール情報を取得できないようにしたいと考えています。
ロジック:など
インターネットが正しく機能しているかどうかを確認します
インターネットが正しく機能しているかどうかを確認します
後で実行するようにスケジュールしないか、スタートアップに追加する場合
完了したら、スケジュールまたはスタートアップから削除してください!
PowerShellスクリプトを作成して電子メールを送信するロジックを使用して、添付ファイルを含めて電子メールを送信する必要がある場合は、を使用して電子メールを実行できます。機密性の高い値をスクリプトロジックにハードコーディングするのではなく、機密性の高い値を引数として渡すバッチスクリプト。
PowerShellスクリプトロジックは、Gmailのローカルメールボックスのユーザー名、メールを送信するために認証するパスワードなどの引数を受け入れることができます。それ以外の場合は、スクリプトにハードコーディングする必要はありません。
スクリプトまたは関数内では、$ args配列を使用して名前のない引数を参照できます。たとえば、すべての引数をコマンドレットに渡します。特定の引数をその位置で参照することもできます。
"最初の引数は" +
$Args[0]
"です"2番目の引数は" +
$Args[1]
"です
また、ロジックをバッチスクリプトに配置して、実行時に機密値を渡すことができる引数を含めることもできます。機密値をハードコーディングするのではなく、引数のプレースホルダーを使用します。
%
を使用して引数の値を取得し、その後にコマンドラインでの数値位置を取得できます。最初に渡される項目は常に%1
で、2番目の項目は常に%2
です。バッチスクリプト内の%*はすべての引数を参照します(例:
%1 %2 %3 %4 %5
...%255
)%1
から%9
までの引数のみが番号で参照できます。
このようにして、スクリプトを開いた場合、保護する必要のある機密値は、スクリプトロジックに公開またはハードコードされず、だれでもスクリプトへの読み取りアクセス権を持つユーザーを確認できます。
重要な注意:各PowerShellスクリプトの例の名前の下部にセクションがありますBatch Execute Script実行するバッチスクリプトから使用するロジック、またはバッチスクリプトへの適切な引数としてユーザー名、パスワード、添付ファイルのフルパスを渡すために使用するロジックがあります ie sendemail.bat "<GmailAccountName>" "<GmailPassword>" "<FullPathAttachment>"
$Username = $args[0]
$EmailPassword = $args[1]
$Username = $Username
$EmailTo = "[email protected]"
$EmailFrom = "[email protected]"
$Subject = "Email Subject"
$Body = "Email Body"
$SMTPServer = "smtp.gmail.com"
$SMTPMessage = New-Object System.Net.Mail.MailMessage($EmailFrom, $EmailTo, $Subject, $Body)
$SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 587)
$SMTPClient.EnableSsl = $true
$SMTPClient.Credentials = New-Object System.Net.NetworkCredential($Username, $EmailPassword);
$SMTPClient.Send($SMTPMessage)
バッチ実行スクリプト
SET GmailAccount=%~1 SET GmailPassword=%~2 SET PowerShellDir=C:\Windows\System32\WindowsPowerShell\v1.0 CD /D "%PowerShellDir%" Powershell -ExecutionPolicy Bypass -Command "& 'C:\Scripts\SendEmail.ps1' '%GmailAccount%' '%GmailPassword%'"
$Username = $args[0]
$EmailPassword = $args[1]
$Attachment = $args[2]
$Username = $Username
$EmailTo = "[email protected]"
$EmailFrom = "[email protected]"
$Subject = "Email Subject"
$Body = "Email Body"
$SMTPServer = "smtp.gmail.com"
$SMTPMessage = New-Object System.Net.Mail.MailMessage($EmailFrom, $EmailTo, $Subject, $Body)
$Attachment = New-Object System.Net.Mail.Attachment($Attachment)
$SMTPMessage.Attachments.Add($Attachment)
$SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 587)
$SMTPClient.EnableSsl = $true
$SMTPClient.Credentials = New-Object System.Net.NetworkCredential($Username, $EmailPassword);
$SMTPClient.Send($SMTPMessage)
バッチ実行スクリプト
SET GmailAccount=%~1 SET GmailPassword=%~2 SET Attachment=%~3 SET PowerShellDir=C:\Windows\System32\WindowsPowerShell\v1.0 CD /D "%PowerShellDir%" Powershell -ExecutionPolicy Bypass -Command "& 'C:\Scripts\SendEmail.ps1' '%GmailAccount%' '%GmailPassword%' '%Attachment%'"
Gmailアカウントのユーザー名、Gmailアカウントのパスワード、および添付ファイルへの完全なパスを渡すだけのオールインワンの動的バッチスクリプトを次に示します。
@ECHO OFF
SET GmailAccount=%~1
SET GmailPassword=%~2
SET Attachment=%~3
CALL :PowerShell
CD /D "%PowerShellDir%"
Powershell -ExecutionPolicy Bypass -Command "& '%PSScript%' '%GmailAccount%' '%GmailPassword%' '%Attachment%'"
EXIT
:PowerShell
SET PowerShellDir=C:\Windows\System32\WindowsPowerShell\v1.0
SET PSScript=%temp%\~tmpSendeMail.ps1
IF EXIST "%PSScript%" DEL /Q /F "%PSScript%"
ECHO $Username = $args[0]>> "%PSScript%"
ECHO $EmailPassword = $args[1]>> "%PSScript%"
ECHO $Attachment = $args[2]>> "%PSScript%"
ECHO >> "%PSScript%"
ECHO $Username = $Username >> "%PSScript%"
ECHO $EmailTo = "[email protected]" >> "%PSScript%"
ECHO $EmailFrom = "[email protected]" >> "%PSScript%"
ECHO $Subject = "Email Subject" >> "%PSScript%"
ECHO $Body = "Email Body" >> "%PSScript%"
ECHO $SMTPServer = "smtp.gmail.com" >> "%PSScript%"
ECHO $SMTPMessage = New-Object System.Net.Mail.MailMessage($EmailFrom, $EmailTo, $Subject, $Body) >> "%PSScript%"
ECHO $Attachment = New-Object System.Net.Mail.Attachment($Attachment) >> "%PSScript%"
ECHO $SMTPMessage.Attachments.Add($Attachment) >> "%PSScript%"
ECHO $SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 587) >> "%PSScript%"
ECHO $SMTPClient.EnableSsl = $true >> "%PSScript%"
ECHO $SMTPClient.Credentials = New-Object System.Net.NetworkCredential($Username, $EmailPassword) >> "%PSScript%"
ECHO $SMTPClient.Send($SMTPMessage) >> "%PSScript%"
GOTO :EOF
このようにバッチスクリプトを実行します。 。 。
sendemail.bat "<GmailAccountName>" "<GmailPassword>" "<FullPathAttachment>"
このスクリプトでは、GmailAccount=
、GmailPassword=
、Attachment=
の変数にハードコードされた値が設定されますが、実行されると、"%~FN0"
を介してスクリプトが完全に削除されます。0
はスクリプト自体です。つまり、このスクリプトを確実にコピーしてから、この情報を公開したくない場所で実行するマシンからのみコピーを実行する必要があります。
@ECHO OFF
SET GmailAccount=<GmailAccountName>
SET GmailPassword=<GmailPassword>
SET Attachment=<FullAttachmentPath>
CALL :PowerShell
CD /D "%PowerShellDir%"
Powershell -ExecutionPolicy Bypass -Command "& '%PSScript%' '%GmailAccount%' '%GmailPassword%' '%Attachment%'"
IF EXIST "%~FN0" DEL /Q /F "%~FN0"
EXIT
:PowerShell
SET PowerShellDir=C:\Windows\System32\WindowsPowerShell\v1.0
SET PSScript=%temp%\~tmpSendeMail.ps1
IF EXIST "%PSScript%" DEL /Q /F "%PSScript%"
ECHO $Username = $args[0]>> "%PSScript%"
ECHO $EmailPassword = $args[1]>> "%PSScript%"
ECHO $Attachment = $args[2]>> "%PSScript%"
ECHO >> "%PSScript%"
ECHO $Username = $Username >> "%PSScript%"
ECHO $EmailTo = "[email protected]" >> "%PSScript%"
ECHO $EmailFrom = "[email protected]" >> "%PSScript%"
ECHO $Subject = "Email Subject" >> "%PSScript%"
ECHO $Body = "Email Body" >> "%PSScript%"
ECHO $SMTPServer = "smtp.gmail.com" >> "%PSScript%"
ECHO $SMTPMessage = New-Object System.Net.Mail.MailMessage($EmailFrom, $EmailTo, $Subject, $Body) >> "%PSScript%"
ECHO $Attachment = New-Object System.Net.Mail.Attachment($Attachment) >> "%PSScript%"
ECHO $SMTPMessage.Attachments.Add($Attachment) >> "%PSScript%"
ECHO $SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 587) >> "%PSScript%"
ECHO $SMTPClient.EnableSsl = $true >> "%PSScript%"
ECHO $SMTPClient.Credentials = New-Object System.Net.NetworkCredential($Username, $EmailPassword) >> "%PSScript%"
ECHO $SMTPClient.Send($SMTPMessage) >> "%PSScript%"
GOTO :EOF
変数置換(FOR /?)
さらに、FOR変数参照の置換が強化されました。これで、次のオプションの構文を使用できます。
%~I - expands %I removing any surrounding quotes (") %~nI - expands %I to a file name only %~fI - expands %I to a fully qualified path name