using System;
using System.Runtime.InteropServices;

public struct RASCONN
{
    public int dwSize;
    public IntPtr hrasconn;
    [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 257)]
    public string szEntryName;
    [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 17)]
    public string szDeviceType;
    [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 129)]
    public string szDeviceName;
}

[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Auto)]
public struct RasStats
{
    public int dwSize;
    public int dwBytesXmited;
    public int dwBytesRcved;
    public int dwFramesXmited;
    public int dwFramesRcved;
    public int dwCrcErr;
    public int dwTimeoutErr;
    public int dwAlignmentErr;
    public int dwHardwareOverrunErr;
    public int dwFramingErr;
    public int dwBufferOverrunErr;
    public int dwCompressionRatioIn;
    public int dwCompressionRatioOut;
    public int dwBps;
    public int dwConnectionDuration;
}

[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Auto)]
public struct RasEntryName
{
    public int dwSize;
    //[MarshalAs(UnmanagedType.ByValTStr,SizeConst=(int)RasFieldSizeConstants.RAS_MaxEntryName + 1)]
    public string szEntryName;
    //#if WINVER5
    //  public int dwFlags;
    //  [MarshalAs(UnmanagedType.ByValTStr,SizeConst=260+1)]
    //  public string szPhonebookPath;
    //#endif
}
public class RAS
{
    [DllImport("Rasapi32.dll", EntryPoint = "RasEnumConnectionsA",
         SetLastError = true)]

internal static extern int RasEnumConnections
        (
        ref RASCONN lprasconn, // buffer to receive connections data
        ref int lpcb, // size in bytes of buffer
        ref int lpcConnections // number of connections written to buffer
        );

[DllImport("rasapi32.dll", CharSet = CharSet.Auto)]
    internal static extern uint RasGetConnectionStatistics(
        IntPtr hRasConn,       // handle to the connection
        [In, Out]RasStats lpStatistics  // buffer to receive statistics
        );
    [DllImport("rasapi32.dll", CharSet = CharSet.Auto)]
    public extern static uint RasHangUp(
        IntPtr hrasconn  // handle to the RAS connection to hang up
        );

[DllImport("rasapi32.dll", CharSet = CharSet.Auto)]
    public extern static uint RasEnumEntries(
        string reserved,              // reserved, must be NULL
        string lpszPhonebook,         // pointer to full path and
        //  file name of phone-book file
        [In, Out]RasEntryName[] lprasentryname, // buffer to receive
        //  phone-book entries
        ref int lpcb,                  // size in bytes of buffer
        out int lpcEntries             // number of entries written
        //  to buffer
        );

[DllImport("wininet.dll", CharSet = CharSet.Auto)]
    public extern static int InternetDial(
        IntPtr hwnd,
        [In]string lpszConnectoid,
        uint dwFlags,
        ref int lpdwConnection,
        uint dwReserved
        );

public RAS()
    {
    }
}
public enum DEL_CACHE_TYPE //要删除的类型。
{
    File,//表示internet临时文件
    Cookie //表示Cookie
}

public class RASDisplay
{
    [DllImport("wininet.dll", CharSet = CharSet.Auto)]
    public static extern bool DeleteUrlCacheEntry(
        DEL_CACHE_TYPE type
        );
    private string m_duration;
    private string m_ConnectionName;
    private string[] m_ConnectionNames;
    private double m_TX;
    private double m_RX;
    private bool m_connected;
    private IntPtr m_ConnectedRasHandle;

RasStats status = new RasStats();
    public RASDisplay()
    {
        m_connected = true;

RAS lpras = new RAS();
        RASCONN lprasConn = new RASCONN();

lprasConn.dwSize = Marshal.SizeOf(typeof(RASCONN));
        lprasConn.hrasconn = IntPtr.Zero;

int lpcb = 0;
        int lpcConnections = 0;
        int nRet = 0;
        lpcb = Marshal.SizeOf(typeof(RASCONN));

nRet = RAS.RasEnumConnections(ref lprasConn, ref lpcb, ref
            lpcConnections);

if (nRet != 0)
        {
            m_connected = false;
            return;

}

if (lpcConnections > 0)
        {
            //for (int i = 0; i < lpcConnections; i++)

//{
            RasStats stats = new RasStats();

m_ConnectedRasHandle = lprasConn.hrasconn;
            RAS.RasGetConnectionStatistics(lprasConn.hrasconn, stats);

m_ConnectionName = lprasConn.szEntryName;

int Hours = 0;
            int Minutes = 0;
            int Seconds = 0;

Hours = ((stats.dwConnectionDuration / 1000) / 3600);
            Minutes = ((stats.dwConnectionDuration / 1000) / 60) - (Hours * 60);
            Seconds = ((stats.dwConnectionDuration / 1000)) - (Minutes * 60) - (Hours * 3600);

m_duration = Hours + " hours " + Minutes + " minutes " + Seconds + " secs";
            m_TX = stats.dwBytesXmited;
            m_RX = stats.dwBytesRcved;
            //}
        }
        else
        {
            m_connected = false;
        }

int lpNames = 1;
        int entryNameSize = 0;
        int lpSize = 0;
        RasEntryName[] names = null;

entryNameSize = Marshal.SizeOf(typeof(RasEntryName));
        lpSize = lpNames * entryNameSize;

names = new RasEntryName[lpNames];
        names[0].dwSize = entryNameSize;

uint retval = RAS.RasEnumEntries(null, null, names, ref lpSize, out lpNames);

//if we have more than one connection, we need to do it again
        if (lpNames > 1)
        {
            names = new RasEntryName[lpNames];
            for (int i = 0; i < names.Length; i++)
            {
                names[i].dwSize = entryNameSize;
            }

retval = RAS.RasEnumEntries(null, null, names, ref lpSize, out lpNames);

}
        m_ConnectionNames = new string[names.Length];

if (lpNames > 0)
        {
            for (int i = 0; i < names.Length; i++)
            {
                m_ConnectionNames[i] = names[i].szEntryName;
            }
        }
    }

public string Duration
    {
        get
        {
            return m_connected ? m_duration : "";
        }
    }

public string[] Connections
    {
        get
        {
            return m_ConnectionNames;
        }
    }

public double BytesTransmitted
    {
        get
        {
            return m_connected ? m_TX : 0;
        }
    }
    public double BytesReceived
    {
        get
        {
            return m_connected ? m_RX : 0;

}
    }
    public string ConnectionName
    {
        get
        {
            return m_connected ? m_ConnectionName : "";
        }
    }
    public bool IsConnected
    {
        get
        {
            return m_connected;
        }
    }

public int Connect(string Connection)
    {
        int temp = 0;
        uint INTERNET_AUTO_DIAL_UNATTENDED = 2;
        int retVal = RAS.InternetDial(IntPtr.Zero, Connection, INTERNET_AUTO_DIAL_UNATTENDED, ref temp, 0);
        return retVal;
    }
    public void Disconnect()
    {
        RAS.RasHangUp(m_ConnectedRasHandle);
    }
}

调用方法:

RASDisplay ras = new RASDisplay();
ras.Disconnect();//断开连接
ras.Connect("ADSL");//重新拨号

注意:断开后连接时,如果不想出现确认对话框,请按下面的步骤进行设置:

1、右击“网上邻居”--属性; 
2、在随后出现的“宽带连接”窗口中,右击宽带连接,单击“属性”; 
3、在随后出现的属性对话框中,单击“选项”; 
4、把随后出现的“提示名称、密码和证书等”前面的对号去掉,点“确定”退出;

refer to :http://blog.163.com/china_yd@126/blog/static/4762981920130711721826/

C# 实现ADSL自动断网和拨号(适用于拨号用户)的更多相关文章

  1. Win10电脑经常自动掉线、自动断网的解决方法

    近期一客户称自己使用电脑上网的时候,过一段时间莫名其妙的出现自动掉线.自动断网的情况,那么遇到这个问题该怎么办?下面装机之家分享一下Win10电脑经常自动掉线.自动断网的解决方法,以Win7系统为例. ...

  2. Delphi:ADOConnection连接SQLServer自动断网问题解决

    =============================== 解决方法一:异常时关闭连接,WinXP,win7 32位大部分情况都是起作用的,不过在有些windows操作系统下(如家庭版)不起作用, ...

  3. ssh空闲一段时间后自动断网

    ssh空闲一段时间后自动断网 用客户端工具,例如securecrt连接linux服务器,有的会出现过一段时间没有任何操作,客户端与服务器就断开了连接. 造成这个的原因,主要是因为客户端与服务器之间存在 ...

  4. 解决Windows Server 2012 在VMware ESXi中经常自动断网问题

    最近一些开发人员反映他们使用的 Windows server2012 R2 虚拟机过段时间就远程连接不上了,ping也不通(已关闭防火墙),我们登录ESXi发现,Windows Server 的网络图 ...

  5. 笔记本电脑连接wifi有时候会自动断网提示有限的访问权限解决办法

    解决办法如下: [设备管理器],找到[网络适配器]第一项,右键属性

  6. bat实现监测计算机网络连接,断网自动重启网络连接

    十月一体验了windows 10预览版之后,决定继续装回正式版,尝个鲜就好了,毕竟预览版还是不稳定,环境不是很方便. 决定装个最新正式版windows 8.1,结果问题来了,无线连接总是失败,显示网络 ...

  7. Python 实现断网自动重连

    为了实现 断网了,自动连接网络原理:每隔一段时间ping一下百度,判断网络状态,没有联网的话,就模仿浏览器发一条Post给服务器import urllibimport hashlibimport su ...

  8. bat实现监测计算机无线连接,断网自动重启无线

    @echo off :Begin ping www.baidu.com if errorlevel 1 goto Reboot if errorlevel 0 goto Continue :Conti ...

  9. 解决rtl8723be无线网卡驱动频繁断网问题

    买了新本子,用的是rtl8723be无线网卡,连WIFI时总是断网.Windows下好解决,Ubuntu下可就麻烦了,又是升级内核又是编译驱动的,折腾了一天,终于找到了解决办法: # echo &qu ...

随机推荐

  1. 阿里云服务器用Docker配置运行nginx并访问

    一.Docker拉取nginx镜像 docker pull nginx:1.12.2 这里是下载的是nginx的1.12.2版本,其他版本的镜像请访问https://hub.docker.com/r/ ...

  2. ROS-单目摄像头标定

    前言:由于摄像图内部与外部的原因,生成的图像往往会发生畸变,为了避免数据源造成的误差,需要针对摄像头的参数进行标定. ros官方提供了camera_calibration软件包进行摄像头标定. 一.安 ...

  3. CSDN日报20170527 ——《人机大战,历史的见证》

    在网络层,互联网提供所有应用程序都要使用的两种类型的服务,尽管目前理解这些服务的细节并不重要,但在所有TCP/IP概述中,都不能忽略他们: 无连接分组交付服务(Connectionless Packe ...

  4. 查看md文件

    使用命令将md文件转为html,在浏览器中演示 通过npm安装i5ting_toc 安装好node之后,可以直接使用npm.Windows+R打开运行框,输入cmd,打开命令窗口.连网的情况下,输入如 ...

  5. DOM基础知识(概念、节点树、事件、Document)

    1.   DOM概念 全称为 Document Object Model,译为文档对象模型 D:文档 - DOM将HTML页面解析为一个文档 —> document对象 O:对象 - DOM将H ...

  6. Android 中的View与ViewGroup

    Android重点知识--View和ViewGroup与自定义控件 作者:丁明祥 邮箱:2780087178@qq.com 一.基础 ViewGroup 参考资料: Android 手把手教您自定义V ...

  7. Hibernate框架学习(五)——批量查询(概述)

    一.HQL查询(Hibernate Query Language)多表查询,但不复杂时使用 Hibernate独家查询语言,属于面向对象的查询语言 1.基本查询 2.条件查询 注意:HQL语句中不可能 ...

  8. Unity脚本中可以引用的类型

    Hierarchy(层级视图)面板里的对象,或者 Project(工程视图)里的Prefab.

  9. TF基础4

    模型的存储与加载 TF的API提供了两种方式来存储和加载模型: 1.生成检查点文件,扩展名.ckpt,通过在tf.train.Saver()对象上调用Saver.save()生成.包含权重和其他在程序 ...

  10. TensorFlow初学

    TensorFlow初学 基本概念 1.激活函数和成本函数 激活函数(activation function):一般是非线性函数,就是每个神经元通过这个函数将原有的来自其他神经的输入做一个非线性变化, ...