[转]URL的解析,C语言实现
http://blog.csdn.net/cuishumao/article/details/10284463
一 说明
(1)应用情况:比如基于socket来实现http协议等,这时候就需要解析URL。
(2)为了移植性,没有用非标准C库windows下的StrDup(linux下为strdup),用自己编写的dup_str。
(3)编译环境:windows ,visual studio2010
二 URL的格式:
(协议)://(主机名):(端口号) / (文件路径)/(文件名)
例如:http://zj.qq.com/a/20130824/002507.htm#p=8
http://www.itpub.net/kwrss/201211/wangzhiduankou.shtml
三 实现
- #include <stdio.h> //printf
- #include <string.h> //strchr strncmp ,memcpy
- #include <malloc.h> //malloc free
- #include <stdlib.h> //atoi
- //将source开始空间的以NULL结尾的字符拷贝到dest中
- //返回的指针需要free
- char*dup_str(const char*source)
- {
- if(source==NULL)
- return NULL;
- int len = strlen(source);
- char *dest = (char*)malloc(len+1);
- memcpy(dest,source,len+1);
- return dest;
- }
- //函数功能:解析URL
- //参数:host带回主机字符串,protocl协议,port端口,abs_path带回绝对路径
- //使用完注意释放host和abs_path在堆上分配的内存
- //备注:(1)先取到URL的一份拷贝,方面将该字符串截成几段,分别处理;
- // (2)用了指针引用,也可以使用二重指针来解决参数带回值的问题
- void parse_URL(const char*URL,const char*protocl,char*&host,unsigned int &port,char*&abs_path)
- {
- if(URL == NULL)
- return ;
- char *url_dup = dup_str(URL);
- char *p_slash = NULL;//主机后第一个斜杠的位置
- char *p_colon = NULL;//主机后第一个冒号的位置
- char *start = 0; //记录www开始的位置
- if(strncmp(url_dup,protocl,strlen(protocl))==0)
- {
- start = url_dup+strlen(protocl)+3;
- p_slash = strchr(start,'/');
- if(p_slash != NULL)
- {
- abs_path= dup_str(p_slash);
- *p_slash = '\0';
- }
- else
- {
- abs_path= dup_str("/");
- }
- p_colon = strchr(start,':');
- if(p_colon != NULL)
- {
- port = atoi(p_colon+1);
- *p_colon = '\0';
- }
- else
- port = 8080;//没有的话取默认的8080端口
- }
- host = dup_str(start);
- }
- if(url_dup != NULL)
- {
- free(url_dup);
- url_dup = NULL;
- }
- }
- int main()
- {
- //这是一个伪造的地址,用于测试
- //char *URL = "http://www.xyz2013.com";
- //char *URL = "ftp://www.xyz2013.com:8080";
- char *URL = "https://www.xyz2013.com:1324/My/5201449.shtml";
- char*abs_path = NULL;
- char*host = NULL;
- unsigned int port;
- parse_URL(URL,"https",host,port,abs_path);
- printf("主机地址:%s\n",host);
- printf("端口号:%d\n",port);
- printf("绝对路径:%s\n",abs_path);
- //需要释放host,abs_path
- if(host!=NULL)
- {
- free(host);
- host = NULL;
- }
- if(abs_path!=NULL)
- {
- free(abs_path);
- abs_path=NULL;
- }
- getchar();
- }
结果:
[转]URL的解析,C语言实现的更多相关文章
- URL的解析,C语言实现
源: URL的解析,C语言实现 c语言实现urlencode和decode
- 巨蟒python全栈开发django4:url反向解析图解&&模板渲染
第一部分: 1.(1)知识点回顾: django回顾: ()下载安装 输入网址,a,form表单get post,爬虫 (请求)==>django项目服务端的url(r"index/& ...
- python 之 Django框架(路由系统、include、命名URL和URL反向解析、命名空间模式)
12.36 Django的路由系统 基本格式: from django.conf.urls import url urlpatterns = [ url(正则表达式, views视图函数,参数,别名) ...
- phpcms V9 MVC模式 与 URL访问解析
[1]URL访问解析 观察访问网页时的网址,可以得出模块访问方法,如下示例: http://www.abcd.com.cn/phpcms/index.php?m=content&c=index ...
- atitit.java解析sql语言解析器解释器的实现
atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...
- phpcms(1)phpcms V9 MVC模式 与 URL访问解析(转)
[1]URL访问解析 观察访问网页时的网址,可以得出模块访问方法,如下示例: http://www.abcd.com.cn/phpcms/index.php?m=content&c=index ...
- django的url反向解析
目的:防止页面中url地址改变,其他与这个URL地址有关联的都要改,减少耦合度 使用:主要分为在html中和视图函数中的使用 HTML中的使用: 如果我们在项目的url文件中通过include导入了应 ...
- Django url配置 正则表达式详解 分组命名匹配 命名URL 别名 和URL反向解析 命名空间模式
Django基础二之URL路由系统 本节目录 一 URL配置 二 正则表达式详解 三 分组命名匹配 四 命名URL(别名)和URL反向解析 五 命名空间模式 一 URL配置 Django 1.11版本 ...
- Django url反向解析与路由分发名称空间
url反向解析 url.py from django.conf.urls import url from django.contrib import admin from app01 import v ...
- rails中path、url路径解析,routes信息,form_for剖析,link_to示例,路由实例说明
原创,转载请注明http://www.cnblogs.com/juandx/p/3963023.html rails中path.url路径解析,routes信息,form_for剖析,link_to ...
随机推荐
- 定义文件XML——从简单开始
本文纯属个人见解,是对前面学习的总结,如有描述不正确的地方还请高手指正~ 通过看XML讲授的视频,算是对XML有了简略的认识,原本不盘算写这篇博客,但无法原来视频讲授的内容就少,再不踊跃写些东西,过不 ...
- 密码配置配置SSH免密码登陆
在本文中,我们主要介绍密码配置的内容,自我感觉有个不错的建议和大家分享下 我的用户名是master 1.安装ssh(若没安装的话) sudo apt-get install ssh 2.配置为可以免密 ...
- java多线程并发编程与CPU时钟分配小议
我们先来研究下JAVA的多线程的并发编程和CPU时钟振荡的关系吧 老规矩,先科普 我们的操作系统在DOS以前都是单任务的 什么是单任务呢?就是一次只能做一件事 你复制文件的时候,就不能重命名了 那么现 ...
- 使用highcharts显示mongodb中的数据
1.mongodb数据表相关 # 显示数据库 show dbs # 数据库 use ceshi # 显示表 show tables # 创建集合 db.createCollection('infoB' ...
- Javascript中 a.href 和 a.getAttribute('href') 结果不完全一致
今天无意中发现这个么问题,页面上对所有A标签的href属性为空的自动添加一个链接地址,结果发现if判断条件始终都没生效,莫名其妙. 原来Javascript中 a.href 和 a.getAttrib ...
- Time.timeScale、游戏暂停
原文链接 项目里面一直在用Time.timeScale来做游戏的 1倍 2倍整体加速,今天我仔细看了一下Time.timeScale才发现之前我理解错了一些东西. Time.timeScale可以控制 ...
- MATLAB中的多项式运算
作者:长沙理工大学 交通运输工程学院 王航臣 1.多项式求根 在MATLAB中求取多项式的根用roots函数. 函数:roots 功能:一元高次方程求解. 语法:roots(c) 说明:返回一个列向量 ...
- CoreJavaE10V1P3.2 第3章 Java的基本编程结构-3.2 注释
3.2 注释 1. //形式注释 System.out.println("We will not use 'Hello, World!'"); // is this too cut ...
- SAP HANA 中的决策表(Decision Table)
http://scn.sap.com/community/developer-center/hana/blog/2013/01/11/what-can-you-do-with-decision-tab ...
- android之控件与布局
基本控件:TextViewButtonEditTextImageViewAlertDialog.BubliderProgressDialog 四种基本布局的特殊属性: LinerLayout andr ...