• <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>
            C++中的一粒沙子
            學習C++,做應用開發
            posts - 10,comments - 22,trackbacks - 0
                CMPP協議的全稱是中國移動通信互聯網短信網關接口協議,它是聯想亞信公司根據SMMP協議為中國移動量身定做的,是符合中國國情的一個短信協議,閑話不多說了,說說CMPP的主要功能吧。(1)短信發送(short message mobile originate)MO,就是手機給SP發短信;(2)短信接受(short message mobile terminated)MT,這個就是SP給手機發的短信了,通常我們手機上收到的不良短信就是SP給我們的MT。CMPP協議的通信基礎是TCP/IP為底層通信承載的,連接方式是長連接方式。SP與ISMG之間,SMSC和ISMG之間的交互過程中均采用異步方式,即任一個網元在收到請求消息后應立即回應。
               下面看看它的消息定義:CMPP中的消息分為消息頭和消息體。消息頭定義如下
             
             

            字段名

            字節數

            類型

            描述

            Total_Length  

            4

            Unsigned Integer

            消息總長度(含消息頭及消息體)

            Command_Id

            4

            Unsigned Integer

            命令或響應類型

            Sequence_Id

            4

            Unsigned Integer

            消息流水號,順序累加,步長為1,循環使用(一對請求和應答消息的流水號必須相同)

             
            那么下面就是SP連接到ISMG上了,看它的Bind連接消息定義
             

            字段名

            字節數

            屬性

            描述

            Source_Addr 

            6

            Octet String

            源地址,此處為SP_Id,即SP的企業代碼。

            AuthenticatorSource

            16

            Octet String

            用于鑒別源地址。其值通過單向MD5 hash計算得出,表示如下:

            AuthenticatorSource =

            MD5Source_Addr+9 字節的0 +shared secret+timestamp

            Shared secret 由中國移動與源地址實體事先商定,timestamp格式為:MMDDHHMMSS,即月日時分秒,10位。

            Version

            1

            Unsigned Integer

            雙方協商的版本號(高位4bit表示主版本號,低位4bit表示次版本號),對于3.0的版本,高4bit3,低4位為0

            Timestamp

            4

            Unsigned Integer

            時間戳的明文,由客戶端產生,格式為MMDDHHMMSS,即月日時分秒,10位數字的整型,右對齊

             
            根據上的定義我們可以寫出的代碼,如下,在VC環境下編寫的

            /*
             *函數功能:建立和CMPP網關的直接通路
             *輸入條件:SP用戶名const char *UserName,SP密碼const char *PWD 
             */
            void Ccmpp_API::CmppConnect(const char *UserName, const char *PWD)
            {
             char netbuf[100];
             CMPP_CONNECT *bufer;
             bufer=(CMPP_CONNECT*)netbuf;
             memset(bufer, 0, 100);
             bufer->nTotalLength = htonl(39);//CMPP_CONNECT消息總長度
             bufer->nCommandId = htonl(CMPP_CONNECT_tag);//消息標志
             //自動產生SeqId號
                if (sequenceid == 123456789i32)
             {
              sequenceid = 1;
             }else{
              sequenceid++;
             }
             bufer->nSeqId = htonl(sequenceid);
               
             int MD5Len;
             MD5_CTX md5;//MD5源字串
             CTime TimeData = CTime::GetCurrentTime();
             CString timestamp = TimeData.Format("%m%d%H%M%S");
             unsigned char md5source[29];
             int Len1 = strlen(UserName);
             int Len2 = strlen(PWD); 
             MD5Len = Len1 + 9 +Len2 + timestamp.GetLength();
             memset(md5source, 0, MD5Len);
             
             memcpy(bufer->sSourceAddr, UserName, Len1);
             memcpy(md5source, UserName, Len1);
             
             for (int j = 0; j<Len2; j++)
             {
              md5source[j + Len1 + 9] = PWD[j];
             }
             for (int i=0;i<timestamp.GetLength();i++)
             {
              md5source[i + Len2 + Len1 + 9]=timestamp[i];
             }
             
             //進行md5加密轉換
             md5.MD5Update(md5source, MD5Len);
             md5.MD5Final(md5source);
             memcpy(bufer->sAuthSource, md5source, 29);
             bufer->cVersion = 0x30;
             bufer->nTimeStamp = htonl(atoi(timestamp));
             CmppSocket.Send(bufer, 39, 0);//把消息打包發送
             return;
            }
             
            今天就到這,下次再寫,歡迎交流!
            posted on 2006-03-15 07:58 炙熱的太陽 閱讀(9526) 評論(8)  編輯 收藏 引用

            FeedBack:
            # re: 淺談CMPP協議(一)
            2006-03-15 10:38 | 小明
            you say:
            SP與ISMG之間,SMSC和ISMG之間的交互過程中均采用異步方式,即任一個網元在收到請求消息后應立即回應。

            既然是異步方式,就不是收到請求后立即回應,否則就是同步方式了

            據我所知,CMPP采用的基于滑動窗口的異步方式,默認情況下可以發最多16的CMPP package,而不必等待他們的resp.  回復  更多評論
              
            # re: 淺談CMPP協議(一)
            2006-03-15 11:21 | 炙熱的太陽
            是的,你說的沒有錯。

            消息是采用并發方式發送,加以滑動窗口流量控制,窗口大小參數W可配置,現階段的配置為16,即接收方在應答前一次收到的消息最多不超過16條。這是它們之間的通信方式。

            而SP與ISMG之間,SMSC和ISMG之間的交互過程中均采用異步方式,即任一個網元在收到請求消息后應立即回應。這是它們交互過程中的應答方式。即收到一個消息就應該回一個回應消息,而不管對方是否收到,所以上面講的并沒有錯喲。


              回復  更多評論
              
            # re: 淺談CMPP協議(一)
            2006-03-17 14:43 | 炙熱的太陽
            發一個在網上找到的一段代碼,用stl寫的connect;
            void CSmsCmpp::EncodeConnect(const long& nSecID,const string& sSrcAddr, const string& sPwd, const string& sUser, BYTE nVer)
            {
            m_smHeader.lCommandLength = 39;
            m_smHeader.lCommandId = CMPP_CONNECT;
            m_smHeader.lSequenceNumber = nSecID;
            EncodeHeader();

            string sAuthName;
            if(int(sUser.size())>0) {
            sAuthName = sUser.c_str();
            }
            else {
            sAuthName = sSrcAddr.c_str();
            }
            AppendOct(m_Body,(PBYTE)sAuthName.c_str(),6);

            vector<BYTE> vAuth;
            std::copy(sAuthName.begin(),sAuthName.end(),back_inserter(vAuth));
            for(int i=0;i<9;i++) vAuth.push_back(0x00);
            std::copy(sPwd.begin(),sPwd.end(),back_inserter(vAuth));
            string sStamp = GetCurTime();
            std::copy(sStamp.begin(),sStamp.end(),back_inserter(vAuth));

            char src[400];
            memset(src,0,400);
            std::copy(vAuth.begin(),vAuth.end(),src);

            PBYTE temp = new BYTE[17];
            memset(temp,0,17);
            DWORD dwSize;
            CryptMD5Hash((PBYTE)src,int(vAuth.size()),temp,dwSize);

            ostringstream oss;
            oss<<"發送連接包!";


            AppendOct(m_Body,(PBYTE)temp,16); //ICP認證碼
            delete[] temp;
            AppendInt(m_Body,nVer);
            DWORD lTimeStamp = atoi(sStamp.c_str());
            lTimeStamp = htonl(lTimeStamp);
            AppendOct(m_Body,(PBYTE)&lTimeStamp,4);
            }  回復  更多評論
              
            # re: 淺談CMPP協議(一)
            2007-08-07 14:16 | 過客
            內容講解不作評論了。不過CMPP的來歷卻不是樓主所說的來自于聯想亞信  回復  更多評論
              
            # re: 淺談CMPP協議(一)
            2007-08-07 14:22 | 過客
            關于異步與同步再說2句。
            對于CMPP、SMPP、SGIP、以及互聯互通的短信協議,異步是指對于發送方在消息發送的時候,在滑動窗口的設定范圍內不必等待接受方的Response消息返回,可以連續發送數據包。所謂的response即時回應,是指接受方在收到發送方的消息時,必須立即發送response包進行回應。因此,通常是用多線程技術實現這2個機制。
              回復  更多評論
              
            # re: 淺談CMPP協議(一)
            2007-11-23 09:58 | pyrophile
            @過客
            CMPP就是中國移動讓亞信給定作的,不信你可以到網上查  回復  更多評論
              
            # re: 淺談CMPP協議(一)[未登錄]
            2009-03-06 17:48 | peter
            能用java實現嗎?  回復  更多評論
              
            # re: 淺談CMPP協議(一)[未登錄]
            2014-04-05 21:20 | 菜鳥
            @小明
            你好,想探討下滑動窗口是怎么計算的,一條群發短信發出去,滑動窗口是按一條算還是按群發發實際拆分的條數呢?  回復  更多評論
              
            欧美与黑人午夜性猛交久久久| 国产韩国精品一区二区三区久久| 99久久精品免费国产大片| 中文字幕亚洲综合久久| 久久一区二区免费播放| 日韩AV无码久久一区二区 | 91久久精品国产免费直播| 精品乱码久久久久久夜夜嗨| 狠狠色婷婷久久综合频道日韩| 国产精品久久久久久一区二区三区| 一本久久a久久精品综合夜夜| 久久精品国产AV一区二区三区| 国产精品美女久久久| 国产欧美久久久精品影院| 亚洲国产精品婷婷久久| 嫩草伊人久久精品少妇AV| 香蕉99久久国产综合精品宅男自 | 99久久精品日本一区二区免费 | 亚洲午夜久久久久妓女影院| 大香网伊人久久综合网2020| 久久综合给合久久国产免费 | 四虎国产精品免费久久5151| 久久精品国产亚洲AV蜜臀色欲| 国内精品久久久久久久影视麻豆| 欧洲精品久久久av无码电影| 久久天天躁夜夜躁狠狠躁2022 | 99久久国产综合精品麻豆| 99久久免费国产精品特黄| 亚洲伊人久久成综合人影院| 国产成人香蕉久久久久| 久久久久久久综合日本亚洲| 久久精品无码一区二区三区| 久久久久无码精品国产不卡| 久久国产精品成人片免费| 久久亚洲精精品中文字幕| 精品久久久久久中文字幕人妻最新| 亚洲国产欧洲综合997久久| 国产69精品久久久久久人妻精品| 久久婷婷国产剧情内射白浆| 精品久久久中文字幕人妻| 亚洲AV无码成人网站久久精品大|