VC++ webbrowser函数使用范例

2024-06-23 17:08

本文主要是介绍VC++ webbrowser函数使用范例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[cpp]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. /*============================说明部分=================================  
  2.  实现一下函数需包含头文件  
  3. #include <Wininet.h>  
  4. #include <Shlwapi.h>  
  5. Linker : Wininet.lib  Shlwapi.lib  
  6. =================================================================*/    
  7. /*========================================END========================================*/    
  8.     
  9. /*============================说明部分=================================  
  10. 清除指定网页Cookie,注意传参,如:www.baidu.com 要写为:baidu.com  
  11. =================================================================*/    
  12. BOOL CleanUrlCache(LPCTSTR lpUrl)    
  13. {    
  14.     LPINTERNET_CACHE_ENTRY_INFO lpICEI = NULL;    
  15.     DWORD dwSize = 0;    
  16.     HANDLE hFind = FindFirstUrlCacheEntry(NULL, NULL, &dwSize);    
  17.     if (hFind == NULL && GetLastError() != ERROR_INSUFFICIENT_BUFFER)    
  18.         return FALSE;    
  19.     
  20.     lpICEI = (LPINTERNET_CACHE_ENTRY_INFO)new char[dwSize];    
  21.     hFind = FindFirstUrlCacheEntry(NULL, lpICEI, &dwSize);    
  22.     if (hFind == NULL)    
  23.     {    
  24.         delete lpICEI;    
  25.         return FALSE;    
  26.     }    
  27.     
  28.     do     
  29.     {    
  30.         if (StrStrI(lpICEI->lpszSourceUrlName, lpUrl))    
  31.         {    
  32.             int bRet = DeleteUrlCacheEntry(lpICEI->lpszSourceUrlName);    
  33.         }    
  34.         delete lpICEI;    
  35.         lpICEI = NULL;    
  36.         dwSize = 0;    
  37.     
  38.         if (!FindNextUrlCacheEntry(hFind, NULL, &dwSize) && GetLastError() != ERROR_INSUFFICIENT_BUFFER)    
  39.             break;    
  40.         lpICEI = (LPINTERNET_CACHE_ENTRY_INFO)new char[dwSize];    
  41.     } while (FindNextUrlCacheEntry(hFind, lpICEI, &dwSize));    
  42.     
  43.     if (lpICEI != NULL)    
  44.         delete lpICEI;    
  45.     return TRUE;    
  46. }    
  47. /*========================================END========================================*/    
  48.     
  49.     
  50.     
  51.     
  52. /*============================说明部分=================================  
  53. 清除IE所有Cookie  
  54. #include <Wininet.h>  
  55. Linker : Wininet.lib  
  56. =================================================================*/    
  57. void   ClearInternetCache()       
  58. {       
  59.     DWORD   dwNeeded   =   0;       
  60.     FindFirstUrlCacheEntry(NULL,   NULL,   &dwNeeded);      
  61.     
  62.     if   (GetLastError()   ==   ERROR_INSUFFICIENT_BUFFER)       
  63.     {       
  64.         unsigned   char   *buffer   =   new   unsigned   char[dwNeeded];       
  65.         try       
  66.         {       
  67.             LPINTERNET_CACHE_ENTRY_INFO   lpicei   =       
  68.                 reinterpret_cast<LPINTERNET_CACHE_ENTRY_INFO>(buffer);       
  69.             HANDLE   HFind   =     FindFirstUrlCacheEntry(NULL,   lpicei,   &dwNeeded);       
  70.             DeleteUrlCacheEntry(lpicei->lpszSourceUrlName);      
  71.     
  72.             bool   no_more_files   =   false;       
  73.             while   (!no_more_files)       
  74.             {       
  75.                 if   (FindNextUrlCacheEntry(HFind,   lpicei,   &dwNeeded))       
  76.                 {       
  77.                     DeleteUrlCacheEntry(lpicei->lpszSourceUrlName);       
  78.                 }       
  79.                 else   switch   (GetLastError())       
  80.                 {       
  81. case   ERROR_INSUFFICIENT_BUFFER:       
  82.     {       
  83.         delete   []   buffer;       
  84.         buffer   =   new   unsigned   char[dwNeeded];       
  85.         lpicei   =   reinterpret_cast<LPINTERNET_CACHE_ENTRY_INFO>(buffer);       
  86.         break;       
  87.     }       
  88. default:       
  89.     {       
  90.         no_more_files   =   true;       
  91.         break;       
  92.     }       
  93.                 }       
  94.             }    
  95.             FindCloseUrlCache(HFind);    
  96.         }       
  97.         catch   (...)       
  98.         {       
  99.             delete   []   buffer;       
  100.         }       
  101.         delete   []   buffer;                       
  102.     }       
  103. }    
  104.     
  105. /*========================================END========================================*/    
  106.     
  107. /*============================说明部分=================================  
  108. CString 转换为 VARIANT 类型  
  109. =================================================================*/    
  110. StringToVariant(CString str)    
  111. {    
  112.     VARIANT variant;    
  113.     VariantInit(&variant);    
  114.     variant.vt=VT_BSTR;    
  115.     variant.bstrVal=str.AllocSysString();    
  116.     
  117.     return variant;    
  118. }    
  119. /*========================================END========================================*/    
  120.     
  121. /*============================说明部分=================================  
  122. 打开指定URL,其中m_webBrowser 是web browser  
  123. 控件关联的控件类型的变量  
  124. =================================================================*/    
  125. OpenURL(LPCTSTR strURL)    
  126. {    
  127.     VARIANT vInfo;    
  128.     VariantInit(&vInfo);    
  129.     CString strHeaders=_T("Content-Type:application/x-WWW-form-urlencoded");    
  130.     VARIANT vHeaders=StringToVariant(strHeaders);    
  131.     m_webBrowser.Navigate(strURL,&vInfo,&vInfo,&vInfo,&vHeaders);    
  132. }    
  133. /*========================================END========================================*/    
  134.     
  135.     
  136.     
  137.     
  138. /*============================说明部分=================================  
  139. 向指定ID的HTML标记中输入文字  
  140. strID为标记的ID值   
  141. #include <mshtml.h>  
  142. #include <atlbase.h>  
  143. =================================================================*/    
  144. InputText(CString strID, CComVariant strText)    
  145. {    
  146.     HRESULT hr;    
  147.     
  148.     IDispatch *pDisp;    
  149.     pDisp=m_webBrowser.get_Document();  //得到webBrowser控件接口     
  150.     
  151.     IHTMLDocument2* pDoc;    
  152.     hr=pDisp->QueryInterface(IID_IHTMLDocument2,(void**)&pDoc); //得到网页文档接口     
  153.         
  154.     IHTMLElementCollection* pColl=NULL;    
  155.     hr=pDoc->get_all(&pColl);//得到所有网页元素记录集合     
  156.     
  157.     IDispatch *pDisp2;    
  158.     VARIANT index;//用于接收返回元素基于的索引,一般不用,设为0就好,而是用IDispatch 接收元素对象接口     
  159.     //V_VT(&index)=VT_I4;     
  160.     //V_I4(&index)=0;     
  161.     index.vt=VT_I4;    
  162.     index.lVal=0;    
  163.     
  164.     VARIANT varID;//要查找的HTML标记ID     
  165.     varID=StringToVariant(strID);    
  166.     
  167.     hr=pColl->item(varID,index,&pDisp2); //找到元素的位置     
  168.     if(S_OK==hr&&NULL!=pDisp2)    
  169.     {    
  170.         IHTMLElement* pElem=NULL;    
  171.         hr=pDisp2->QueryInterface(IID_IHTMLElement,(void**)&pElem);    
  172.     
  173.         if(S_OK==hr&&NULL!=pElem)    
  174.         {    
  175.             pElem->put_innerText(strText.bstrVal);    
  176.             pElem->Release();    
  177.         }    
  178.         pDisp2->Release();    
  179.         pDisp->Release();    
  180.     }    
  181. }    
  182. /*========================================END========================================*/    
  183. /*============================说明部分=================================  
  184. 点击指定ID值的HTML按钮  
  185. strID是按钮的ID值  
  186. #include <mshtml.h>  
  187. #include <atlbase.h>  
  188. =================================================================*/    
  189. ClickBtn(CString strID)    
  190. {    
  191.     HRESULT hr;    
  192.     IDispatch* pDisp;    
  193.     pDisp=m_webBrowser.get_Document();//①得到网页控件接口     
  194.     
  195.     IHTMLDocument2* pDoc;    
  196.     hr=pDisp->QueryInterface(IID_IHTMLDocument2,(void**)&pDoc);//②得到网页文档接口     
  197.     
  198.     IHTMLElementCollection* pColl=NULL;    
  199.     hr=pDoc->get_all(&pColl);//③得到网页元素记录集合接口     
  200.     
  201.     IDispatch* pDisp2;    
  202.     VARIANT index;    
  203.     //V_VT(&index)=VT_I4;     
  204.     //V_I4(&index)=0;     
  205.     index.vt=VT_I4;    
  206.     index.lVal=0;    
  207.     
  208.     VARIANT varID;    
  209.     varID=StringToVariant(strID);    
  210.     
  211.     hr=pColl->item(varID,index,&pDisp2);//④得到指定HTML标记接口     
  212.     
  213.     if(S_OK==hr&&NULL!=pDisp2)    
  214.     {    
  215.         IHTMLElement* pElem=NULL;    
  216.         hr=pDisp2->QueryInterface(IID_IHTMLElement,(void**)&pElem);//⑤得到确定元素接口     
  217.     
  218.         if(S_OK==hr&&NULL!=pElem)    
  219.         {    
  220.             pElem->click();    
  221.             pElem->Release();    
  222.         }    
  223.         pDisp2->Release();    
  224.         pDisp->Release();    
  225.     }    
  226. }    
  227. /*========================================END========================================*/    
  228. /*===============================================================  
  229. 根据页面Class属性值点击页面元素  
  230. =================================================================*/    
  231. void CPiLiangQianDaoDlg::ClickByClassName()    
  232. {    
  233.     IHTMLElementCollection   *objAllElement=NULL;     
  234.     IHTMLDocument2   *objDocument=NULL;     
  235.     
  236.     objDocument=(IHTMLDocument2 *)m_webBrowser.get_Document();     
  237.     //由控件得到IHTMLDocument2接口指针     
  238.     
  239.     objDocument-> get_all(&objAllElement);   //得到网页所有元素的集合     
  240.     
  241.     IHTMLElement   *   pElem   =   NULL;       
  242.     VARIANT   name;     
  243.     CComBSTR   tag;     
  244.     long     a;     
  245.     objAllElement-> get_length(&a);     
  246.     name.vt=VT_I4;    
  247.     for(int   i=0;i <a;i++)//遍历所有元素     
  248.     {     
  249.         name.lVal   =   i;     
  250.         IDispatch   *   pDispatch=NULL;     
  251.         objAllElement-> item(name,name,&pDispatch);     
  252.         IHTMLElement*   spElement;     
  253.         pDispatch-> QueryInterface(IID_IHTMLElement,   (void**)&spElement);     
  254.         BSTR   tag;     
  255.         spElement->get_className(&tag);     
  256.         CString   ss(tag);     
  257.         if(ss == "j_signbtn sign_btn2 j_cansign sign0" || ss == "j_signbtn sign_btn2 j_cansign sign1" || ss == "j_signbtn sign_btn2 j_cansign sign6")     
  258.             spElement-> click();     
  259.     }     
  260. /*=====================================================================================*/    
  261. /*=====================================================================================  
  262. 根据网页打开的进程设置进度条  
  263. 给web browser添加OnProgressChange响应函数  
  264. m_procCtrl是进度条关联的控件变量  
  265. =======================================================================*/    
  266. if(ProgressMax>0)    
  267.     m_procCtrl.SetPos(100*Progress / ProgressMax);    
  268. //========================================     
  269.     
  270. /*====================================================================  
  271. 搜索点击页面文字连接  
  272. Str为文字  
  273. =======================================================================*/    
  274. ClickItem(CString str)    
  275. {    
  276.     IHTMLElementCollection   *objAllElement=NULL;     
  277.     IHTMLDocument2   *objDocument=NULL;     
  278.             
  279.    objDocument=(IHTMLDocument2 *)m_webBrowser.get_Document();     
  280.    //由控件得到IHTMLDocument2接口指针     
  281.     
  282.     objDocument-> get_all(&objAllElement);   //得到网页所有元素的集合     
  283.     
  284.     IHTMLElement   *   pElem   =   NULL;       
  285.     VARIANT   name;     
  286.     CComBSTR   tag;     
  287.     long     a;     
  288.     objAllElement-> get_length(&a);     
  289.     name.vt=VT_I4;    
  290.     for(int   i=0;i <a;i++)//遍历所有元素     
  291.     {     
  292.         name.lVal   =   i;     
  293.         IDispatch   *   pDispatch=NULL;     
  294.         objAllElement-> item(name,name,&pDispatch);     
  295.         IHTMLElement*   spElement;     
  296.         pDispatch-> QueryInterface(IID_IHTMLElement,   (void**)&spElement);     
  297.         BSTR   tag;     
  298.         spElement-> get_outerText(&tag);     
  299.         CString   ss(tag);     
  300.         if(ss=="地图")     
  301.             spElement-> click();     
  302.     }     
  303. }    
  304. /*=====================================================================================*/    
  305. /*=======================================================================================  
  306. 在DocumentCompleteExplorer判断是否为主框架加载完毕  
  307. 在页面中有多个框架时会多次触发,可能导致页面中后面的“首页”链接得不到,可以在void   CTest2Dlg::OnDownloadCompleteExplorer1(LPDISPATCH   pDisp,   VARIANT   FAR*   URL)   
  308. 加入下面代码:   
  309. ======================================================================================*/CComQIPtr <IWebBrowser2,   &IID_IWebBrowser2>   pWeb; CComQIPtr <IHTMLDocument2,&IID_IHTMLDocument2>   pDoc2; pWeb   =   pDisp; pWeb-> get_Document((IDispatch**)&pDoc2); if   (m_ie.GetDocument()   !=   pDoc2)   return;    
  310. /*==========================================================================*/    
  311.     
  312.     
  313. /*======================================================================  
  314.    判断网页是否加载完毕  
  315. ========================================================================*/    
  316. void CPiLiangQianDaoDlg::DocumentCompleteExplorer(LPDISPATCH pDisp, VARIANT* URL)    
  317. {    
  318.     // TODO: 在此处添加消息处理程序代码     
  319.     if(m_webBrowser.get_ReadyState() == READYSTATE_COMPLETE && times == 0)     
  320.     {    
  321.      ((CListBox *)GetDlgItem(IDC_LIST_STATE))->AddString(_T("加载完毕!"));    
  322.      m_IsInitDone = 1;    
  323.      times++;    
  324.     }    
  325. }       
  326. /*======================================================================================  
  327.  截取网页部分内容,并画图显示  
  328. ======================================================================================*/    
  329. {    
  330. CClientDC hImageDC(GetDlgItem(IDC_EDIT_INFO));    
  331.     
  332.     HRESULT hr;    
  333.     
  334.     IDispatch *pDisp;    
  335.     pDisp=m_webBrowser.get_Document();  //得到webBrowser控件接口     
  336.     
  337.     IHTMLDocument2* pDoc;    
  338.     hr=pDisp->QueryInterface(IID_IHTMLDocument2,(void**)&pDoc); //得到网页文档接口     
  339.         
  340.     IHTMLElementCollection* pColl=NULL;    
  341.     hr=pDoc->get_all(&pColl);//得到所有网页元素记录集合     
  342.     
  343.     IDispatch *pDisp2;    
  344.     VARIANT index;//用于接收返回元素基于的索引,一般不用,设为就好,而是用IDispatch 接收元素对象接口     
  345.     //V_VT(&index)=VT_I4;     
  346.     //V_I4(&index)=0;     
  347.     index.vt=VT_I4;    
  348.     index.lVal=0;    
  349.     
  350.     VARIANT varID;//要查找的HTML标记ID     
  351.     varID=StringToVariant(_T("userlike_info_head_img"));    
  352.     
  353.     hr=pColl->item(varID,index,&pDisp2); //找到元素的位置     
  354.     if(S_OK==hr&&NULL!=pDisp2)    
  355.     {    
  356.         IHTMLElement3* pElem=NULL;    
  357.         hr=pDisp2->QueryInterface(IID_IHTMLElement3,(void**)&pElem);    
  358.         IHTMLElementRender *pRender =  NULL;      
  359.         pElem ->QueryInterface(IID_IHTMLElementRender, (void **) &pRender);      
  360.         pRender->DrawToDC(hImageDC);    
  361.     }    
  362. }    
  363. /*=================================================================================*/    
  364.     
  365. /*=================================================================================  
  366. 判断网页是否加在完全(包含框架)  
  367. 原理:如果直接早DocummentComple里判断的话,包含多个框架(frame)的网页就会多次激发该函数。所以这里我们这里通过pDish判断是不是主框架的的借口(最后调用该函数),如果是的话就是最后一次激发,表示主框架家在完毕,也就是整个网页加载完毕!  
  368. =====================================================================================*/    
  369. void CTieBaGuajiDlg::DocumentCompleteExplorer1(LPDISPATCH pDisp, VARIANT* URL)    
  370. {    
  371.     // TODO: 在此处添加消息处理程序代码     
  372.     CComQIPtr <IWebBrowser2,   &IID_IWebBrowser2>   pWeb;     
  373.     CComQIPtr <IHTMLDocument2,&IID_IHTMLDocument2>   pDoc2;     
  374.     pWeb   =   pDisp;     
  375.     pWeb-> get_Document((IDispatch**)&pDoc2);     
  376.     if   (m_webBrowser.get_Document()   ==   pDoc2)       
  377.     {    
  378.           ((CListBox*)GetDlgItem(IDC_LIST_STATE))->AddString(_T("初始化完成!"));    
  379.     }    
  380.     /     
  381.     /*if(0==m_count)  
  382.     {  
  383.         ((CListBox*)GetDlgItem(IDC_LIST_STATE))->AddString(_T("初始化完成!"));  
  384.         m_count++;  
  385.     }*/    
  386. }    
  387. /*=============================================================================*/    
  388. /*==============================================================================  
  389.  另外如果不想让webbrowser空间弹出错误提示可以,在对空间资源编辑时设置Slient为TRUE  
  390. ==============================================================================*/  

这篇关于VC++ webbrowser函数使用范例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087759

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象