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

#include <iostream>
#include <fstream>
#include <Windows.h>
#include <wininet.h>
#define MAXBLOCKSIZE 28+1 // openID 固定长 28
#pragma comment(lib,"wininet.lib") //引入动态库 char* getWeiXinFromUserNameFromSEA(const char*);
using namespace std; int main(){
char *p=NULL; //用于存放返回结果
p=getWeiXinFromUserNameFromSEA("http://913337456-my.stor.sinaapp.com/xxx.txt"); cout<<p;
return ;
} //我这里设置了函数 带有 返回值,大家可以不适用返回值!
char* getWeiXinFromUserNameFromSEA(const char *Url){
char *str = new char[MAXBLOCKSIZE]; // 用于最后返回的结果,动态分配
const char *x="From_AF"; int i = ;//第一个是打开标记,i是下面的转化控制变量
WCHAR exchange_text_from_url[],exchange_text_from_x[];
LPCWSTR py = exchange_text_from_url;// url 转 lpcwstr 的中间变量
LPCWSTR pz = exchange_text_from_x; //另外的信息
//unicode编码 下的 设置,我这里使用了宽字节,免去转换的麻烦
MultiByteToWideChar( , ,x, -,exchange_text_from_x, );//WCHAR to LPCWSTR,转化
MultiByteToWideChar( , ,Url, -, exchange_text_from_url, );
//结束转化
HINTERNET handle_for_init_internet = InternetOpen("From_AF", INTERNET_OPEN_TYPE_DIRECT, NULL, NULL, );
if (handle_for_init_internet != NULL){
HINTERNET handle_for_read_info = InternetOpenUrl(handle_for_init_internet, Url, NULL,NULL,NULL,NULL);
if (handle_for_read_info != NULL){
char result[MAXBLOCKSIZE]; //用于保存 缓冲区的数据组合
char buffer[MAXBLOCKSIZE];//下载文件的缓冲区
DWORD bytes_read = ;//下载的字节数
BOOL temp_boolean;
while(bytes_read!=){
//使用 InternetReadFile 从缓存区 读取 数据到 buffer 字符串,要度的字节数是 buffer的有效长度,控制是 bytes_read
temp_boolean = InternetReadFile(handle_for_read_info,buffer,sizeof(buffer), &bytes_read);
}
for(i;i<MAXBLOCKSIZE-;i++){
if(i==MAXBLOCKSIZE- && buffer[i]==''){ //去掉最后的干扰值 0 }else if(buffer[i]>= && buffer[i]<=){ //多种测试,最终还是使用 ASCII 码范围判断来解决了 烫烫烫~~~~
//cout<<buffer[i]; //通过使用循环 针对性地 输出单个 字符消除缓冲区的其他混杂 空量
//这里不直接搞出 buffer 是因为,缓存区里有很多 不知什么数据在输出的时候会变成很多烫,一般是空才会有烫
result[i]=buffer[i]; //经过测试,这个逐个赋值能够去掉 其中夹杂的 烫~~~
}
}
result[i]='\0'; //赋值 结尾 符,防止 自身爆 烫
strcpy(str,result); //copy 给 字符串指针,用于返回
//安全操作,销毁句柄
InternetCloseHandle(handle_for_read_info); handle_for_read_info = NULL;
}
InternetCloseHandle(handle_for_init_internet); handle_for_init_internet = NULL;
return str;
}
}
C++ 与 php 的交互 之----- C++ 获取 网页文字内容,获取 php 的 echo 值。的更多相关文章
- C++ 与 php 的交互 之----- C++ 异步获取 网页文字内容,异步获取 php 的 echo 值。
已搬迁至 http://www.cnblogs.com/linguanh/p/4543836.html
- Python获取网页指定内容(BeautifulSoup工具的使用方法)
Python用做数据处理还是相当不错的,如果你想要做爬虫,Python是很好的选择,它有很多已经写好的类包,只要调用,即可完成很多复杂的功能,此文中所有的功能都是基于BeautifulSoup这个包. ...
- telnet建立http连接获取网页HTML内容
利用telnet可以与服务器建立http连接,获取网页,实现浏览器的功能.它对于需要对http header进行观察和测试到时候非常方便.因为浏览器看不到http header. 步骤如下: 1. 运 ...
- C# 获取网页数据、获取本机IP 分类: C# 2014-12-16 14:59 308人阅读 评论(0) 收藏
说明: (1) http://www.3322.org/dyndns/getip 这个网址可以获取本机IP,读取的内容就是本机IP (2)方法经测试,可以实现. (3)参考:http://www.cn ...
- 黄聪:C#获取网页HTML内容的三种方式
C#通常有三种方法获取网页内容,使用WebClient.WebBrowser或者HttpWebRequest/HttpWebResponse. 方法一:使用WebClient static void ...
- asp.net 利用HttpWebRequest自动获取网页编码并获取网页源代码
/// <summary> /// 获取源代码 /// </summary> /// <param name="url"></param& ...
- [python]获取网页中内容为汉字的字符串的判断
实际上是这样,将获取到网页中表单内容与汉字字符串作比较,即: a = request.POST['a'] if a == '博客园': print 'ok' else: print 'false' a ...
- 使用SOCKET获取网页的内容
使用fsockopen()函数来实现获取页面信息,完整代码如下 //设置字符集(由于要抓取的网易网站字符集编码是gbk编码) header("content-type:text/html;c ...
- Python3爬虫04(其他例子,如处理获取网页的内容)
#!/usr/bin/env python# -*- coding:utf-8 -*- import osimport reimport requestsfrom bs4 import Navigab ...
随机推荐
- 关于chrome控制台那些事
作为一名前端,除了编写完美代码之外(个人还不具备),当然也要会调试啦,对于firebug比较而言,我还是更喜欢chrome控制台比较多(可能使用较多,更顺手的原因吧).所以来总结下,关于chrome控 ...
- Unity自动寻路入门指南
所有用于成为NavMesh的网格都必须被指定为 Navigation Static . 方法如下,选中GameObject,然后在菜单栏的[Window]-[Navigation]-[Object]- ...
- Android应用性能优化(转)
人类大脑与眼睛对一个画面的连贯性感知其实是有一个界限的,譬如我们看电影会觉得画面很自然连贯(帧率为24fps),用手机当然也需要感知屏幕操作的连贯性(尤其是动画过度),所以Android索性就把达到这 ...
- Android四大组件--MediaPlayer详解(转)
一. MediaPlayer 状态机 介绍 Android MediaPlayer 状态即图例 : 1. Idle (闲置) 状态 和 End (结束) 状态 MediaPlayer 对象声明周期 : ...
- HTML以及CSS的作用和理念
首先,在学习之前,这些是必要知道的东西.什么是HTML,什么是CSS 它们有什么用?又能做什么? 了解HTML和CSS的用途,能更有利我们快速,高效的学习它们. 那么,关于这两者,我就用我通俗的语言像 ...
- HDFS DataNode 设计实现解析
前文分析了 NameNode,本文进一步解析 DataNode 的设计和实现要点. 文件存储 DataNode 正如其名是负责存储文件数据的节点.HDFS 中文件的存储方式是将文件按块(block)切 ...
- ABP理论学习之开篇介绍
返回总目录 为了和2016年春节赛跑,完成该系列博客,我牺牲了今天中午的时间来完成该系列的第一篇----开篇介绍.开篇介绍嘛,读过大学教材的同学都知道,这玩意总是那么无聊,跟考试没关系,干脆直接跳过, ...
- Hadoop学习笔记—16.Pig框架学习
一.关于Pig:别以为猪不能干活 1.1 Pig的简介 Pig是一个基于Hadoop的大规模数据分析平台,它提供的SQL-LIKE语言叫Pig Latin,该语言的编译器会把类SQL的数据分析请求转换 ...
- c#实现redis客户端(一)
最近项目使用中要改造redis客户端,看了下文档,总结分享一下. 阅读目录: 协议规范 基础通信 状态命令 set.get命令 管道.事务 总结 协议规范 redis允许客户端以TCP方式连接,默认6 ...
- TDR测试原理
什么是TDR? TDR是英文Time Domain Reflectometry 的缩写,中文名叫时域反射计,是测量传输线特性阻抗的主要工具.TDR主要由三部分构成:快沿信号发生器,采样示波器和探头系统 ...