PENTEST VIA CELLULAR NETWORK (V): NMAP PORT SCANNER WITH SMS MESSAGE
- Layout for this exercise (Smartphone and Raspberry Pi / SIM card / Modem):
data:image/s3,"s3://crabby-images/cd2c9/cd2c959ecd083de4efb77cb88e77bfb35a3c311a" alt=""
- This exercise is based on the four previous exercises:
http://www.whitelist1.com/2018/03/pentest-via-cellular-network-i-global.html
http://www.whitelist1.com/2018/03/pentest-via-cellular-network-ii.html
http://www.whitelist1.com/2018/03/pentest-via-cellular-network-iii-sms.html
http://www.whitelist1.com/2018/03/pentest-via-cellular-network-iv-port.html
1 - Writing the Python script
- The Python script used in this exercise uses libraries and scripts from previous exercises:
data:image/s3,"s3://crabby-images/83a75/83a750fb0a56a814cae37cb141757b3ccadbb975" alt=""
data:image/s3,"s3://crabby-images/58174/581747b2ee15e5469ebdf1fc372af26a22089048" alt=""
- Some libraries are imported:
data:image/s3,"s3://crabby-images/b08f5/b08f5dd93c1cacfb3e79081c4ab342262e77800a" alt=""
- A function is defined to process the SMS message requests:
data:image/s3,"s3://crabby-images/38d21/38d2115e2b19d57c3ac57a1418294e3202f5be80" alt=""
- External stored data is invoked:
data:image/s3,"s3://crabby-images/f9a4d/f9a4d5147bcbde60fe76a6b337e18d81b62a1034" alt=""
- The script waits until an SMS message arrives, then processing it, and finally giving back an answer:
data:image/s3,"s3://crabby-images/a9f92/a9f929d0a4b8d69ea10c6f0a0cc624853cb606ea" alt=""
2 - Testing the script
- First, from the smartphone an SMS message is launched asking about the port 22 of the localhost:
data:image/s3,"s3://crabby-images/9ecb3/9ecb3cf089a93dc51a089451572f072164df8ceb" alt=""
- Running the Python script at the Raspberry Pi, it detects the request from the smartphone and finally gives back an answer:
data:image/s3,"s3://crabby-images/90daa/90daa40ec37c9de1b798eafd042ad5b974ad5840" alt=""
data:image/s3,"s3://crabby-images/f0856/f08565883a838c86da1c548685137731b4304d46" alt=""
data:image/s3,"s3://crabby-images/555ff/555ff19d7a8291297d0b481a1c98f9de159d0a9f" alt=""
data:image/s3,"s3://crabby-images/cfae7/cfae70b560a6c8680d88ad5629179d4b5c5e3988" alt=""
data:image/s3,"s3://crabby-images/65787/65787996724cae4c741b51ec0aba2f62d54ce0ca" alt=""
- Before launching another test to the host 192.168.1.6, let's perform an Nmap scan in the usual way:
data:image/s3,"s3://crabby-images/b65a5/b65a5b8cf8e5c7afd9a12e2b4ea2f95ffe6647f4" alt=""
- Now, from the smartphone an SMS message is launched inquiring about the port 135 of the host 192.168.1.6:
data:image/s3,"s3://crabby-images/e12fa/e12face6e74ac30d871f342fced062a8c5e5358f" alt=""
- The Raspberry Pi gives an answer back to the smartphone via an SMS message, and the result is equal to the usual Nmap port scanning: port 135 is open.
data:image/s3,"s3://crabby-images/f921b/f921be229e5494892a50f2299faccfc408c77121" alt=""
data:image/s3,"s3://crabby-images/6e9ef/6e9efa7135f8b9c44ae8952e77947e743ec58215" alt=""
data:image/s3,"s3://crabby-images/b0930/b0930e4588e14e64a0f828ead057fdeb20af9db6" alt=""
data:image/s3,"s3://crabby-images/69df1/69df1c8f653f8ffcfec083b495960c85d6858523" alt=""