C++ 与 php 的交互 之----- C++ 获取 网页文字内容,获取 php 的 echo 值。

转载请声明出处!

http://www.cnblogs.com/linguanh/category/633252.html

      距离上次 谈 C++ 制作json 或者其他数据传送给 服务器,时隔两个多月。

      链接:http://www.cnblogs.com/linguanh/p/4340119.html

 

      这次是从服务器上 中获取 文字内容到控制台,或者写入本地文本等操作,废话不多说,开讲。

      

-----------------------------------------------------------分割线-------------------------------------------------------------

      测试服务器是: 新浪云 sea;

      测试内容:获取 由 php 脚步从服务器中 读取出来的 数据,我这里是 微信用户的openID;

      工具:VS 2012;

 

先上直观的图片,后上文本源码

      总体例子

 

核心函数

 

 

对于多字节wchar 到 lpcswtr 的转化函数介绍,请转到 该链接

http://www.cnblogs.com/linguanh/p/4241939.html

 

 1 #include <iostream>
 2 #include <fstream>
 3 #include <Windows.h>
 4 #include <wininet.h>
 5 #define MAXBLOCKSIZE 28+1 // openID 固定长 28 
 6 #pragma   comment(lib,"wininet.lib") //引入动态库
 7 
 8 char* getWeiXinFromUserNameFromSEA(const char*);
 9 using namespace std;
10 
11 int main(){
12     char *p=NULL; //用于存放返回结果
13     p=getWeiXinFromUserNameFromSEA("http://913337456-my.stor.sinaapp.com/xxx.txt");
14 
15     cout<<p;
16     return 0 ; 
17 } 
18  
19 //我这里设置了函数 带有 返回值,大家可以不适用返回值!
20 char* getWeiXinFromUserNameFromSEA(const char *Url){
21     char *str = new char[MAXBLOCKSIZE]; // 用于最后返回的结果,动态分配
22     const char *x="From_AF"; int i = 0;//第一个是打开标记,i是下面的转化控制变量 
23     WCHAR exchange_text_from_url[256],exchange_text_from_x[256];
24     LPCWSTR py = exchange_text_from_url;// url 转 lpcwstr 的中间变量
25     LPCWSTR pz = exchange_text_from_x; //另外的信息
26     //unicode编码 下的 设置,我这里使用了宽字节,免去转换的麻烦
27     MultiByteToWideChar( 0, 0,x, -1,exchange_text_from_x, 64 );//WCHAR to LPCWSTR,转化
28     MultiByteToWideChar( 0, 0,Url, -1, exchange_text_from_url, 256 );
29     //结束转化
30     HINTERNET handle_for_init_internet = InternetOpen("From_AF", INTERNET_OPEN_TYPE_DIRECT, NULL, NULL, 0);
31      if (handle_for_init_internet != NULL){
32          HINTERNET handle_for_read_info = InternetOpenUrl(handle_for_init_internet, Url, NULL,NULL,NULL,NULL);
33          if (handle_for_read_info != NULL){
34              char result[MAXBLOCKSIZE]; //用于保存 缓冲区的数据组合
35              char buffer[MAXBLOCKSIZE];//下载文件的缓冲区
36              DWORD bytes_read = 1;//下载的字节数
37              BOOL temp_boolean;
38              while(bytes_read!=0){ 
39                  //使用 InternetReadFile 从缓存区 读取 数据到 buffer 字符串,要度的字节数是 buffer的有效长度,控制是 bytes_read
40                  temp_boolean = InternetReadFile(handle_for_read_info,buffer,sizeof(buffer), &bytes_read);       
41              }
42              for(i;i<MAXBLOCKSIZE-1;i++){
43                  if(i==MAXBLOCKSIZE-2 && buffer[i]=='0'){ //去掉最后的干扰值 0
44 
45                  }else if(buffer[i]>=34 && buffer[i]<=126){ //多种测试,最终还是使用 ASCII 码范围判断来解决了 烫烫烫~~~~
46                     //cout<<buffer[i]; //通过使用循环 针对性地 输出单个 字符消除缓冲区的其他混杂 空量
47                     //这里不直接搞出 buffer 是因为,缓存区里有很多 不知什么数据在输出的时候会变成很多烫,一般是空才会有烫
48                      result[i]=buffer[i];  //经过测试,这个逐个赋值能够去掉 其中夹杂的 烫~~~
49                  }
50              } 
51              result[i]='\0'; //赋值 结尾 符,防止 自身爆 烫
52              strcpy(str,result); //copy 给 字符串指针,用于返回
53              //安全操作,销毁句柄
54              InternetCloseHandle(handle_for_read_info); handle_for_read_info = NULL;
55          }
56          InternetCloseHandle(handle_for_init_internet); handle_for_init_internet = NULL;
57          return str;
58     } 
59 }

 

posted @ 2015-06-01 14:15  指尖下的幽灵  阅读(4818)  评论(2编辑  收藏  举报