Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5994
  • 博文数量: 4
  • 博客积分: 55
  • 博客等级: 民兵
  • 技术积分: 15
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-08 13:38
文章分类
文章存档

2013年(3)

2012年(1)

我的朋友

分类: LINUX

2013-04-25 14:28:16

原文地址:C语言实现URL解码 作者:atomix2

这是URL编码之后的数据。

于是用了如下的代码解决了问题: 

  1. void urldecode(char *p)  
  2. {  
  3. register i=0;  
  4. while(*(p+i))  
  5. {  
  6.    if ((*p=*(p+i)) == '%')  
  7.    {  
  8.     *p=*(p+i+1) >= 'A' ? ((*(p+i+1) & 0XDF) - 'A') + 10 : (*(p+i+1) - '0');  
  9.     *p=(*p) * 16;  
  10.     *p+=*(p+i+2) >= 'A' ? ((*(p+i+2) & 0XDF) - 'A') + 10 : (*(p+i+2) - '0');  
  11.     i+=2;  
  12.    }  
  13.    else if (*(p+i)=='+')  
  14.    {  
  15.     *p=' ';  
  16.    }  
  17.    p++;  
  18. }  
  19. *p='\0';  
  20. }  


URL的编码是这样的其实url编码就是一个字符ascii码的十六进制。不过稍微有些变动,需要在前面加上 “%”。比如“\”,它的ascii码是92,92的十六进制是5c,所以“\”的url编码就是%5c。那么汉字的url编码呢?很简单,看例子: “胡”的ascii码是-17670,十六进制是BAFA,url编码是“%BA%FA”

所以在进行解码时就要将十六进制转换成十进制,由于传入的是以字符串形式所以中间存在着字符转整型的过程


阅读(188) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~