亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? smb_andx_decode.c

?? 著名的入侵檢測系統snort的最新版本的源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
    printf("\n");}#endifint SkipBytes(u_int8_t *data, u_int16_t size){    u_int16_t i = 0;    while ( i < size && *data != 0 )    {        data++;        i++;    }    return i;}int SkipBytesWide(u_int8_t *data, u_int16_t size){    u_int16_t i = 0;    /* Check against size-1 in case someone is screwing with us and giving         us an odd number of bytes for 2-byte Unicode.  */    while ( i < (size - 1) && *data != 0 )    {        data += 2;        i += 2;    }    return i;}int ProcessSMBTreeConnXReq(SMB_HDR *smbHdr, u_int8_t *data, u_int16_t size, u_int16_t total_size){    SMB_TREE_CONNECTX_REQ *treeConnX;    u_int16_t byteCount;    u_int8_t *tree_data;    u_int16_t tree_data_len;    u_int8_t *passwd_ptr;    u_int16_t passwd_len;    u_int8_t *path_ptr;    int path_len;    u_int8_t *service_ptr;    int service_len;    int is_ipc;    if ( size <= sizeof(SMB_TREE_CONNECTX_REQ) )    {        return 0;    }    treeConnX = (SMB_TREE_CONNECTX_REQ *)data;        size -= sizeof(SMB_TREE_CONNECTX_REQ);    tree_data = data + sizeof(SMB_TREE_CONNECTX_REQ);    byteCount = smb_ntohs(treeConnX->byteCount);    tree_data_len = byteCount;    passwd_len = smb_ntohs(treeConnX->passwdLen);    /* Sanity check */    if ( byteCount > size || passwd_len >= byteCount)        return 0;    passwd_ptr = tree_data;    tree_data += passwd_len;    tree_data_len -= passwd_len;    /* Get path */    path_len = GetSMBStringLength(tree_data, tree_data_len, HAS_UNICODE_STRINGS(smbHdr));    if (path_len == -1 || path_len == tree_data_len)        return 0;    path_ptr = tree_data;    is_ipc = IsIPC(tree_data, path_len, HAS_UNICODE_STRINGS(smbHdr));    if (is_ipc && _dcerpc->smb_state == STATE_START)    {        _dcerpc->smb_state = STATE_GOT_TREE_CONNECT;    }    tree_data += path_len;    tree_data_len -= path_len;    /* Service field is ALWAYS ascii */    service_len = GetSMBStringLength(tree_data, tree_data_len, 0);    if (service_len == -1)        return 0;    service_ptr = tree_data;    /* there shouldn't be any more data */    if (tree_data + service_len != tree_data + tree_data_len)        return 0;#ifdef DEBUG_DCERPC_PRINT    /* Password data      * it seems like the password length has to be an odd number     * This passwd will always be ASCII -- equiv of     * CaseInsensitivePasswd field from SessSetupAndX message */    if (passwd_len > 0)        printf("Password: %02.*X\n", passwd_len, passwd_ptr);    if (path_len > 0)        PrintSMBString("Path: ", path_ptr, path_len, HAS_UNICODE_STRINGS(smbHdr));    /* Service field is ALWAYS ascii */    if (service_len > 0)        PrintSMBString("Service: ", service_ptr, service_len, 0);#endif    /* put tree_data at end of this request for comparing     * against andXOffset */    tree_data += tree_data_len;    /* Handle next andX command in this packet */    if (treeConnX->andXCommand != SMB_NONE)    {        u_int16_t andXOffset = smb_ntohs(treeConnX->andXOffset);        u_int8_t *next_command;        u_int16_t data_left_len;        if ( andXOffset >= total_size )            return 0;        next_command = (u_int8_t *)smbHdr + andXOffset;             /* Make sure we don't backtrack or look at the same data again */        if (next_command < tree_data)            return 0;        /* Skip header, get size of remaining data */        data_left_len = total_size - andXOffset;        /* Next block is at smbHdr + smb_ntohs(sess_setupx_req->andXOffset) */        return ProcessNextSMBCommand(treeConnX->andXCommand, smbHdr, next_command,                                     data_left_len, total_size);            }    return 0;}int ProcessSMBNTCreateX(SMB_HDR *smbHdr, u_int8_t *data, u_int16_t size, u_int16_t total_size){    SMB_NTCREATEX_REQ *ntCreateX;    u_int16_t byteCount;    u_int8_t *nt_create_data;    u_int16_t nt_create_data_len;    u_int8_t *file_name_ptr;    int file_name_len;    if ( size <= sizeof(SMB_NTCREATEX_REQ) )    {        return 0;    }    ntCreateX = (SMB_NTCREATEX_REQ *)data;    size -= sizeof(SMB_NTCREATEX_REQ);    byteCount = smb_ntohs(ntCreateX->byteCount);    if (byteCount > size)        return 0;    nt_create_data = data + sizeof(SMB_NTCREATEX_REQ);    nt_create_data_len = byteCount;    /* Appears to be a pad in there to word-align if unicode */    if (HAS_UNICODE_STRINGS(smbHdr))    {        nt_create_data++;        nt_create_data_len--;    }    /* note that the file name length in the header does not seem     * to be used by the server */    file_name_len = GetSMBStringLength(nt_create_data, nt_create_data_len,                                       HAS_UNICODE_STRINGS(smbHdr));    if (file_name_len == -1)        return 0;    file_name_ptr = nt_create_data;    /* there shouldn't be any more data */    if (nt_create_data + file_name_len != nt_create_data + nt_create_data_len)        return 0;    if ( _dcerpc->smb_state == STATE_GOT_TREE_CONNECT )        _dcerpc->smb_state = STATE_GOT_NTCREATE;#ifdef DEBUG_DCERPC_PRINT    PrintSMBString("Create/Open: ", file_name_ptr, file_name_len, HAS_UNICODE_STRINGS(smbHdr));#endif    /* put nt_create_data at end of this request for comparing     * against andXOffset */    nt_create_data += nt_create_data_len;    /* Handle next andX command in this packet */    if (ntCreateX->andXCommand != SMB_NONE)    {        u_int16_t andXOffset = smb_ntohs(ntCreateX->andXOffset);        u_int8_t *next_command;        u_int16_t data_left_len;        if ( andXOffset >= total_size )            return 0;               next_command = (u_int8_t *)smbHdr + andXOffset;        /* Make sure we don't backtrack or look at the same data again */        if (next_command < nt_create_data)            return 0;        /* Skip header, get size of remaining data */        data_left_len = total_size - andXOffset;        /* Next block is at smbHdr + smb_ntohs(sess_setupx_req->andXOffset) */        return ProcessNextSMBCommand(ntCreateX->andXCommand, smbHdr, next_command,                                     data_left_len, total_size);    }    return 0;}int ProcessSMBWriteX(SMB_HDR *smbHdr, u_int8_t *data, u_int16_t size, u_int16_t total_size){    SMB_WRITEX_REQ *writeX;    u_int8_t *writeX_data;    u_int16_t writeX_data_len;    u_int16_t writeX_byte_count;    u_int16_t data_offset;    u_int16_t padding;    /* Only process WriteAndX packet if it is part of a DCE/RPC session */    if ( _dcerpc->smb_state != STATE_GOT_NTCREATE )    {        return 0;    }    if ( size <= sizeof(SMB_WRITEX_REQ) )    {        return 0;    }    writeX = (SMB_WRITEX_REQ *)data;    data_offset = smb_ntohs(writeX->dataOffset);    if ( data_offset >= total_size )    {        return 0;    }    writeX_data = (u_int8_t *)smbHdr + data_offset;    writeX_data_len = smb_ntohs(writeX->dataLength);    writeX_byte_count = smb_ntohs(writeX->byteCount);    /* byte count is always greater than or equal to data length and     * accounts for extra padding at end of header and before actual data */    if (writeX_data_len > writeX_byte_count)        return 0;     padding = writeX_byte_count - writeX_data_len;    /* data_offset put us somewhere before the end of the header and padding */    if (writeX_data < (u_int8_t *)writeX + sizeof(SMB_WRITEX_REQ) + padding)        return 0;    /* data_offset + data_len will put us past end of packet */    if (writeX_data + writeX_data_len > (u_int8_t *)smbHdr + total_size)        return 0;#ifdef DEBUG_DCERPC_PRINT    if (writeX_data_len > 0)        printf("WriteAndX data: %02.*X\n", writeX_data_len, writeX_data);#endif    if (writeX_data_len > 0)        SMB_Fragmentation((u_int8_t *) smbHdr, writeX, writeX_data, writeX_data_len);    /* put dce_data at end of this request for comparing     * against andXOffset */    writeX_data += writeX_data_len;    /* Handle next andX command in this packet */    if (writeX->andXCommand != SMB_NONE)    {        u_int16_t andXOffset = smb_ntohs(writeX->andXOffset);        u_int8_t *next_command;        u_int16_t data_left_len;        if ( andXOffset >= total_size )            return 0;        next_command = (u_int8_t *)smbHdr + andXOffset;        /* Make sure we don't backtrack or look at the same data again */        if (next_command < writeX_data)            return 0;        /* Skip WriteX header, get size of remaining data */        data_left_len = total_size - andXOffset;        /* Next block is at smbHdr + smb_ntohs(sess_setupx_req->andXOffset) */        return ProcessNextSMBCommand(writeX->andXCommand, smbHdr, next_command,                                     data_left_len, total_size);    }    return 0;}int ProcessSMBTransaction(SMB_HDR *smbHdr, u_int8_t *data, u_int16_t size, u_int16_t total_size){    SMB_TRANS_REQ  *trans;    u_int8_t  *dcerpc_data;    u_int16_t dcerpc_data_len;    u_int16_t data_offset;    /* Only process Trans packet if we think it is part of a DCE/RPC session        NTCREATE state is when we get the bind packet       IS_DCERPC is when we get a request packet      */    if ( _dcerpc->smb_state != STATE_GOT_NTCREATE )    {        return 0;    }    /* We got a Tree Connect followed by a NTCreate, followed by Trans.         Assume DCE/RPC */    _dcerpc->state = STATE_IS_DCERPC;    if ( size <= sizeof(SMB_TRANS_REQ) )    {        return 0;    }    trans = (SMB_TRANS_REQ *)data;    data_offset = smb_ntohs(trans->dataOffset);    dcerpc_data = (u_int8_t *)smbHdr + data_offset;    if ( data_offset >= total_size )        return 0;    /* offset didn't put us after header     * TODO Account for transaction name length - seems like     * for unicode strings there is an extra byte of padding     * after byteCount before name starts */    if (dcerpc_data < (u_int8_t *)trans + sizeof(SMB_TRANS_REQ))        return 0;    dcerpc_data_len = smb_ntohs(trans->totalDataCount);    /* make sure data length doesn't put us past end of packet */    if (dcerpc_data + dcerpc_data_len > (u_int8_t *)smbHdr + total_size)        return 0;    if (dcerpc_data_len > 0)        ProcessDCERPCMessage((u_int8_t *)smbHdr, dcerpc_data - (u_int8_t *)smbHdr, dcerpc_data, dcerpc_data_len);#ifdef DEBUG_DCERPC_PRINT    printf("Trans data: %02.*X\n", dcerpc_data_len, dcerpc_data);#endif    return 0;}int ProcessSMBReadX(SMB_HDR *smbHdr, u_int8_t *data, u_int16_t size, u_int16_t total_size){    SMB_READX_REQ *readX;    if ( size < sizeof(SMB_READX_REQ) )    {        return 0;    }    readX = (SMB_READX_REQ *)data;    data += sizeof(SMB_READX_REQ);    /* Handle next andX command in this packet */    if (readX->andXCommand != SMB_NONE)    {        u_int16_t andXOffset = smb_ntohs(readX->andXOffset);        u_int8_t *next_command;        u_int16_t data_left_len;        if ( andXOffset >= total_size )            return 0;               next_command = (u_int8_t *)smbHdr + andXOffset;        /* Make sure we don't backtrack or look at the same data again */        if (next_command < data)            return 0;        /* Skip ReadX header, get size of remaining data */        data_left_len = total_size - andXOffset;        /* Next block is at smbHdr + smb_ntohs(sess_setupx_req->andXOffset) */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91污片在线观看| 国产不卡视频一区二区三区| 亚洲少妇最新在线视频| 久久综合狠狠综合久久综合88 | 成人免费福利片| 国产综合一区二区| 国产成人亚洲综合a∨婷婷 | 国产精品三级av在线播放| 91精品国产综合久久久久久漫画| 欧美日韩二区三区| 欧美精品一二三四| 日韩精品在线一区| 久久久噜噜噜久噜久久综合| 久久久久免费观看| 亚洲乱码一区二区三区在线观看| 亚洲精品久久久蜜桃| 亚洲v中文字幕| 麻豆成人久久精品二区三区小说| 国内精品国产成人| 国产999精品久久| 欧美做爰猛烈大尺度电影无法无天| 欧美专区在线观看一区| 日韩欧美国产综合| 国产欧美一区二区三区在线看蜜臀 | 色94色欧美sute亚洲线路二| 色综合久久综合网97色综合| 337p亚洲精品色噜噜噜| 国产日韩欧美综合一区| 曰韩精品一区二区| 久久99精品国产麻豆不卡| thepron国产精品| 正在播放亚洲一区| 中文字幕日韩av资源站| 日韩影视精彩在线| 99re视频这里只有精品| 5858s免费视频成人| 综合久久久久综合| 精品一区二区在线视频| 一本到一区二区三区| 精品成人免费观看| 亚洲午夜精品久久久久久久久| 麻豆91在线看| 欧美综合在线视频| 日韩视频一区二区三区| 亚洲免费大片在线观看| 国产精品夜夜爽| 91精品国产一区二区人妖| 中文字幕一区二区三区色视频| 日产欧产美韩系列久久99| www.66久久| 国产拍揄自揄精品视频麻豆| 爽好多水快深点欧美视频| 91麻豆文化传媒在线观看| wwwwww.欧美系列| 免费成人在线网站| 欧美精品一卡二卡| 亚洲午夜影视影院在线观看| 成人精品在线视频观看| 久久亚洲一级片| 久久国产精品99精品国产| 欧美乱妇15p| 亚洲国产一区二区视频| 91香蕉视频黄| 亚洲欧美另类久久久精品| 国产91在线|亚洲| 久久久国产一区二区三区四区小说 | 国产精华液一区二区三区| 91精品国产色综合久久ai换脸| 亚洲精品自拍动漫在线| 一本色道**综合亚洲精品蜜桃冫| 国产午夜亚洲精品午夜鲁丝片| 久久精品国产成人一区二区三区| 欧美一区二区日韩| 毛片av一区二区| 精品国产乱码久久久久久久久 | 日韩理论片中文av| 成人激情校园春色| 亚洲日本韩国一区| 91丨porny丨国产| 一区二区三区中文字幕电影 | 精品国产一区二区三区av性色| 热久久一区二区| 精品福利视频一区二区三区| 免费观看在线综合色| 久久亚洲私人国产精品va媚药| 国产精品99久久久久久似苏梦涵 | 欧美色中文字幕| 午夜免费久久看| 欧美二区乱c少妇| 极品少妇一区二区| 国产精品私人自拍| 欧美影视一区二区三区| 日韩国产精品久久| 久久亚洲春色中文字幕久久久| 国产福利91精品一区二区三区| 成人欧美一区二区三区1314| 色婷婷av一区二区三区大白胸| 亚洲国产婷婷综合在线精品| 91精品免费观看| 国产精品中文字幕欧美| 亚洲免费观看在线观看| 欧美日韩电影一区| 国产成人超碰人人澡人人澡| 亚洲视频一区在线| 欧美一区二区免费| 成人精品在线视频观看| 亚洲影视在线播放| 久久综合给合久久狠狠狠97色69| 不卡影院免费观看| 日本不卡高清视频| 日韩伦理电影网| 日韩欧美你懂的| 成人激情图片网| 美日韩一区二区| 亚洲视频在线一区观看| 欧美一区二区国产| 99精品欧美一区二区蜜桃免费| 图片区小说区国产精品视频| 久久日一线二线三线suv| 色综合久久综合网欧美综合网| 老司机午夜精品99久久| 亚洲激情一二三区| 91免费观看国产| 欧美色视频一区| 一区二区三区在线影院| 日韩欧美在线观看一区二区三区| 97久久超碰国产精品| 精品无人码麻豆乱码1区2区| 一区二区三区四区高清精品免费观看 | 91同城在线观看| 久久综合久久综合久久| 国产精品美女久久福利网站| 一区二区三区四区亚洲| 亚洲高清不卡在线| 美国毛片一区二区三区| 国产.欧美.日韩| 99国产精品国产精品毛片| 欧美色涩在线第一页| 日韩欧美国产精品一区| 久久久久国色av免费看影院| 亚洲同性gay激情无套| 亚洲成人高清在线| 狠狠色丁香久久婷婷综| av亚洲精华国产精华精| 欧美日韩国产一二三| 欧美mv和日韩mv国产网站| 国产精品不卡在线| 五月婷婷另类国产| 国产aⅴ综合色| 欧美日韩在线播| 久久免费看少妇高潮| 亚洲免费在线观看| 精品一区二区三区久久| 99久久免费国产| 日韩精品专区在线影院观看| 国产精品福利av| 老司机精品视频在线| 91免费看`日韩一区二区| 日韩视频在线一区二区| 亚洲精品视频一区二区| 国产精品一二二区| 欧美日韩黄色一区二区| 国产精品系列在线| 欧美a级一区二区| 在线免费视频一区二区| 亚洲国产成人在线| 美女视频黄 久久| 欧美日韩一本到| 国产精品卡一卡二| 国产精品69毛片高清亚洲| 欧美精品一级二级| 亚洲激情中文1区| 成人国产一区二区三区精品| 日韩欧美国产午夜精品| 亚洲狠狠爱一区二区三区| 成人一区二区在线观看| 久久天天做天天爱综合色| 亚洲bt欧美bt精品777| 色国产综合视频| 国产精品电影院| 成人一二三区视频| xvideos.蜜桃一区二区| 日本vs亚洲vs韩国一区三区二区| 日本高清不卡视频| 中文字幕在线不卡国产视频| 国产在线播放一区| 日韩欧美一级在线播放| 亚洲成av人片一区二区梦乃| 91社区在线播放| 亚洲精品免费一二三区| 99久久精品国产毛片| 国产免费久久精品| 成人视屏免费看| 国产清纯在线一区二区www| 国产成人一级电影| 久久婷婷国产综合精品青草| 国产呦精品一区二区三区网站| 日韩精品一区二区三区在线 | 亚洲人成网站色在线观看| 国产成人在线视频网站|