• <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>

            西城

            指尖代碼,手上年華

            聯系 聚合 管理
              20 Posts :: 0 Stories :: 62 Comments :: 0 Trackbacks
            例子中的一句代碼,用來取得用戶從瀏覽器的輸入信息。
            cgicc::form_iterator name = cgi.getElement("name");
            之前已經創建好Cgicc類。想研究一下Cgicc類究竟做了什么。
            可以猜測,在調用getElement之前,Cgicc已經存儲好了所有的輸入。
            Cgicc的構造函數主體如下:
            CGICCNS Cgicc::Cgicc(reader_function_t stream_reader)
              : fEnvironment(stream_reader)
            {
              fFormData.reserve(40);
              fFormFiles.reserve(5);

              if(stringsAreEqual(getEnvironment().getRequestMethod(), "post"))
                parseFormInput(getEnvironment().getPostData());
              else
                parseFormInput(getEnvironment().getQueryString());
            }
            在初始化參數表中,首先創建一個CgiEnvironment的類的實例,用來初始化系統信息,讀取從服務器傳來的各個參數。其中包括請求的方法(POST或者GET)。
            然后為兩個vector分配存儲空間。然后通過查看請求的方法調用相應的函數。下面以post為例:
            getEnvironment是一個內聯函數,用來返回Cgicc的私有變量fEnvironment.fEnvironment的getPostData()方法返回其私有變量fPostData(std::string);
            而在CgiEnvirontment的構造函數中:
                STDNS auto_ptr<char> temp(new char[getContentLength()]);

                // use the appropriate reader function
                if(stream_reader == NULL) {
                  STDNS cin.read(temp.get(), getContentLength());
                  if((unsigned long)STDNS cin.gcount() != getContentLength())
                throw STDNS runtime_error("I/O error");
                }
                else {
                  // user specified a reader function
                  if((*stream_reader)
                 (temp.get(), getContentLength()) != getContentLength())
                throw STDNS runtime_error("I/O error");
                }

                fPostData = STDNS string(temp.get(), getContentLength());

            cin讀取用戶請求并存至temp中,并復制至fPostData中。這就是我們要處理的數據。(temp使用標準庫的auto_ptr,會自動銷毀)。


            對fPostData的進一步處理則由Cgicc::parserFormInput來做。而parserFormInput則通過對整個字符串的解析將其分成鍵值對,形成一個FormEntry對象,并存入
            fFormData(vector)中。所以,在cgicc類創建之后就可以直接通過查詢相應的輸入數據。getElement利用標準庫算法find_if在vector中查找相應的值。STL中一般
            用迭代器查找時若無結果都會將迭代器置于容器后一位,所以判斷是否查找成功的代碼應該這樣寫:
            if(name != cgi.getElements().end()) {
               // iterator refers to a valid element
            }

            posted on 2012-03-26 16:47 西城 閱讀(2422) 評論(0)  編輯 收藏 引用 所屬分類: Cgicc
            伊人热热久久原色播放www | 久久精品国产亚洲欧美| 亚洲中文字幕久久精品无码喷水| 色婷婷综合久久久中文字幕| 久久99国产综合精品女同| 97热久久免费频精品99| 香蕉久久一区二区不卡无毒影院| 亚洲国产婷婷香蕉久久久久久| 日韩人妻无码一区二区三区久久 | 日韩AV无码久久一区二区| 久久精品国产亚洲AV无码偷窥| 国产精品久久久99| 一本色道久久88精品综合| 91精品国产高清91久久久久久| 久久亚洲AV成人无码软件| 久久国产精品久久国产精品| 伊人久久精品影院| 国产高清美女一级a毛片久久w| 色综合久久综合中文综合网| 精品久久久久中文字幕一区| 久久久亚洲欧洲日产国码二区| 欧美精品丝袜久久久中文字幕 | 人人狠狠综合久久亚洲88| 国产精品久久久久久久久久影院| 日本久久久久久中文字幕| 久久九九精品99国产精品| 亚洲国产成人久久精品99 | 性做久久久久久久久老女人| 99久久夜色精品国产网站| 日韩va亚洲va欧美va久久| 丁香狠狠色婷婷久久综合| 久久久久久久女国产乱让韩| 国产99久久久国产精品~~牛| 久久久久四虎国产精品| 色欲久久久天天天综合网精品| 亚洲国产精品无码久久SM| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 日韩va亚洲va欧美va久久| 久久九九免费高清视频| 久久久不卡国产精品一区二区| 人妻丰满?V无码久久不卡|