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
三 实现

  1. #include <stdio.h>     //printf
  2. #include <string.h>    //strchr strncmp ,memcpy
  3. #include <malloc.h>    //malloc free
  4. #include <stdlib.h>    //atoi
  5. //将source开始空间的以NULL结尾的字符拷贝到dest中
  6. //返回的指针需要free
  7. char*dup_str(const char*source)
  8. {
  9. if(source==NULL)
  10. return  NULL;
  11. int len = strlen(source);
  12. char *dest = (char*)malloc(len+1);
  13. memcpy(dest,source,len+1);
  14. return dest;
  15. }
  16. //函数功能:解析URL
  17. //参数:host带回主机字符串,protocl协议,port端口,abs_path带回绝对路径
  18. //使用完注意释放host和abs_path在堆上分配的内存
  19. //备注:(1)先取到URL的一份拷贝,方面将该字符串截成几段,分别处理;
  20. //      (2)用了指针引用,也可以使用二重指针来解决参数带回值的问题
  21. void parse_URL(const char*URL,const char*protocl,char*&host,unsigned int &port,char*&abs_path)
  22. {
  23. if(URL == NULL)
  24. return ;
  25. char *url_dup = dup_str(URL);
  26. char *p_slash = NULL;//主机后第一个斜杠的位置
  27. char *p_colon = NULL;//主机后第一个冒号的位置
  28. char *start = 0;    //记录www开始的位置
  29. if(strncmp(url_dup,protocl,strlen(protocl))==0)
  30. {
  31. start = url_dup+strlen(protocl)+3;
  32. p_slash = strchr(start,'/');
  33. if(p_slash != NULL)
  34. {
  35. abs_path= dup_str(p_slash);
  36. *p_slash = '\0';
  37. }
  38. else
  39. {
  40. abs_path= dup_str("/");
  41. }
  42. p_colon = strchr(start,':');
  43. if(p_colon != NULL)
  44. {
  45. port = atoi(p_colon+1);
  46. *p_colon = '\0';
  47. }
  48. else
  49. port = 8080;//没有的话取默认的8080端口
  50. }
  51. host = dup_str(start);
  52. }
  53. if(url_dup != NULL)
  54. {
  55. free(url_dup);
  56. url_dup = NULL;
  57. }
  58. }
  59. int main()
  60. {
  61. //这是一个伪造的地址,用于测试
  62. //char *URL = "http://www.xyz2013.com";
  63. //char *URL = "ftp://www.xyz2013.com:8080";
  64. char *URL = "https://www.xyz2013.com:1324/My/5201449.shtml";
  65. char*abs_path = NULL;
  66. char*host = NULL;
  67. unsigned int port;
  68. parse_URL(URL,"https",host,port,abs_path);
  69. printf("主机地址:%s\n",host);
  70. printf("端口号:%d\n",port);
  71. printf("绝对路径:%s\n",abs_path);
  72. //需要释放host,abs_path
  73. if(host!=NULL)
  74. {
  75. free(host);
  76. host = NULL;
  77. }
  78. if(abs_path!=NULL)
  79. {
  80. free(abs_path);
  81. abs_path=NULL;
  82. }
  83. getchar();
  84. }

结果:

[转]URL的解析,C语言实现的更多相关文章

  1. URL的解析,C语言实现

    源: URL的解析,C语言实现 c语言实现urlencode和decode

  2. 巨蟒python全栈开发django4:url反向解析图解&&模板渲染

    第一部分: 1.(1)知识点回顾: django回顾: ()下载安装 输入网址,a,form表单get post,爬虫 (请求)==>django项目服务端的url(r"index/& ...

  3. python 之 Django框架(路由系统、include、命名URL和URL反向解析、命名空间模式)

    12.36 Django的路由系统 基本格式: from django.conf.urls import url urlpatterns = [ url(正则表达式, views视图函数,参数,别名) ...

  4. phpcms V9 MVC模式 与 URL访问解析

    [1]URL访问解析 观察访问网页时的网址,可以得出模块访问方法,如下示例: http://www.abcd.com.cn/phpcms/index.php?m=content&c=index ...

  5. atitit.java解析sql语言解析器解释器的实现

    atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...

  6. phpcms(1)phpcms V9 MVC模式 与 URL访问解析(转)

    [1]URL访问解析 观察访问网页时的网址,可以得出模块访问方法,如下示例: http://www.abcd.com.cn/phpcms/index.php?m=content&c=index ...

  7. django的url反向解析

    目的:防止页面中url地址改变,其他与这个URL地址有关联的都要改,减少耦合度 使用:主要分为在html中和视图函数中的使用 HTML中的使用: 如果我们在项目的url文件中通过include导入了应 ...

  8. Django url配置 正则表达式详解 分组命名匹配 命名URL 别名 和URL反向解析 命名空间模式

    Django基础二之URL路由系统 本节目录 一 URL配置 二 正则表达式详解 三 分组命名匹配 四 命名URL(别名)和URL反向解析 五 命名空间模式 一 URL配置 Django 1.11版本 ...

  9. Django url反向解析与路由分发名称空间

    url反向解析 url.py from django.conf.urls import url from django.contrib import admin from app01 import v ...

  10. rails中path、url路径解析,routes信息,form_for剖析,link_to示例,路由实例说明

    原创,转载请注明http://www.cnblogs.com/juandx/p/3963023.html  rails中path.url路径解析,routes信息,form_for剖析,link_to ...

随机推荐

  1. 可供VC调用的QT编写的界面DLL方法

    一般直接编写的QT动态库是无法被Windows下的VC6.0等调用的. 如下步骤 第一步:必须要在QT界面库源码下包含qtwinmigrate的源码包和库,网上可下载到. 第二步:在QT的proc文件 ...

  2. Jquery控制点击时一、二级菜单自由隐藏与出现

    一.基本HTML和CSS HTML中产生一.二级导航的代码: {loop $nav $key $value} <div class=”u_con”> <span class=” xg ...

  3. [ios] 微信订阅号: ios博文精选

    晚上下班后时间充裕,平时要么看电视剧,要么玩游戏 感觉浪费时间.  最后决定自己也搞一个微信订阅号分享技术方面的东西,也提升自己. 如果大家也是一样情况,欢迎大家关注我的订阅号. 微信订阅号: ios ...

  4. C#开发学习——常用的正则表达式

    对于想学习正则表达式的童鞋,一些基础的语法啥的,可以参考 http://www.cnblogs.com/China3S/archive/2013/11/30/3451971.html 下边是一些我们常 ...

  5. Java SE ——TCP协议网络编程(三)

    之前的代码中关闭了 socket 对象的输入流与输出流,但并没有关闭掉socket 对象,会造成服务器资源的浪费,应通过调用 socket 的 close() 方法来关闭当前的socket 对象. 因 ...

  6. ThinkPhp 源码阅读心得

    php 中header 函数 我可能见多了,只要用来跳转.今天在阅读TP源码的时候发现,header函数有第三个参数.有些困惑所以找到手册查阅下,发现 void header ( string $st ...

  7. 01--css编码技巧--css揭秘

    一 尽量减少代码重复 1.按钮 #btn { padding: .3em .8em; border: 1px solid #446d88; background: #58a linear-gradie ...

  8. 【C#】【SHARE】The registering of global hotkeys

    I remember that when I was still using VB6 sereval years ago, if global hotkeys are required, a mass ...

  9. 嗯,这个BLOG其实是个更新服务器

    2333 软件:http://dwz.cn/NKSGUI

  10. ArrayList构造函数

    //1.摘要: //初始化 System.Collections.ArrayList 类的新实例,该实例为空并且具有默认初始容量. // public ArrayList(); ArrayList a ...