转载请声明出处!

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 值。的更多相关文章

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

    已搬迁至 http://www.cnblogs.com/linguanh/p/4543836.html

  2. Python获取网页指定内容(BeautifulSoup工具的使用方法)

    Python用做数据处理还是相当不错的,如果你想要做爬虫,Python是很好的选择,它有很多已经写好的类包,只要调用,即可完成很多复杂的功能,此文中所有的功能都是基于BeautifulSoup这个包. ...

  3. telnet建立http连接获取网页HTML内容

    利用telnet可以与服务器建立http连接,获取网页,实现浏览器的功能.它对于需要对http header进行观察和测试到时候非常方便.因为浏览器看不到http header. 步骤如下: 1. 运 ...

  4. C# 获取网页数据、获取本机IP 分类: C# 2014-12-16 14:59 308人阅读 评论(0) 收藏

    说明: (1) http://www.3322.org/dyndns/getip 这个网址可以获取本机IP,读取的内容就是本机IP (2)方法经测试,可以实现. (3)参考:http://www.cn ...

  5. 黄聪:C#获取网页HTML内容的三种方式

    C#通常有三种方法获取网页内容,使用WebClient.WebBrowser或者HttpWebRequest/HttpWebResponse. 方法一:使用WebClient static void ...

  6. asp.net 利用HttpWebRequest自动获取网页编码并获取网页源代码

    /// <summary> /// 获取源代码 /// </summary> /// <param name="url"></param& ...

  7. [python]获取网页中内容为汉字的字符串的判断

    实际上是这样,将获取到网页中表单内容与汉字字符串作比较,即: a = request.POST['a'] if a == '博客园': print 'ok' else: print 'false' a ...

  8. 使用SOCKET获取网页的内容

    使用fsockopen()函数来实现获取页面信息,完整代码如下 //设置字符集(由于要抓取的网易网站字符集编码是gbk编码) header("content-type:text/html;c ...

  9. Python3爬虫04(其他例子,如处理获取网页的内容)

    #!/usr/bin/env python# -*- coding:utf-8 -*- import osimport reimport requestsfrom bs4 import Navigab ...

随机推荐

  1. day 2 Linux基础

    6.用户.群组和权限 1) 新建用户natasha,uid为1000,gid为555,备注信息为"master" useradd natasha usermod -u1000 na ...

  2. spring和Hibernate整合

    首先导入spring和Hibernate的jar包,以及JDBC和c3p0的jar包, 然后就是Hibernate的XML配置文件,不需要加入映射文件,这里用spring容器管理了. Hibernat ...

  3. keepalived 原主上线时vip漂移情况

    1. 设置为MASTER,BACKUP 优先级相同 的情况: master端的keepalived起来就会获取到vip变成主. 2. 设置为BACKUP,BACKUP 一个优先级高一个优先级低 的情况 ...

  4. webpack配置ES6 + react套装开发

    配置ES6 1.安装插件: babel-loader,babel-preset-es2015,babel-preset-react. 2.添加配置文件中部分内容: { test: /\.js$/, l ...

  5. 工作中那些提高你效率的神器(第一篇)_Everything

    引言 无论是工作还是科研,我们都希望工作既快又好,然而大多数时候却迷失在繁杂的重复劳动中,久久无法摆脱繁杂的事情. 你是不是曾有这样一种想法:如果我有哆啦A梦的口袋,只要拿出神奇道具就可解当下棘手的问 ...

  6. 有关JVM配置参数含义

    1.参数的含义-vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M-vmargs 说明后面是VM的参数,所以后面的其实都是JV ...

  7. backbone入门示例

    最近因为有个项目需要用backbone+mui  所以最近入坑backbone. Backbonejs有几个重要的概念,先介绍一下:Model,Collection,View,Router.其中Mod ...

  8. 最近在新公司的一些HTML学习

    还是先把代码贴在这  后期再写感想 <!DOCTYPE html> <head> <meta http-equiv="x-ua-compatible" ...

  9. 一个防止误删MSSQL数据库的方法

    一个防止误删MSSQL数据库的方法 环境:Windows2008 R2 .SQL 2012 今天发现一个有趣的现象,之前数据库服务器的其中几个数据库做过镜像,不过现在已经删除了,今天又要在那台服务器上 ...

  10. RESTful API 设计最佳实践

    背景 目前互联网上充斥着大量的关于RESTful API(为了方便,以后API和RESTful API 一个意思)如何设计的文章,然而却没有一个"万能"的设计标准:如何鉴权?API ...