C语言实现url的编码和解码
生活随笔
收集整理的這篇文章主要介紹了
C语言实现url的编码和解码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
url提交信息為何要轉碼呢?因為url本身會有很多特殊字符。而提交的參數中如果再有特殊字符的話,url就不能區分哪些是參數內容,哪些是分隔符。尤其是unicode,gb18030,big5等多字節的編碼,不知道里面會隱藏什么字節,因此必須全部轉碼。
更多詳情請看:《關于URL編碼》
本文代碼為從PHP代碼中修改而來,只保留了2個函數。
- 字符’a’-‘z’,’A’-‘Z’,’0’-‘9’,’.’,’-‘,’*’和’_’ 都不被編碼,維持原值;
- 空格’ ‘被轉換為加號’+’。
- 其他每個字節都被表示成”%XY”的格式,X和Y分別代表一個十六進制位。編碼為UTF-8。
示例代碼:
#include <stdio.h> #include <string.h>#define BURSIZE 2048int hex2dec(char c) {if ('0' <= c && c <= '9') {return c - '0';} else if ('a' <= c && c <= 'f'){return c - 'a' + 10;} else if ('A' <= c && c <= 'F'){return c - 'A' + 10;} else {return -1;} }char dec2hex(short int c) {if (0 <= c && c <= 9) {return c + '0';} else if (10 <= c && c <= 15) {return c + 'A' - 10;} else {return -1;} }//編碼一個url void urlencode(char url[]) {int i = 0;int len = strlen(url);int res_len = 0;char res[BURSIZE];for (i = 0; i < len; ++i) {char c = url[i];if ( ('0' <= c && c <= '9') ||('a' <= c && c <= 'z') ||('A' <= c && c <= 'Z') || c == '/' || c == '.') {res[res_len++] = c;} else {int j = (short int)c;if (j < 0)j += 256;int i1, i0;i1 = j / 16;i0 = j - i1 * 16;res[res_len++] = '%';res[res_len++] = dec2hex(i1);res[res_len++] = dec2hex(i0);}}res[res_len] = '\0';strcpy(url, res); }// 解碼url void urldecode(char url[]) {int i = 0;int len = strlen(url);int res_len = 0;char res[BURSIZE];for (i = 0; i < len; ++i) {char c = url[i];if (c != '%') {res[res_len++] = c;}else {char c1 = url[++i];char c0 = url[++i];int num = 0;num = hex2dec(c1) * 16 + hex2dec(c0);res[res_len++] = num;}}res[res_len] = '\0';strcpy(url, res); }int main(int argc, char *argv[]) {char url[100] = "http://'測試/@mike";urlencode(url); //編碼后printf("http://'測試/@mike ----> %s\n", url);char buf[100] = "http%3A//%27%E6%B5%8B%E8%AF%95/%40mike";urldecode(buf); //解碼后printf("http%%3A//%%27%%E6%%B5%%8B%%E8%%AF%%95/%%40mike ----> %s\n", buf);return 0; }編譯運行效果如下:
本文轉自:http://blog.csdn.net/langeldep
總結
以上是生活随笔為你收集整理的C语言实现url的编码和解码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用Jquery判断是电脑或手机和微信浏
- 下一篇: bootloader学习笔记---第二篇