Skip to main content

Phishing mail analysis checklist

1. before reply to any mail, please check that reply address is set as the appropriate one. from the address you received the mail and to the address the mail is suppose to going should be same. as well as check the domain name as well. because sender name, email address and domain name can be spoofed easily. so if the mail looks suspicious then check it reply-to header, domain header. you can do this by checking mail source code. for example, from thunderbard email client navigate to more > view source code 

in this source code all the necessary email header you can get.

2. check mail return path. return path says if the mail bounce back then where should the bounce back mail should come. return-path should be the sender mail address. if it is another mail address then it is suspicious. 

3. check the mail attachment. sometimes it is showing doc or excel attachment but behind this exe file is hidden. so analysis the following headers from the source code. 

Content-Type: Application/Octet-Stream

Content-Transfer-Encoding: base64 

Content-Disposition: Attachment

Here content-type header clearly saying that attachment is application which is binary and non-readable exe format to human. most email service provider forbidden to transfer exe file in email in order to prevent rogue programs transfer. that is why attacker try to hide the exe file under docs or excel or rar files. 

4. check antispam header which is X-Spamd-Bar and X-Spam-Level header. Rspamd antispam filter or if any mail server perform antispam filtering then those mail server add the above two headers in the mail source code. values are written in ++++++ sign or ****** sign. more the value comes the mail is more suspicious. though it has not been standardized so manual analysis based on suspicion.

5. another important header is Received header. it shows the trail or path of a mail message from sender to receiver. the downmost Received header is the origin mail server of the mail message. after that each server adds its header when the email pass through. here delay is count. meaning to cross each email server how much the time delay occured!! generally some seconds needs to cross hops. but if you see here time delay is huge then this is suspicious. Google has a very good online tool to calculate time delay received header. but remember if attacker compromise the email server then he can send email quickly and you cannot notice that. 

https://toolbox.googleapps.com/apps/messageheader/analyzeheader

https://toolbox.googleapps.com/apps/main/

6. check email Authentication-Results header. the value could be none | pass | fail

none means no SPF record found. Pass means SPF, DKIM, DMARC all values are correct. fail means SPF, DKIM, DMARC all values are not correct.

if these 3 values are correct that means your mail servers are authenticated by other mail services, mail servers and ISP's.

SPF - Sender policy framework. it says that what ip address or what servers are allowed to send email from that particular domain. based on that their hostname and ip addresses are published on their dns txt record. 

DKIM - Domain keys identified mail. it follows a cryptographic formula. each mail are signed by the domain private key. and public key are stored on that domain's dns txt record. other mail server or isp's can verify that the email header and email message has not been altered or tempered. 

DMARC - domain-based message authentication, reporting and conformance. it confirms senders email message are protected by both SPF and DKIM values. 

mxtoolbox is a another great tool to analyze mails. 

sometimes you need to extract url from email attachment (.yml file). for example say one of your organization user attach a suspicious email for you to analysis. that email could contain some url or link. on those cases, urlextractor can help. 

urlscan.io can help to find out what that url actually is. virustotal can also help. 

ipinfo.io will also help to find ip address of a company. 



 

Comments

Popular posts from this blog

Install Nessus from docker

Docker installation. Give the below commands one by one. apt install docker-cli apt install docker.io After the installation is complete, if you are inside wsl then give this command to start docker, because inside wsl systemd (systemctl) does not work: service docker start WSL troubleshooting : If the above command " service docker start " does not work then use below command: dockerd (It may not work if any previous docker process is running. It will show you pid of that process. Use this command to kill that process " kill -9 pid " and run dockerd command again) If " docker ps -a " giving error like " Cannot connect to the Docker daemon at unix:///run/podman/podman.sock. Is the docker daemon running? " This is because you may installed podman-docker package. If you remove the package still you will get this error but you should remove the package. Then issue this command: env | grep -i docker DOCKER_HOST=unix:///run/podman/podman.sock   -->...

Installtion of SQLMutant tool

This tool is perfectly works on ubuntu 24 system. And I found it is not working properly in kali linux 24 version.   https://github.com/blackhatethicalhacking/SQLMutant/tree/main This tool need to use along with sqlmap tool. Showing this cheat sheet for kali or debian based system.  This tool actually analyze everything and give you the vulnerable url where sql injection is possible. You just need to use then sqlmap to exploit that.   Prerequisite: apt install pipx -y (for ubuntu) pip3 install uro or pipx install uro pipx ensurepath pipx completions  (not needed)  source ~/.bashrc   or restart system If go tool is not installed then run the below two commands first ( golang-go ) or follow this link to install go (https://mahimfiroj.blogspot.com/2024/12/installing-nuclei-in-kali.html) otherwise skip this step.   dpkg -l | grep packagename (Using this command you can check package is installed or not) apt install gccgo-go -y or apt install gol...

net command cheat sheet

  To see what users present in the system: net user To see local groups in the system: net localgroup To see domain groups. This should be run on a domain controller: net group To see the details of a user along with his/her group membership: net user mahim To see who are the members of a particular group (local machine): net localgroup "administrators"    (These are not case sensitive. You can use administrators or Administrators. Both will give you same result. To see who are the members of a particular group (domain machine): net group "domain admins" Create a local user: net user localuser1 MyP@ssw0rd /add Create a domain user: net user domainuser1 MyP@ssw0rd /add /domain Add the local user to local admin group: net localgroup Administrators localuser1 /add Add the user to domain admin group: net group "Domain Admins" domainuser1 /add /domain Avi