Exploring Trace Routes



Click here for a larger image.

Environment: VC6 SP4, NT4 SP3, winCE 2.0

Introduction

This project was undertaken because of the need to explore sockets and their different uses. I started by making a ping program that pinged the network addresses. The ping program was inspired by FAQs at http://tangentsoft.net/wskfaq/ and mostly used their functions!!!! The route program is an enhancement of the same program (ping program) that used raw sockets.

How to Run It

The standard Trace Route that comes with the Windows Operating System was basically an example for me to emulate. The shortcomings (which is my point of view) with the standard Trace Route was the delay it had, which takes three (and I presume ICMP Packet replies). My program takes one ICMP reply. As soon as I get an ICMP_ECHO(integer 0) reply, I know that the packet has reached the destination and the program exits.

Go to Command Prompt ... in the Dos Prompt. Type the Path or the EXE and with space, type the URL or ip Address such as C:\>TracesRoutes.exe x.x.x.x Remember to type a valid IP Address; otherwise, an error message "Destination Unreachable " would be given.

The Code

All of the code is the same except for a few changes here and there. The main function is Decode_Reply.

int decode_reply( IPHeader* reply, int bytes, sockaddr_in* from )
{
......
    // Make sure the reply is sane
    if (bytes < header_len + ICMP_MIN)
    {
        cerr << "too few bytes from " << inet_ntoa(from->sin_addr)
                                      << endl;
        return -1;
    }
    else if ( icmphdr->type != ICMP_ECHO_REPLY )
    {
        if ( icmphdr->type != ICMP_TTL_EXPIRE )
        {
            if ( icmphdr->type == ICMP_DEST_UNREACH )
            {
                cerr << "Destination unreachable" << endl;
            }
            else
            {
                cerr << "Unknown ICMP packet type "
                     << int(icmphdr->type) <<
                        " received" << endl;
            }
            return -1;
        }
        // If "TTL expired", fall through. Next test will fail
        // if we try it, so we need a way past it.
    }
    else if (icmphdr->id != (USHORT)GetCurrentProcessId())
    {
        // Must be a reply for another pinger running locally,
        // so just ignore it.
        return -2;
    }


    // Okay, we ran the gamut, so the packet must be legal --
    // dump it
    if (( icmphdr->type == ICMP_TTL_EXPIRE ) ||
        ( icmphdr->type == ICMP_ECHO_REPLY ) )
    {
        in_addr in;
        in.S_un.S_addr = reply->source_ip;
        cout << "\n Source IP " << inet_ntoa( in ) ;
        int nTime = GetTickCount () - ulTimestamp ;
        if ( nTime < 0 )
        {
            cout << "  Time: " << "<10 ms."
                 << endl;
        }
        else
        {
            cout << "  Time: " << ( GetTickCount() -
                 ulTimestamp ) << " ms." << endl;
        }
    }
.........
    return> 0;
}

Problems?

If you are facing problems, contact your system administrator. I have tested this software on both private and public IPs. Mostly, System Administrators disable this functionality. If you are on a network, you can trace another computer on same network to test it.

Comments?

Kindly send your comments to http://babarq.netfirms.com. Thanx.

Downloads

Download demo project - 36 Kb


Comments

  • TraceRoute

    Posted by Legacy on 07/31/2003 12:00am

    Originally posted by: Babar

    Updated .... but dont know how to Edit my Contribution here .... ask me for Src

    Reply
  • problem

    Posted by Legacy on 12/10/2002 12:00am

    Originally posted by: luru

    Maybe you haven't set proper wait timeout.So when it receives nothing,it will down.

    Reply
  • Source

    Posted by Legacy on 12/06/2002 12:00am

    Originally posted by: Richard

    Could you please post the source code?

    Thanks,
    Richard

    • Do you have the Java source code,please?

      Posted by fengyeqing on 04/15/2005 09:54pm

      My E_mail: sunzhiyang2003@yahoo.com.cn

      Reply
    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Live Event Date: October 29, 2014 @ 11:00 a.m. ET / 8:00 a.m. PT Are you interested in building a cognitive application using the power of IBM Watson? Need a platform that provides speed and ease for rapidly deploying this application? Join Chris Madison, Watson Solution Architect, as he walks through the process of building a Watson powered application on IBM Bluemix. Chris will talk about the new Watson Services just released on IBM bluemix, but more importantly he will do a step by step cognitive …

  • Email is the most common communication vehicle used by organizations of all shapes and sizes. Among the billions of email messages sent every day are sensitive information, critical requests, and other essential business data. IT staff bear the burden of ensuring the confidentiality, integrity, and availability of the information contained within the communication. This white paper explores the email security landscape, an assessment of the threats organizations face,  and the building blocks of an effective …

Most Popular Programming Stories

More for Developers

Latest Developer Headlines

RSS Feeds