zoukankan      html  css  js  c++  java
  • 使用C语言解析URL

    1. [代码]容易写成自己输入URL,这里测试一个例子     
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <ctype.h>
    #define MAXN 1024+10
    char url [MAXN] = "http://www.google.com:80/wiki/Search?search=train&go=Go#steammachine";
     
    int main()
    {
        const char *parseptr1;
        const char *parseptr2;
        int len;
        int i;
        parseptr2 = url;
        parseptr1 = strchr(parseptr2, ':');
        if ( NULL == parseptr1 ) {
            printf("URL错误! ");
            return 0;
        }
        len = parseptr1 - parseptr2;
        for ( i = 0; i < len; i++ ) {
            if ( !isalpha(parseptr2[i]) ) {
                printf("URL错误! ");
                return 0;
            }
        }
        printf("protocol: ");
        for(i=0;i<len;i++)
            printf("%c",parseptr2[i]);
        printf(" ");//解析协议
        parseptr1++;
        parseptr2 = parseptr1;
        for ( i = 0; i < 2; i++ ) {
            if ( '/' != *parseptr2 ) {
                printf("URL错误! ");
                return 0;
            }
            parseptr2++;
        }
        parseptr1 = strchr(parseptr2, ':');
        if ( NULL == parseptr1 )//判断有无端口号
        {http://www.huiyi8.com/hunsha/chuangyi/
            parseptr1 = strchr(parseptr2, '/');
            if ( NULL == parseptr1 ) {
            printf("URL错误! ");
            return 0;}创意婚纱照片
            len = parseptr1 - parseptr2;
            printf("host: ");
            for(i=0;i<len;i++)
               printf("%c",parseptr2[i]);
            printf(" ");//解析主机
        }
        else{
        len = parseptr1 - parseptr2;
        printf("host: ");
        for(i=0;i<len;i++)
            printf("%c",parseptr2[i]);
        printf(" ");
        parseptr1++;
        parseptr2 = parseptr1;
        parseptr1 = strchr(parseptr2, '/');
        if ( NULL == parseptr1 ) {
            printf("URL错误! ");
            return 0;
        }
        len = parseptr1 - parseptr2;
        printf("port: ");
        for(i=0;i<len;i++)
            printf("%d",(parseptr2[i]-48));
        printf(" ");//解析端口
        }
        parseptr1++;
        parseptr2 = parseptr1;
        while ( '' != *parseptr1 && '?' != *parseptr1  && '#' != *parseptr1 ) {
            parseptr1++;
        }
        len = parseptr1 - parseptr2;
        printf("path: ");
            for(i=0;i<len;i++)
               printf("%c",parseptr2[i]);
            printf(" ");//解析路径
        parseptr2=parseptr1;
        if ( '?' == *parseptr1 ) {
            parseptr2++;
            parseptr1 = parseptr2;
            while ( '' != *parseptr1 && '#' != *parseptr1 ) {
                parseptr1++;
            }
            len = parseptr1 - parseptr2;
        printf("query: ");
        for(i=0;i<len;i++)
            printf("%c",parseptr2[i]);//判断有无询问并解析
        printf(" ");
        }
        parseptr2=parseptr1;
        if ( '#' == *parseptr1 ) {
            parseptr2++;
            parseptr1 = parseptr2;
            while ( '' != *parseptr1 ) {
                parseptr1++;
            }
            len = parseptr1 - parseptr2;
        printf("fragment: ");
        for(i=0;i<len;i++)
            printf("%c",parseptr2[i]);
        printf(" ");//判断有无片段并解析
             
        }
    }   

  • 相关阅读:
    oracle解决连接池不足
    ORA-12537:TNS连接已关闭
    oracle 11g 大量废连接占满数据库连接问题处理
    oracle: 浅谈sqlnet.ora文件的作用,及SQLNET.AUTHENTICATION_SERVICES设置
    查询oracle数据库的数据库名、实例名、ORACLE_SID
    工程:有价值的事物的创建过程,及依赖的资源与知识
    工程学
    并发的本质是任务空间与执行空间
    异步的本质是不确定性
    聊一聊 redux 异步流之 redux-saga
  • 原文地址:https://www.cnblogs.com/xkzy/p/3956162.html
Copyright © 2011-2022 走看看