C语言获取网页源代码的学习所得
研究了一天这个玩意感觉挺有意思的。
刚开始是什么都不懂,现在写出来一段代码感觉略微有点意思了。
下面我分享一下学习过程和自己的理解。
整体过程大概就是如下情况:
先搜了一下别人的写这个东西的代码。
研究了一下代码中一些难理解的东西。慢慢就写出来了。
简单分析:
创建一个socket套接字连接主机
发送GET报文头字符串
接收
存放
准备工作:
connect()和服务器建立连接
send() recv() 都是在利用套接字
用户提供一个网址,我们分析网址。
网址中包含的信息 有些是要填入sockaddr地址信息中 ,有些是要填入GET报头文
我们能得知信息有 主机名 资源路径 端口
例如一个 www.baidu.com/1.html 主机名www.baidu.com 资源路径 /1.html 端口没有 就 默认 80
建立连接 connect()函数搞定
参数中需要socket 和 sockaddr 前者就是套接字,后者是一个套接字地址结构
可以从sockaddr_in 强制转化过来 这个是另一种套接字地址结构体
需要提供 端口和 ip地址
端口 我们分析网址就能得到
ip地址 是用gethostbyname()这个函数搞定
函数名就挺形象的 通过主机名字获得host信息
意思就是 从 www.baidu.com 主机名 获得host信息
然后我们从信息里面把ip地址提取出来
GET报文头 需要主机名 资源路径 这两样网址中都提供了
发送 send()这个函数搞定
接收 recv()这个函数搞定
细分逻辑:
主要是学习这些函数以及结构的过程,和一些简单的逻辑组织。
分析网址 这个都在string.h
从host结构中获得ip地址填入套接字地址结构 这个查阅一下gethostbyname()和sockaddr以及sockaddr_in
连接connect()
存放GET报文头,把报文头用字符串函数组建起来,放在数组或者其他。。
发送send()
如果你发送的GET报文头得到了回应,目标就会传送你要的信息回来
接收recv()
信息可能很多,可能不能一次性接收完,分多次。用memcpy()和malloc()以及realloc()
memcpy() copy字节数到目标 malloc()声明一定大小的内存区域 realloc()改变内存区域大小
什么时候接收完 如果套接字中有接收的内容就一直接收。没有就等待,直到超时,然后返回0.
这个超时时间限定是可以设置的。setsockopt()这个函数。可以设置接收和发送
int nNetTimeout = 5000;
setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, (char *)&nNetTimeout, sizeof(int));
遗留问题的思考:对于接收到数据处理。编码问题。我觉得套接字中传输的是数据,不是字符串。
正文这个我觉得倒是好理解,有人用utf8写了一个html网页文件保存在服务器,我们所获取的正文应该是这个用utf8编码写的数据 (我猜的)
但是接收到的报文头是什么编码呢,我们用什么简单的方法把它们分离,没有去研究。。有机会再看看
C语言获取网页源代码的学习所得的更多相关文章
- Java 网络爬虫获取网页源代码原理及实现
Java 网络爬虫获取网页源代码原理及实现 1.网络爬虫是一个自动提取网页的程序,它为搜索引擎从万维网上下载网页,是搜索引擎的重要组成.传统爬虫从一个或若干初始网页的URL开始,获得初始网页上的URL ...
- php查看网页源代码的方法
这篇文章主要介绍了php查看网页源代码的方法,涉及php读取网页文件的技巧,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了php查看网页源代码的方法.分享给大家供大家参考.具体实现 ...
- c#利用WebClient和WebRequest获取网页源代码的比较
前几天举例分析了用asp+xmlhttp获取网页源代码的方法,但c#中一般是可以利用WebClient类和WebRequest类获取网页源代码.下面分别说明这两种方法的实现. WebClient类获取 ...
- delphi 获取网页源代码
//获取网页源代码 var s: string; begin s := WebBrowser1.OleObject.document.body.innerHTML; //body内的所有代码 ...
- JS远程获取网页源代码的例子
js代码获取网页源代码. 代码: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> < ...
- 如何在ios手机端的Safari浏览器 中“查看网页源代码”
在这里给大家分享一个很简单的用苹果手机无需越狱就可以查看网页源代码的方法,不过这个方法只用于苹果手机自带的Safari浏览器 随便添加一个safari 书签 (用于一会改为查看源码功能书签)进入书签 ...
- c#利用WebClient和WebRequest获取网页源代码
C#中一般是可以利用WebClient类和WebRequest类获取网页源代码.下面分别说明这两种方法的实现. WebClient类获取网页源代码 WebClient类 WebClient ...
- c#利用HttpWebRequest获取网页源代码
c#利用HttpWebRequest获取网页源代码,搞了好几天终于解决了,直接获取网站编码进行数据读取,再也不用担心乱码了! 命名空间:Using System.Net private static ...
- C#用正则表达式 获取网页源代码标签的属性或值
1.有url获取到网页源代码: using System.Web; using System.IO; using System.Net; private void GetHtmlinfo(string ...
随机推荐
- UVA 539 The Settlers of Catan dfs找最长链
题意:画边求最长链,边不能重复数点可以. 很水,用暴力的dfs即可,因为数据不大. 本来以为可以用floyd进行dp的,后来想想好像不能在有回路上的图跑...于是没去做. #include <c ...
- javaweb学习总结十一(JAXP对XML文档进行DOM解析)
一:将内存中写好的xml文件读取到硬盘上 二:DOM方式对xml文件进行增删改查 1:添加节点(默认是在最后的子节点后面添加) @Test // 向元素中添加节点<version>1.0& ...
- cent0s7 显卡驱动导致重启黑屏
由于 CentOS7.0 版本与前面的 CentOS6.5 及之前的版本的模式变更方法有很大 的不同,以前的版本中我们可以在vi /etc/inittab 文件中将id:5:initdefault 更 ...
- nmap命令-----基础用法
系统漏洞扫描之王-nmap NMap,也就是Network Mapper,是Linux下的网络扫描和嗅探工具包. 其基本功能有三个: (1)是扫描主机端口,嗅探所提供的网络服务 (2)是探测一 ...
- CSS组件化思考
为什么组件化? 分层设计,代码复用,减少冗余: 维护方便,弹性好: 如何组件化? 目前代码分成三级: 第一级粒度最细,是基础,主要包含字体配置,颜色配置,UI框架(比如MUI或者pure.css): ...
- Javascript之获取屏幕宽高
<head> <title> new document </title> <meta name="generator" content=& ...
- sqlserver之二进制和字符串sql语句
正常情况下我们对数据库的操作就是如下的写法来操作数据库 ID AS 编号,BookName AS 书名 FROM dbo.books ORDER BY ID; ; 但是在客户正在使用的数据库里,我们开 ...
- 使用EntityFramework连接 Mysql
原文:使用EntityFramework连接 Mysql 1,安装VS.net 插件 http://forums.mysql.com/read.php?174,601041,601041 2,安装连接 ...
- 第六篇、AVplayer定制视频播放控件
1.引用头文件#import AVFoundation 2.自定义AVPlayer(播放的机器) 3.自定义AVPlayerItem(胶片) >> 视频的URL转成AVAsset 4.AV ...
- 【leetcode】352. Data Stream as Disjoint Intervals
问题描述: Given a data stream input of non-negative integers a1, a2, ..., an, ..., summarize the numbers ...