首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C#.NET Winform -获取当前的Chrome URL需要很长时间

C#.NET Winform是一种用于开发Windows桌面应用程序的编程语言和框架。获取当前的Chrome URL是指获取正在运行的Chrome浏览器的当前网页地址。

在C#.NET Winform中,可以使用一些方法来获取当前的Chrome URL。以下是一个示例代码:

代码语言:txt
复制
using System;
using System.Diagnostics;
using System.Runtime.InteropServices;

namespace ChromeURLGetter
{
    public class ChromeURL
    {
        [DllImport("user32.dll", SetLastError = true)]
        private static extern IntPtr FindWindow(string lpClassName, string lpWindowName);

        [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        private static extern int GetWindowText(IntPtr hWnd, string lpString, int nMaxCount);

        [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        private static extern int GetWindowTextLength(IntPtr hWnd);

        [DllImport("user32.dll", SetLastError = true)]
        private static extern uint GetWindowThreadProcessId(IntPtr hWnd, out uint lpdwProcessId);

        [DllImport("kernel32.dll", SetLastError = true)]
        private static extern IntPtr OpenProcess(uint dwDesiredAccess, bool bInheritHandle, uint dwProcessId);

        [DllImport("kernel32.dll", SetLastError = true)]
        private static extern bool CloseHandle(IntPtr hObject);

        [DllImport("kernel32.dll", SetLastError = true)]
        private static extern bool ReadProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, [Out] byte[] lpBuffer, uint nSize, out int lpNumberOfBytesRead);

        private const int PROCESS_VM_READ = 0x0010;
        private const int MAX_WINDOW_TITLE_LENGTH = 256;

        public static string GetCurrentChromeURL()
        {
            IntPtr chromeMainWindowHandle = FindWindow("Chrome_WidgetWin_1", null);
            if (chromeMainWindowHandle == IntPtr.Zero)
            {
                return null; // Chrome窗口未找到
            }

            uint chromeProcessId;
            GetWindowThreadProcessId(chromeMainWindowHandle, out chromeProcessId);
            if (chromeProcessId == 0)
            {
                return null; // 无法获取Chrome进程ID
            }

            IntPtr chromeProcessHandle = OpenProcess(PROCESS_VM_READ, false, chromeProcessId);
            if (chromeProcessHandle == IntPtr.Zero)
            {
                return null; // 无法打开Chrome进程
            }

            IntPtr chromeUrlPointer;
            byte[] buffer = new byte[MAX_WINDOW_TITLE_LENGTH * 2];
            int bytesRead;
            bool success = ReadProcessMemory(chromeProcessHandle, chromeMainWindowHandle + 0x010F, buffer, (uint)buffer.Length, out bytesRead);
            if (!success || bytesRead == 0)
            {
                CloseHandle(chromeProcessHandle);
                return null; // 读取Chrome URL失败
            }

            string chromeUrl = System.Text.Encoding.Unicode.GetString(buffer, 0, bytesRead);
            chromeUrl = chromeUrl.Substring(0, chromeUrl.IndexOf('\0')); // 移除字符串中的空字符

            CloseHandle(chromeProcessHandle);
            return chromeUrl;
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            string currentURL = ChromeURL.GetCurrentChromeURL();
            Console.WriteLine("当前的Chrome URL是:" + currentURL);
        }
    }
}

这段代码通过调用Windows API来获取Chrome浏览器的主窗口句柄,然后获取Chrome进程ID,并打开该进程。接着,通过读取Chrome进程的内存,获取到当前网页的URL。

这是一个简单的示例,你可以根据实际需求进行修改和扩展。注意,这种方法可能会受到Chrome版本的影响,需要根据实际情况进行调整。

推荐的腾讯云相关产品:腾讯云服务器(CVM),腾讯云数据库(TencentDB),腾讯云函数计算(SCF),腾讯云容器服务(TKE),腾讯云人工智能(AI)等。你可以访问腾讯云官方网站(https://cloud.tencent.com/)了解更多关于这些产品的详细信息和使用指南。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • CefSharp中c#和JavaScript交互读取电脑信息

    CEF是由Marshall Greenblatt于2008年创建的基于Google Chromium的BSD许可开源项目。与主要关注谷歌Chrome应用程序开发的Chromium项目本身不同,CEF专注于在第三方应用程序中促进嵌入式浏览器用例。CEF通过提供生产质量稳定的API,发布跟踪特定Chromium版本和二进制发行版的分支机构,使用户免受基础Chromium和Blink代码复杂性的影响。CEF中的大多数功能都具有默认实现,这些实现提供丰富的功能,同时几乎不需要用户进行集成工作。目前,全球已有超过1亿个CEF安装实例嵌入到来自各种公司和行业的产品中。CEF维基百科页面上提供了使用CEF的公司和产品的部分列表。CEF的一些用例包括:

    02

    .NET实现之(WebBrowser数据采集—终结篇)

    我们继续上一篇".NET实现之(WebBrowser数据采集-基础篇)",由于时间关系这篇文未能及时编写;上一篇文章发布后,得来了部分博友的反对意见,觉得这样的文章没有意义,WebBrowser采集数据效率低下用WebRequest效率就能提高了,本人不理解,为什么同样是HTTP协议进行数据采集,效率能提高多少,在采集过程中同样要经历种种的高层协议向底层协议转换等过程,我个人感觉WebRequest是实现更多的扩展性,本人的WebBrowser数据采集,并不是谈抓取数据的效率,重点是讲解WebBrowser控件的原理,能用WebBrowser与HTML网页进行很方便的集成,本人的下一篇文章".NET实现之(WebBrowser数据采集-续)",就将用WebBrowser进行与HTML网页进行混合使用,在HTML的对象中我要在我的WebBrowser控件中通过读取数据库,将Winform的控件在HTML中进行呈现,然后将我们的Winform中的数据动态的填入HTML网页中;这样的人性化、方便性、模拟性我想是WebRequest所不能取代的,我们大部分的软件是要提供给用户使用的,有一个友好的用户界面是必须的;[王清培版权所有,转载请给出署名]

    02

    我是如何定位和处理大数据容易报错

    很长时间没跟大家共同进步了,一直都在忙某行业的深潜和发掘;所以疏远了技术的研究。刚好昨天遇到一个行业软件进行大数据导入后通过算法匹配出现报错的情况。简单地先说一下这个行业软件框架,用的是SQLlite数据库,WINFORM做的客户端,后端通过服务进行数据处理;客户端与后端服务就是通过HTTP协议传输。大体就这样,先不说什么多并发及用户控制等,反正现成的前人载树也就这样。那目前遇到的问题就是当用户导入大批量数据后,服务端写库成功后,要对数据进行逻辑分析将结果呈现在客户端。刚才都说因为客户端是通过HTTP协议传输所以客户端直读导入数据后post发送给服务端就是了,服务端写库完善,这块基本没毛病,毛病就是在对数据处理这边。大数据一处理就耗时而客户端等待时间过长就会报错。

    05

    VC++编写ActiveX控件

    暑假在做一个项目的时候,本来是用C#.NET来写的一个港口进出闸的流程控制程序,里面涉及一个响应用PLC的采集信息的问题(PLC用串口和工控机相连接),然后思考如何用C#写串口通讯程序,结果师兄在一旁直接用VC++写了一个“*.ocx控件”,并在自己的电脑上进行了测试,完工后就把生成的“*.ocx”控件注册文件复制到了我们的电脑上。我们就在C#.NET程序里面将此控件拖入到主窗口中,然后就能直接利用此控件的事件来捕捉PLC的命令了,感觉好神奇。然后,我对C++的态度有了极大的转变,以前只知道C++写窗口程序是多么麻烦啊(远不如C#.NET来得快和直接),而它的所谓“比较底层,和底层操作系统的关系比C#这些高级语言要密切很多”的好处一直都没有体会到,现在才知道,正是因为C++比较底层,比较基础,所以它可以开发出很多和语言无关的公用程序块,如dll动态链接库和COM组件,原则上,只要你的Windows的系统,用VC++开发出来的这些公用程序块就能被任何语言调用(如果不用MFC框架,而用ATL框架来编写,甚至还可以脱离Windwos系统,不仅仅实现跨语言,甚至跨平台调用,这个笔者就没有仔细研究了)。

    03
    领券