惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
S
SegmentFault 最新的问题
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Attack and Defense Labs
Attack and Defense Labs
F
Full Disclosure
Vercel News
Vercel News
N
News | PayPal Newsroom
The GitHub Blog
The GitHub Blog
H
Hacker News: Front Page
H
Heimdal Security Blog
P
Privacy International News Feed
博客园 - 司徒正美
Google DeepMind News
Google DeepMind News
N
Netflix TechBlog - Medium
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cisco Blogs
L
Lohrmann on Cybersecurity
D
Docker
Recent Announcements
Recent Announcements
Security Archives - TechRepublic
Security Archives - TechRepublic
人人都是产品经理
人人都是产品经理
C
CXSECURITY Database RSS Feed - CXSecurity.com
P
Proofpoint News Feed
T
Tailwind CSS Blog
C
Check Point Blog
博客园 - 叶小钗
Google Online Security Blog
Google Online Security Blog
Martin Fowler
Martin Fowler
Stack Overflow Blog
Stack Overflow Blog
博客园 - 聂微东
S
Secure Thoughts
博客园 - Franky
博客园_首页
阮一峰的网络日志
阮一峰的网络日志
P
Palo Alto Networks Blog
Latest news
Latest news
量子位
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 三生石上(FineUI控件)
The Cloudflare Blog
Last Week in AI
Last Week in AI
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Cyberwarzone
Cyberwarzone
小众软件
小众软件
Cisco Talos Blog
Cisco Talos Blog
Hacker News: Ask HN
Hacker News: Ask HN
T
Threatpost
T
Tenable Blog
P
Privacy & Cybersecurity Law Blog
WordPress大学
WordPress大学

博客园 - Gofficer

决战紫禁之巅 为学 C#网页自动登录和提交POST信息的多种方法 一个C#写的调用外部进程类 快速实现在Windows应用程序中支持拖拽的TreeView控件(C#) PPT转图片 开发人员,敢问路在何方? C# 实现注销、关机、重启电脑功能 ultraGrid 控件中,实现单元格内容换行显示 如何用一条sql取得第10到第20条的记录? 用Sandcastle一键生成CHM帮助文档 实现服务器端与客户端对话 C#中访问WEB页面 使用代理服务器 HTTP请求和应答 Socket套接字实现服务器端连接 Socket套接字实现客户端连接 启动和停止本地系统进程 异常处理
自定义Ping方法
Gofficer · 2007-08-24 · via 博客园 - Gofficer

namespace MyPing
{
    
using System;
    
using System.Net;
    
using System.Net.Sockets;
    
public class IcmpPacket
    
{
        
public Byte  Type;    // type of message
        public Byte  SubCode;    // type of sub code
        public UInt16 CheckSum;   // ones complement checksum of struct
        public UInt16 Identifier;      // identifier
        public UInt16 SequenceNumber;     // sequence number
        public Byte [] Data;
    }
 // class IcmpPacket
    class Ping
    
{
        
const int SOCKET_ERROR = -1;
        
const int ICMP_ECHO = 8;
        
public static void Main(string[] argv)
        
{
            
if(argv.Length==0)
            
{
                Console.WriteLine(
"Usage:Ping <hostname> -t") ;
                Console.WriteLine(
"<hostname> The name of the Host who you want to ping");
                Console.WriteLine(
"-t Optional Switch to Ping the host continuously") ;
            }

            
else if(argv.Length==1)
            
{
                PingHost(argv[
0]) ;
            }

            
else if(argv.Length==2)
            
{
                
if(argv[1]=="-t")
                
{
                    
while(true)
                    
{
                        PingHost(argv[
0]) ;
                    }

                }

                
else
                
{
                    PingHost(argv[
0]) ;
                }

            }

            
else
            
{
                Console.WriteLine(
"Error in Arguments") ;
            }

        }

        
public static void PingHost(string host)
        
{
            IPHostEntry serverHE, fromHE;
            
int nBytes = 0;
            
int dwStart = 0, dwStop = 0;
            Socket socket 
= new Socket(AddressFamily.InterNetwork, SocketType.Raw, ProtocolType.Icmp);
            
try
            
{
                serverHE 
= Dns.GetHostByName(host);
            }

            
catch(Exception)
            
{
                Console.WriteLine(
"Host not found"); // fail
                return ;
            }

            IPEndPoint ipepServer 
= new IPEndPoint(serverHE.AddressList[0], 0);
            EndPoint epServer 
= (ipepServer);
            fromHE 
= Dns.GetHostByName(Dns.GetHostName());
            IPEndPoint ipEndPointFrom 
= new IPEndPoint(fromHE.AddressList[0], 0);
            EndPoint EndPointFrom 
= (ipEndPointFrom);
            
int PacketSize = 0;
            IcmpPacket packet 
= new IcmpPacket();
            packet.Type 
= ICMP_ECHO; //8
            packet.SubCode = 0;
            packet.CheckSum 
= UInt16.Parse("0");
            packet.Identifier   
= UInt16.Parse("45");
            packet.SequenceNumber  
= UInt16.Parse("0");
            
int PingData = 32// sizeof(IcmpPacket) - 8;
            packet.Data = new Byte[PingData];
            
for (int i = 0; i < PingData; i++)
                packet.Data[i] 
= (byte)'#';
            PacketSize 
= PingData + 8;
            Byte [] icmp_pkt_buffer 
= new Byte[ PacketSize ];
            Int32 Index 
= 0;
            Index 
= Serialize(packet,icmp_pkt_buffer,PacketSize,PingData);
            
if( Index == -1 )
            
{
                Console.WriteLine(
"Error in Making Packet");
                
return ;
            }

            Double double_length 
= Convert.ToDouble(Index);
            Double dtemp 
= Math.Ceiling( double_length / 2);
            
int cksum_buffer_length = Convert.ToInt32(dtemp);
            UInt16 [] cksum_buffer 
= new UInt16[cksum_buffer_length];
            
int icmp_header_buffer_index = 0;
            
forint i = 0; i < cksum_buffer_length; i++ ) 
            
{
                cksum_buffer[i] 
=
                    BitConverter.ToUInt16(icmp_pkt_buffer,icmp_header_buffer_index);
                icmp_header_buffer_index 
+= 2;
            }

            UInt16 u_cksum 
= checksum(cksum_buffer, cksum_buffer_length);
            packet.CheckSum  
= u_cksum;
            Byte [] sendbuf 
= new Byte[ PacketSize ];
            Index 
= Serialize(packet,sendbuf,PacketSize,PingData);
            
if( Index == -1 )
            
{
                Console.WriteLine(
"Error in Making Packet");
                
return ;
            }

            dwStart 
= System.Environment.TickCount; // Start timing
            if ((nBytes = socket.SendTo(sendbuf, PacketSize, 0, epServer)) == SOCKET_ERROR)
            
{
                Console.WriteLine(
"Socket Error cannot Send Packet");
            }

            Byte [] ReceiveBuffer 
= new Byte[256];
            nBytes 
= 0;
            
bool recd =false ;
            
int timeout=0 ;
            
while(!recd)
            
{
                nBytes 
= socket.ReceiveFrom(ReceiveBuffer, 2560ref EndPointFrom);
                
if (nBytes == SOCKET_ERROR)
                
{
                    Console.WriteLine(
"Host not Responding") ;
                    recd
=true ;
                    
break;
                }

                
else if(nBytes>0)
                
{
                    dwStop 
= System.Environment.TickCount - dwStart; // stop timing
                    Console.WriteLine("Reply from "+epServer.ToString()+" in "+dwStop+"MS,\tBytes Received :"+nBytes);
                    recd
=true;
                    
break;
                }

                timeout
=System.Environment.TickCount - dwStart;
                
if(timeout>1000)
                
{
                    Console.WriteLine(
"Time Out") ;
                    recd
=true;
                }

            }

            socket.Close();
        }

        
public static Int32 Serialize(  IcmpPacket packet, Byte [] Buffer, Int32 PacketSize, Int32 PingData )
        
{
            Int32 cbReturn 
= 0;
            
int Index=0;
            Byte [] b_type 
= new Byte[1];
            b_type[
0= (packet.Type);
            Byte [] b_code 
= new Byte[1];
            b_code[
0= (packet.SubCode);
            Byte [] b_cksum 
= BitConverter.GetBytes(packet.CheckSum);
            Byte [] b_id 
= BitConverter.GetBytes(packet.Identifier);
            Byte [] b_seq 
= BitConverter.GetBytes(packet.SequenceNumber);
            Array.Copy( b_type, 
0, Buffer, Index, b_type.Length );
            Index 
+= b_type.Length;
            Array.Copy( b_code, 
0, Buffer, Index, b_code.Length );
            Index 
+= b_code.Length;
            Array.Copy( b_cksum, 
0, Buffer, Index, b_cksum.Length );
            Index 
+= b_cksum.Length;
            Array.Copy( b_id, 
0, Buffer, Index, b_id.Length );
            Index 
+= b_id.Length;
            Array.Copy( b_seq, 
0, Buffer, Index, b_seq.Length );
            Index 
+= b_seq.Length;
            Array.Copy( packet.Data, 
0, Buffer, Index, PingData );
            Index 
+= PingData;
            
if( Index != PacketSize )
            
{
                cbReturn 
= -1;
                
return cbReturn;
            }

            cbReturn 
= Index;
            
return cbReturn;
        }

        
public static UInt16 checksum( UInt16[] buffer, int size )
        
{
            Int32 cksum 
= 0;
            
int counter;
            counter 
= 0;
            
while ( size > 0 )
            
{
                UInt16 val 
= buffer[counter];
                cksum 
+= Convert.ToInt32( buffer[counter] );
                counter 
+= 1;
                size 
-= 1;
            }

            cksum 
= (cksum >> 16+ (cksum & 0xffff);
            cksum 
+= (cksum >> 16);
            
return (UInt16)(~cksum);
        }

    }
 // class ping
}