• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Codejie's C++ Space

            Using C++

            輪子:Telnet Server的仿照實現


                就如前幾天說的,我需要一個'TelnetServer'來插入到程序里面,以實現相應的調試工作。我們知道一個符合Telnet標準的服務器還是滿復雜的,能力所限,于是我只能寫一個自己能看得過去的仿照版的TelnetServer -- CmdChannel。
                CmdChannel有著和TelnetServer類似的能力需求--通過Telnet登錄,然后執(zhí)行所需命令;簡單點說,就是一個Shell。從需求可以看出,首先需要一個Socket Server,用于建立Telnet連接,然后需要一個命令解析器,用于判斷輸入的命令,再,這兩個就夠了。下圖是組成框架。


                如圖中各模塊的名稱可以看出,TelnetServer負責偵聽和維護Telnet的連接,CmdParser負責解析命令輸入,而GlobalData只是一個數據塊,用于存儲各種所需數據,如Socket連接、命令參數等等。
                流程很簡單,CmdChannel初始并運行后,TelnetServer啟動ListenSocket建立Socket服務,偵聽通過Telnet建立的連接,并將連接數據記錄在ClientSocket中;當收到命令輸入后,TelnetServer將命令字串交由CmdParser進行分解和分析,當CmdParser匹配到指定命令后,傳遞命令行分解出來的參數給命令的回調函數,并執(zhí)行該回調函數;函數做該做的事情,然后結束。

                群眾常說,無圖無真相,OK,運行圖在下面:


                下面這個是Ubuntu的

             



               根據需要,代碼由C實現,供應用調用,由于CmdChannel的目的只是用于調試,在release時不應被包含在應用代碼中,因此,CmdChannel被封裝為Library,通過幾個簡單的宏進行相關的操作。下面是測試代碼:
            int my_cmd_hello(struct _cc_telnet_clientdata* client, int argc, const char argv[][CC_SIZE_CMD])
            {
                
            if(argc > 0)
                
            {
                    CC_CMD_OUTPUT(client, 
            "hello %s\r\n", argv[0]);    
                }

                
            else
                
            {
                    CC_CMD_OUTPUT(client, 
            "helloooo, whom do you want to say hello to?\r\n");
                }

                
            return 0;
            }


            int main()
            {
                CC_CREATE(
            "CC>>""192.168.56.1"200002);    
                CC_REGCMD(
            "hello""say hello to..", my_cmd_hello);
                CC_DESTROY();

                
            while(1)
                
            {
                    Sleep(
            1000);
                }

                
            return 0;
            }

                可見,使用起來是相當的簡單,嘿嘿。。。
                目前只是實現了WinSock的TelnetServer,過幾天再添加BSD-Socket的相關代碼。今天的篇幅有點長了,代碼我貼后面的隨筆中了,有興趣的,一起Review吧~

            posted on 2009-12-16 22:43 codejie 閱讀(1554) 評論(2)  編輯 收藏 引用 所屬分類: C++ 、輪子精神

            評論

            # re: 輪子:Telnet Server的仿照實現[未登錄] 2012-01-12 10:08 venus

            你好 請問 你這程序是否可以作為telnet client使用呢?
              回復  更多評論   

            # re: 輪子:Telnet Server的仿照實現 2012-01-12 10:37 codejie

            @venus
            代碼是用來模擬Telnet Server的,應該沒法Client;想來Client應該比較簡單,就是字符串的發(fā)送和接收。另外,這個只是一個簡單的命令行處理加Socket通信,不算是真正的符合Telnet規(guī)范的Server。  回復  更多評論   

            公告

            Using C++

            導航

            統(tǒng)計

            留言簿(73)

            隨筆分類(513)

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品免费观看| 国产精品一区二区久久精品无码| 久久久久亚洲精品天堂久久久久久| 99久久国产主播综合精品| 香蕉久久AⅤ一区二区三区| 天天躁日日躁狠狠久久 | 久久久久亚洲AV成人网人人网站 | 精品久久久久久无码中文野结衣| 久久涩综合| 久久99久久99小草精品免视看| 久久99精品国产99久久6| 国产精品乱码久久久久久软件| 狠狠88综合久久久久综合网| 亚洲乱码日产精品a级毛片久久| 狠狠色丁香久久综合婷婷| 久久久噜噜噜久久中文字幕色伊伊| 青青热久久综合网伊人| 中文无码久久精品| 香蕉aa三级久久毛片| 久久国产精品无码网站| 国产精品青草久久久久婷婷| 久久精品亚洲AV久久久无码| 久久久中文字幕日本| 亚洲午夜精品久久久久久人妖| 久久国产乱子伦免费精品| 久久99热这里只有精品国产| 久久久99精品成人片中文字幕| 国产精品久久久久久久久免费| 久久精品国产清自在天天线 | 国产精品狼人久久久久影院| 久久国产精品99精品国产987| 青草国产精品久久久久久| 亚洲AV无码久久精品蜜桃| 亚洲AV日韩精品久久久久| 亚洲另类欧美综合久久图片区| 污污内射久久一区二区欧美日韩| 亚洲一区二区三区日本久久九| 国产精品日韩深夜福利久久| 青青草国产成人久久91网| 久久国产精品偷99| 欧美大战日韩91综合一区婷婷久久青草 |