亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Linux Shell > 正文

腳本實現SSH登錄郵件報警

2020-07-27 19:05:25
字體:
來源:轉載
供稿:網友

登錄保護是一個非常重要的環節,下面通過圖文并茂的方式給大家詳細講解下:


前兩天@cyy 給我發了一個圖

然后我就想到USHQ的ssh登錄app通知功能,然后就像如果把這個部署到自用的服務器就好了。至少多一層安全系數。

首先要感謝@Legion 幫忙搞定了幾個錯誤以及搞定了Geo2IP的JSON轉換。 (P.S.此人為自動化運維大神級人物,現任職于德國一數據統計企業。)

當然,我和他相比我就是戰五渣了...大家一定要多向 @Legion 學習啊~~

說下需要做的準備:

sendmail或者Postfix
php
bash
CentOS/Debian/Ubuntu
若你的生產環境中沒有php sendmail Postfix等組件,請移步:

@Legion: Linux之使用shell腳本實現ssh登錄報警

參考文件

首先是報警腳本文件

Shell

#!/bin/sh########################################################################## File Name: Login-alert.sh# Author: Jason# Email: master#deamwork.com# Created Time: Tue Jul 21 2015 21:23:16 PM CST ##########################################################################require jq#wget http://stedolan.github.io/jq/download/linux64/jq -O /usr/local/bin/jq#chmod +x /usr/local/bin/jq#if error, please # following one#PATH=/usr/local/nginx/sbin:/usr/local/php/bin:/usr/local/mysql/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin#Geo2IP by Legion(http://www.dwhd.org/)eval `curl -s "http://ip.taobao.com/service/getIpInfo.php?ip=${SSH_CLIENT%% *}" | jq . | awk -F':|[ ]+|"' '{if($3~/^(country|area|region|city|isp)$/){print $3"="$7}}'`#html mail contentcat >> mail-no-base64.html <<EOF#請自行準備郵件模板,以下為可能用到的變量#輸出主機名 `hostname`#輸出登錄端口 ${SSH_CLIENT##* }#輸出登錄來源IP ${SSH_CLIENT%% *}#輸出IP地址歸屬地 {country}_${area}_${region}_${city}_${isp}#輸出登錄時間 `date`EOF#Base64 Encodingbase64 mail-no-base64.html > mail-base64.html#使用Sendmail#sendmail -t >/dev/null 2>&1 <<EOF#to:example@example.com#from:Example<example@example.com>#subject:[`hostname`]服務器登錄告警#`cat mail-no-base64.html`#EOF#使用postfix#cat >> mail.php <<EOF#<?php#/$to = "example@example.com";#/$subject = "[`hostname`]服務器登錄告警";#/$message = "`cat mail-base64.html`";#/$headers = "MIME-Version: 1.0" . "/r/n";#/$headers .= "Content-Type: text/html; charset=/"utf-8/"" . "/r/n";#/$headers .= "Content-Transfer-Encoding: base64" . "/r/n";#/$headers .= 'From: Example<example@example.com>' . "/r/n";#/$send = mail(/$to,/$subject,/$message,/$headers);#if(/$send){echo 'Mail Send Successful.';}else{echo 'Failed.';}#?>#EOF#使用 SMTP (require smtp-class.php)cat >> mail.php <<EOF<?phprequire("smtp-class.php"); /$smtpserver = "smtp.example.com";/$smtpserverport = 25;/$smtpusermail = "example@example.com";/$smtpemailto = "example@example.com";/$smtpuser = "example";/$smtppass = "password";/$mailsubject = "[`hostname`]服務器登錄告警";/$mailbody = "`cat mail-base64.html`";/$mailtype = "HTML";/$smtp = new smtp(/$smtpserver,/$smtpserverport,true,/$smtpuser,/$smtppass);/$smtp->debug = TRUE;/$smtp->sendmail(/$smtpemailto, /$smtpusermail, /$mailsubject, /$mailbody, /$mailtype); ?>EOFphp mail.phpyes y | rm mail-no-base64.html mail-base64.html mail.php

然后是如何觸發這個腳本:

Shell

復制代碼 代碼如下:

echo "screen -fa -d -m -S WL /etc/Login-alert.sh" >> /etc/profile

用這種方法, 新開終端或者復制終端都會觸發報警

如果使用smtp方式,請保存以下文件為smtp-class.php

PHP

<?phpclass smtp{  /* Public Variables */  var $smtp_port;  var $time_out;  var $host_name;  var $log_file;  var $relay_host;  var $debug;  var $auth;  var $user;  var $pass;  /* Private Variables */   var $sock;  /* Constractor */  function smtp($relay_host = "", $smtp_port = 25,$auth = false,$user,$pass)  {    $this->debug = FALSE;    $this->smtp_port = $smtp_port;    $this->relay_host = $relay_host;    $this->time_out = 30; //is used in fsockopen()     $this->auth = $auth;//auth    $this->user = $user;    $this->pass = $pass;    $this->host_name = "localhost"; //is used in HELO command     $this->log_file = "";    $this->sock = FALSE;}  /* Main Function */  function sendmail($to, $from, $subject = "", $body = "", $mailtype, $cc = "", $bcc = "", $additional_headers = "")  {    $mail_from = $this->get_address($this->strip_comment($from));    $body = ereg_replace("(^|(/r/n))(/.)", "/1./3", $body);    $header .= "MIME-Version:1.0/r/n";    if($mailtype=="HTML")    {      $header .= "Content-Type: text/html; charset=/"utf-8/"" . "/r/n";      $header .= "Content-Transfer-Encoding: base64" . "/r/n";    }    $header .= "To: ".$to."/r/n";    if ($cc != "")     {      $header .= "Cc: ".$cc."/r/n";    }    $header .= "From: $from<".$from.">/r/n";    $header .= "Subject: ".$subject."/r/n";    $header .= $additional_headers;    $header .= "Date: ".date("r")."/r/n";    $header .= "X-Mailer:By TianhaiTech (PHP/".phpversion().")/r/n";    list($msec, $sec) = explode(" ", microtime());    $header .= "Message-ID: <".date("YmdHis", $sec).".".($msec*1000000).".".$mail_from.">/r/n";    $TO = explode(",", $this->strip_comment($to));    if ($cc != "")     {      $TO = array_merge($TO, explode(",", $this->strip_comment($cc)));      }    if ($bcc != "")     {      $TO = array_merge($TO, explode(",", $this->strip_comment($bcc)));    }    $sent = TRUE;    foreach ($TO as $rcpt_to)     {      $rcpt_to = $this->get_address($rcpt_to);      if (!$this->smtp_sockopen($rcpt_to))       {        $this->log_write("Error: Cannot send email to ".$rcpt_to."/n");        $sent = FALSE;        continue;      }      if ($this->smtp_send($this->host_name, $mail_from, $rcpt_to, $header, $body))       {        $this->log_write("E-mail has been sent to <".$rcpt_to.">/n");      }       else       {        $this->log_write("Error: Cannot send email to <".$rcpt_to.">/n");        $sent = FALSE;      }      fclose($this->sock);      $this->log_write("Disconnected from remote host/n");    }    return $sent;  }  /* Private Functions */  function smtp_send($helo, $from, $to, $header, $body = "")  {    if (!$this->smtp_putcmd("HELO", $helo))     {      return $this->smtp_error("sending HELO command");    }    #auth    if($this->auth)    {      if (!$this->smtp_putcmd("AUTH LOGIN", base64_encode($this->user)))       {        return $this->smtp_error("sending HELO command");      }      if (!$this->smtp_putcmd("", base64_encode($this->pass)))       {        return $this->smtp_error("sending HELO command");      }    }    if (!$this->smtp_putcmd("MAIL", "FROM:<".$from.">"))     {      return $this->smtp_error("sending MAIL FROM command");    }    if (!$this->smtp_putcmd("RCPT", "TO:<".$to.">"))     {      return $this->smtp_error("sending RCPT TO command");    }    if (!$this->smtp_putcmd("DATA"))    {      return $this->smtp_error("sending DATA command");    }    if (!$this->smtp_message($header, $body))     {      return $this->smtp_error("sending message");    }    if (!$this->smtp_eom())    {      return $this->smtp_error("sending <CR><LF>.<CR><LF> [EOM]");    }    if (!$this->smtp_putcmd("QUIT"))     {      return $this->smtp_error("sending QUIT command");    }    return TRUE;  }  function smtp_sockopen($address)  {    if ($this->relay_host == "")     {      return $this->smtp_sockopen_mx($address);    }     else    {      return $this->smtp_sockopen_relay();    }  }  function smtp_sockopen_relay()  {    $this->log_write("Trying to ".$this->relay_host.":".$this->smtp_port."/n");    $this->sock = @fsockopen($this->relay_host, $this->smtp_port, $errno, $errstr, $this->time_out);    if (!($this->sock && $this->smtp_ok()))     {      $this->log_write("Error: Cannot connenct to relay host ".$this->relay_host."/n");      $this->log_write("Error: ".$errstr." (".$errno.")/n");      return FALSE;    }    $this->log_write("Connected to relay host ".$this->relay_host."/n");    return TRUE;;  }  function smtp_sockopen_mx($address)  {    $domain = ereg_replace("^.+@([^@]+)$", "/1", $address);    if (!@getmxrr($domain, $MXHOSTS))     {      $this->log_write("Error: Cannot resolve MX /"".$domain."/"/n");      return FALSE;    }    foreach ($MXHOSTS as $host)     {      $this->log_write("Trying to ".$host.":".$this->smtp_port."/n");      $this->sock = @fsockopen($host, $this->smtp_port, $errno, $errstr, $this->time_out);      if (!($this->sock && $this->smtp_ok()))       {        $this->log_write("Warning: Cannot connect to mx host ".$host."/n");        $this->log_write("Error: ".$errstr." (".$errno.")/n");        continue;      }      $this->log_write("Connected to mx host ".$host."/n");      return TRUE;    }    $this->log_write("Error: Cannot connect to any mx hosts (".implode(", ", $MXHOSTS).")/n");    return FALSE;  }  function smtp_message($header, $body)  {    fputs($this->sock, $header."/r/n".$body);    $this->smtp_debug("> ".str_replace("/r/n", "/n"."> ", $header."/n> ".$body."/n> "));    return TRUE;  }  function smtp_eom()  {    fputs($this->sock, "/r/n./r/n");    $this->smtp_debug(". [EOM]/n");    return $this->smtp_ok();  }  function smtp_ok()  {    $response = str_replace("/r/n", "", fgets($this->sock, 512));    $this->smtp_debug($response."/n");    if (!ereg("^[23]", $response))     {      fputs($this->sock, "QUIT/r/n");      fgets($this->sock, 512);      $this->log_write("Error: Remote host returned /"".$response."/"/n");      return FALSE;    }    return TRUE;  }  function smtp_putcmd($cmd, $arg = "")  {    if ($arg != "")     {      if($cmd=="")       {        $cmd = $arg;      }      else      {        $cmd = $cmd." ".$arg;      }    }    fputs($this->sock, $cmd."/r/n");    $this->smtp_debug("> ".$cmd."/n");    return $this->smtp_ok();  }  function smtp_error($string)  {    $this->log_write("Error: Error occurred while ".$string."./n");    return FALSE;  }  function log_write($message)  {    $this->smtp_debug($message);    if ($this->log_file == "")    {      return TRUE;    }    $message = date("M d H:i:s ").get_current_user()."[".getmypid()."]: ".$message;    if (!@file_exists($this->log_file) || !($fp = @fopen($this->log_file, "a")))     {      $this->smtp_debug("Warning: Cannot open log file /"".$this->log_file."/"/n");      return FALSE;;    }    flock($fp, LOCK_EX);    fputs($fp, $message);    fclose($fp);    return TRUE;  }  function strip_comment($address)  {    $comment = "/([^()]*/)";    while (ereg($comment, $address))     {      $address = ereg_replace($comment, "", $address);    }    return $address;  }  function get_address($address)  {    $address = ereg_replace("([ /t/r/n])+", "", $address);    $address = ereg_replace("^.*<(.+)>.*$", "/1", $address);    return $address;  }  function smtp_debug($message)  {    if ($this->debug)     {      echo $message;    }  }}

?>
實現效果:

有需要的朋友可以參考下,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲国产日韩2020| 欧美性生活大片免费观看网址| 亚洲女人天堂色在线7777| 亚洲免费福利视频| 精品久久久久久亚洲国产300| 国产精品毛片a∨一区二区三区|国| 亚洲精品欧美日韩专区| 欧美日韩性视频| 国产精品高潮呻吟久久av黑人| 久久久中文字幕| www.久久久久久.com| 国产精品无av码在线观看| 久久成人人人人精品欧| 亚洲欧美在线播放| 国产精品成人品| 国产欧美一区二区白浆黑人| 国产中文字幕91| 日韩精品福利网站| 亚洲国产精品久久久久秋霞不卡| 亚洲精品欧美一区二区三区| 日韩国产在线看| 亚洲综合最新在线| 亚洲一区二区三区乱码aⅴ| 2021国产精品视频| 久久久久久久97| 亚洲国产91色在线| 欧美激情免费看| 亚洲欧美日韩一区在线| 国产精品男女猛烈高潮激情| 欧美激情一级精品国产| 国产一区二区三区在线观看视频| 日韩精品亚洲精品| 97精品国产91久久久久久| 久久伊人免费视频| 国产精品黄页免费高清在线观看| 亚洲国产精品小视频| 中文字幕精品av| 久久69精品久久久久久国产越南| 亚洲夜晚福利在线观看| 欧美亚洲第一页| 亚洲v日韩v综合v精品v| 亚洲国产精品yw在线观看| 91精品视频专区| 久久91亚洲精品中文字幕| 日韩中文综合网| 欧美成人剧情片在线观看| 亚洲精品久久在线| 欧美刺激性大交免费视频| 国产精品久久久久久久天堂| 国产午夜精品全部视频在线播放| 国产精品盗摄久久久| 国产精品高潮在线| 久久国产精品久久精品| 国产日韩在线播放| 亚洲人成网站色ww在线| 久久成年人视频| 精品国产一区二区三区在线观看| 欧美日韩国产在线看| 国产精品久久久久久av| 亚洲xxxx妇黄裸体| 伊人成人开心激情综合网| 国产精品自在线| 日韩电影在线观看永久视频免费网站| 亚洲老司机av| 欧美日韩中文在线| 国产成人精彩在线视频九色| 日韩女优人人人人射在线视频| 日韩av电影在线播放| 色诱女教师一区二区三区| 国产亚洲一区二区在线| 国产精品对白刺激| 久久成人一区二区| 日韩av资源在线播放| 国产精品日韩一区| 国模精品视频一区二区| 欧美在线视频观看| 裸体女人亚洲精品一区| 久久久伊人日本| 91欧美激情另类亚洲| 精品亚洲国产视频| 欧美激情免费在线| 欧美日韩成人在线视频| 日韩av一卡二卡| 久久成人人人人精品欧| 日韩免费看的电影电视剧大全| 亚洲片在线资源| 久久久久久久av| 色婷婷综合久久久久中文字幕1| 日韩最新av在线| 国产suv精品一区二区三区88区| 亚洲第一男人av| 亚洲r级在线观看| 亚洲国产精品嫩草影院久久| 欧美激情综合色综合啪啪五月| xxxxxxxxx欧美| 国产精品无av码在线观看| 国内精品久久久久久影视8| 亚洲视频免费一区| 亚洲免费成人av电影| 欧美日韩性生活视频| 国产小视频国产精品| 久久99青青精品免费观看| 亚洲一区中文字幕在线观看| 91欧美视频网站| 国产一区二区在线免费视频| 日韩av123| 久久久免费精品视频| 国产精品观看在线亚洲人成网| 91色琪琪电影亚洲精品久久| 久久夜色精品国产亚洲aⅴ| 欧美专区在线播放| 欧美激情a在线| 国产精品国产福利国产秒拍| 不卡在线观看电视剧完整版| 18性欧美xxxⅹ性满足| 日韩欧美在线字幕| 成人午夜一级二级三级| 亚洲精品黄网在线观看| 久久网福利资源网站| 亚洲欧美色图片| 26uuu另类亚洲欧美日本一| 亚洲www视频| 国产精品大片wwwwww| 久久天天躁狠狠躁夜夜躁2014| 97精品久久久中文字幕免费| 亚洲欧洲国产伦综合| xxx欧美精品| 精品中文字幕在线观看| 日韩免费观看视频| 日本电影亚洲天堂| 91精品免费看| 欧亚精品中文字幕| 欧美日韩视频在线| 日韩国产精品一区| 国内偷自视频区视频综合| 日韩av综合中文字幕| 精品久久久久久久久久久久| 日韩欧美国产骚| 国产精品www| 日韩精品视频三区| 国产网站欧美日韩免费精品在线观看| 欧美性猛交xxxx乱大交| 欧美在线亚洲一区| 久久这里有精品视频| 91理论片午午论夜理片久久| 91亚洲va在线va天堂va国| 国产精品第二页| 成人黄色片网站| 亚洲天堂日韩电影| 久久综合九色九九| 亚洲欧洲国产一区| 国产91色在线免费| y97精品国产97久久久久久| 国产成人精品日本亚洲| 欧美日韩成人在线观看| 欧美在线中文字幕| 国产亚洲精品美女久久久| 日韩中文字幕久久| 久久人人爽人人爽爽久久| 国产视频久久久| 欧美一区深夜视频| www国产亚洲精品久久网站| 欧美在线观看日本一区| 日韩在线视频线视频免费网站|