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

简介: 转载请声明出处! http://www.cnblogs.com/linguanh/category/633252.html       距离上次 谈 C++ 制作json 或者其他数据传送给 服务器,时隔两个多月。

转载请声明出处!

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 }

 

如果您认为这篇文章还不错或者有所收获,您可以通过扫描一下下面的支付宝二维码 打赏我一杯咖啡【物质支持】,也可以点击右下角的【推荐】按钮【精神支持】,因为这两种支持都是我继续写作,分享的最大动力


img_12e3f54d4d0f70f0eb14f20548e3d781.png
目录
相关文章
|
4月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
3月前
|
存储 SQL 关系型数据库
PHP与数据库交互:从基础到进阶
【10月更文挑战第9天】在编程的世界里,数据是流动的血液,而数据库则是存储这些珍贵资源的心脏。PHP作为一门流行的服务器端脚本语言,其与数据库的交互能力至关重要。本文将带你从PHP与数据库的基本连接开始,逐步深入到复杂查询的编写和优化,以及如何使用PHP处理数据库结果。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技巧,让你在PHP和数据库交互的道路上更加从容不迫。
|
5月前
|
存储 SQL 关系型数据库
PHP与MySQL交互的奥秘
【8月更文挑战第29天】在编程的世界里,PHP和MySQL就像是一对默契的舞伴,共同演绎着数据的交响曲。本文将带你探索它们之间的互动,从连接数据库到执行查询,再到处理结果,每一步都充满了节奏与和谐。我们将一起走进这段代码的旅程,感受数据流动的魅力。
|
2月前
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
70 3
|
1月前
|
SQL 关系型数据库 MySQL
PHP与MySQL的高效交互:从基础到实践####
本文深入探讨了PHP与MySQL数据库之间的高效交互技术,涵盖了从基础连接到高级查询优化的全过程。不同于传统的摘要概述,这里我们直接以一段精简代码示例作为引子,展示如何在PHP中实现与MySQL的快速连接与简单查询,随后文章将围绕这一核心,逐步展开详细讲解,旨在为读者提供一个从入门到精通的实战指南。 ```php <?php // 数据库配置信息 $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "test_db"; // 创建连接 $conn = new mysqli($se
46 0
|
5月前
|
SQL 关系型数据库 MySQL
PHP与数据库交互的艺术:深入探讨PDO扩展
【8月更文挑战第28天】在数字信息时代的海洋里,PHP作为一艘灵活的帆船,承载着无数网站和应用的梦想。而PDO扩展,则是这艘帆船上不可或缺的导航仪,指引着数据安全与效率的航向。本文将带你领略PHP与数据库交互的艺术,深入浅出地探索PDO的世界,从连接数据库到执行复杂的查询,每一步都清晰可见。我们将一起航行在这段奇妙的旅程上,解锁数据的奥秘,体验编程的乐趣。
109 1
|
5月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
7月前
|
存储 SQL PHP
PHP中的PDO与数据库交互
PHP的PDO扩展提供了一种方式来统一访问多种数据库
124 0
|
8月前
|
XML 前端开发 JavaScript
【PHP 开发专栏】PHP 与 Ajax 交互开发
【4月更文挑战第30天】本文探讨了PHP与Ajax交互在Web开发中的应用。Ajax负责客户端的异步请求,PHP处理服务器端业务逻辑。两者结合实现高效、流畅的用户体验。文中阐述了Ajax的工作原理,PHP的角色,数据传输格式选择,并提供了发送Ajax请求、PHP处理请求的示例代码。实际应用包括实时数据更新、表单验证和动态内容加载。开发中需注意跨域、数据安全和性能优化。PHP与Ajax的结合将继续在Web开发中发挥重要作用。
101 0
|
8月前
|
SQL 关系型数据库 MySQL
【PHP开发专栏】PHP与数据库交互入门
【4月更文挑战第29天】本文介绍了PHP与数据库交互的基础,包括选择MySQL或PostgreSQL等关系型数据库,使用MySQLi或PDO扩展进行连接。示例展示了如何使用PHP连接数据库,如MySQLi的面向对象连接方式和PDO的多数据库支持。此外,还讲解了执行SQL查询(如SELECT、INSERT、UPDATE、DELETE)的操作,并强调了安全性与错误处理,如使用预处理语句防止SQL注入。通过学习,读者可掌握PHP操作数据库的基本技能。
90 0