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

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

?? spnegoparse.c

?? 代理服務器 squid-2.6.STABLE16
?? C
?? 第 1 頁 / 共 5 頁
字號:
//    [in]  pbTokenData             -  Points to binary element data in//                                     a SPNEGO token.//    [in]  nElementLength          -  Length of the element//    [in]  ucExpectedType          -  Expected DER type.//    [in]  spnegoElementType       -  Which element is this?//    [out] pSpnegoElement          -  Filled out with element data.//// Returns://    int   Success - SPNEGO_E_SUCCESS//          Failure - SPNEGO API Error code//// Comments ://    Checks that pbTokenData is pointing at the specified DER type.  If so,//    then we verify that lengths are proper and then fill out the //    SPNEGO_ELEMENT data structure.//////////////////////////////////////////////////////////////////////////////int InitSpnegoTokenElementFromBasicType( unsigned char* pbTokenData, int nElementLength,                                          unsigned char ucExpectedType,                                          SPNEGO_ELEMENT_TYPE spnegoElementType,                                          SPNEGO_ELEMENT* pSpnegoElement ){   int   nReturn = SPNEGO_E_UNEXPECTED_TYPE;   long  nLength = 0L;   long  nActualTokenLength = 0L;   // The type BYTE must match our token data or something is badly wrong   if ( *pbTokenData == ucExpectedType )   {      // Check that we are pointing at the specified type      if ( ( nReturn = ASNDerCheckToken( pbTokenData, ucExpectedType,                                          nElementLength, nElementLength,                                          &nLength, &nActualTokenLength ) )                                == SPNEGO_E_SUCCESS )      {         // Adjust for this token         nElementLength -= nActualTokenLength;         pbTokenData += nActualTokenLength;         // Initialize the element now         pSpnegoElement->eElementType = spnegoElementType;         pSpnegoElement->iElementPresent = SPNEGO_TOKEN_ELEMENT_AVAILABLE;         pSpnegoElement->type = ucExpectedType;         pSpnegoElement->nDatalength = nLength;         pSpnegoElement->pbData = pbTokenData;      }   }  // IF type makes sense   LOG(("InitSpnegoTokenElementFromBasicType returned %d\n",nReturn));   return nReturn;}///////////////////////////////////////////////////////////////////////////////// Function://    InitSpnegoTokenElementFromOID//// Parameters://    [in]  pbTokenData             -  Points to binary element data in//                                     a SPNEGO token.//    [in]  nElementLength          -  Length of the element//    [in]  spnegoElementType       -  Which element is this?//    [out] pSpnegoElement          -  Filled out with element data.//// Returns://    int   Success - SPNEGO_E_SUCCESS//          Failure - SPNEGO API Error code//// Comments ://    Initializes a SpnegoElement from an OID - normally, this would have//    used the Basic Type function above, but since we do binary compares//    on the OIDs against the DER information as well as the OID, we need//    to account for that.//////////////////////////////////////////////////////////////////////////////int InitSpnegoTokenElementFromOID( unsigned char* pbTokenData, int nElementLength,                                   SPNEGO_ELEMENT_TYPE spnegoElementType,                                   SPNEGO_ELEMENT* pSpnegoElement ){   int   nReturn = SPNEGO_E_UNEXPECTED_TYPE;   long  nLength = 0L;   long  nActualTokenLength = 0L;   // The type BYTE must match our token data or something is badly wrong   if ( *pbTokenData == OID )   {      // Check that we are pointing at an OID type      if ( ( nReturn = ASNDerCheckToken( pbTokenData, OID,                                          nElementLength, nElementLength,                                          &nLength, &nActualTokenLength ) )                                == SPNEGO_E_SUCCESS )      {         // Don't adjust any values for this function         // Initialize the element now         pSpnegoElement->eElementType = spnegoElementType;         pSpnegoElement->iElementPresent = SPNEGO_TOKEN_ELEMENT_AVAILABLE;         pSpnegoElement->type = OID;         pSpnegoElement->nDatalength = nElementLength;         pSpnegoElement->pbData = pbTokenData;      }   }  // IF type makes sense   LOG(("InitSpnegoTokenElementFromBasicType returned %d\n",nReturn));   return nReturn;}///////////////////////////////////////////////////////////////////////////////// Function://    InitSpnegoTokenElements//// Parameters://    [in]  pSpnegoToken            -  Points to SPNEGO_TOKEN struct//    [in]  pbTokenData             -  Points to initial binary element//                                     data in a SPNEGO token.//    [in]  nRemainingTokenLength   -  Length remaining past header//// Returns://    int   Success - SPNEGO_E_SUCCESS//          Failure - SPNEGO API Error code//// Comments ://    Interprets the data at pbTokenData based on the TokenType in//    pSpnegoToken.  Since some elements are optional (technically all are//    but the token becomes quite useless if this is so), we check if//    an element exists before filling out the element in the array.//////////////////////////////////////////////////////////////////////////////int InitSpnegoTokenElements( SPNEGO_TOKEN* pSpnegoToken, unsigned char* pbTokenData,                           long nRemainingTokenLength  ){   //   // The following arrays contain the token identifiers for the elements   // comprising the actual token.  All values are optional, and there are   // no defaults.   //   static unsigned char abNegTokenInitElements[] =      { SPNEGO_NEGINIT_ELEMENT_MECHTYPES, SPNEGO_NEGINIT_ELEMENT_REQFLAGS,         SPNEGO_NEGINIT_ELEMENT_MECHTOKEN, SPNEGO_NEGINIT_ELEMENT_MECHLISTMIC };   static unsigned char abNegTokenTargElements[] =      { SPNEGO_NEGTARG_ELEMENT_NEGRESULT, SPNEGO_NEGTARG_ELEMENT_SUPPORTEDMECH,         SPNEGO_NEGTARG_ELEMENT_RESPONSETOKEN, SPNEGO_NEGTARG_ELEMENT_MECHLISTMIC };   int   nReturn = SPNEGO_E_SUCCESS;   int   nCtr = 0L;   long  nElementLength = 0L;   long  nActualTokenLength = 0L;   unsigned char* pbElements = NULL;   // Point to the correct array   switch( pSpnegoToken->ucTokenType )   {      case SPNEGO_TOKEN_INIT:      {         pbElements = abNegTokenInitElements;      }      break;      case SPNEGO_TOKEN_TARG:      {         pbElements = abNegTokenTargElements;      }      break;   }  // SWITCH tokentype   //   // Enumerate the element arrays and look for the tokens at our current location   //   for ( nCtr = 0L;         SPNEGO_E_SUCCESS == nReturn &&         nCtr < MAX_NUM_TOKEN_ELEMENTS &&         nRemainingTokenLength > 0L;         nCtr++ )   {            // Check if the token exists      if ( ( nReturn = ASNDerCheckToken( pbTokenData, pbElements[nCtr],                                          0L, nRemainingTokenLength,                                          &nElementLength, &nActualTokenLength ) )                                == SPNEGO_E_SUCCESS )      {         // Token data should skip over the sequence token and then         // call the appropriate function to initialize the element         pbTokenData += nActualTokenLength;         // Lengths in the elements should NOT go beyond the element         // length         // Different tokens mean different elements         if ( SPNEGO_TOKEN_INIT == pSpnegoToken->ucTokenType )         {            // Handle each element as appropriate            switch( pbElements[nCtr] )            {               case SPNEGO_NEGINIT_ELEMENT_MECHTYPES:               {                  //                  // This is a Mech List that specifies which OIDs the                  // originator of the Init Token supports.                  //                  nReturn = GetSpnegoInitTokenMechList( pbTokenData, nElementLength,                                                         &pSpnegoToken->aElementArray[nCtr] );               }               break;               case SPNEGO_NEGINIT_ELEMENT_REQFLAGS:               {                  //                  // This is a BITSTRING which specifies the flags that the receiver                  // pass to the gss_accept_sec_context() function.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  BITSTRING, spnego_init_reqFlags,                                                                  &pSpnegoToken->aElementArray[nCtr] );               }               break;               case SPNEGO_NEGINIT_ELEMENT_MECHTOKEN:               {                  //                  // This is an OCTETSTRING which contains a GSSAPI token corresponding                  // to the first OID in the MechList.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  OCTETSTRING, spnego_init_mechToken,                                                                  &pSpnegoToken->aElementArray[nCtr] );              }               break;               case SPNEGO_NEGINIT_ELEMENT_MECHLISTMIC:               {                  //                  // This is an OCTETSTRING which contains a message integrity BLOB.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  OCTETSTRING, spnego_init_mechListMIC,                                                                  &pSpnegoToken->aElementArray[nCtr] );               }               break;            }  // SWITCH Element         }         else         {            switch( pbElements[nCtr] )            {               case SPNEGO_NEGTARG_ELEMENT_NEGRESULT:               {                  //                  // This is an ENUMERATION which specifies result of the last GSS                  // token negotiation call.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  ENUMERATED, spnego_targ_negResult,                                                                  &pSpnegoToken->aElementArray[nCtr] );               }               break;               case SPNEGO_NEGTARG_ELEMENT_SUPPORTEDMECH:               {                  //                  // This is an OID which specifies a supported mechanism.                  //                  nReturn = InitSpnegoTokenElementFromOID( pbTokenData, nElementLength,                                                           spnego_targ_mechListMIC,                                                           &pSpnegoToken->aElementArray[nCtr] );               }               break;               case SPNEGO_NEGTARG_ELEMENT_RESPONSETOKEN:               {                  //                  // This is an OCTETSTRING which specifies results of the last GSS                  // token negotiation call.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  OCTETSTRING, spnego_targ_responseToken,                                                                  &pSpnegoToken->aElementArray[nCtr] );               }               break;               case SPNEGO_NEGTARG_ELEMENT_MECHLISTMIC:               {                  //                  // This is an OCTETSTRING which specifies a message integrity BLOB.                  //                  nReturn = InitSpnegoTokenElementFromBasicType( pbTokenData, nElementLength,                                                                  OCTETSTRING, spnego_targ_mechListMIC,                                                                  &pSpnegoToken->aElementArray[nCtr] );               }               break;            }  // SWITCH Element         }  // ELSE !NegTokenInit         // Account for the entire token and following data         nRemainingTokenLength -= ( nActualTokenLength + nElementLength );         // Token data should skip past the element length now         pbTokenData += nElementLength;      }  // IF Token found      else if ( SPNEGO_E_TOKEN_NOT_FOUND == nReturn )      {         // For now, this is a benign error (remember, all elements are optional, so         // if we don't find one, it's okay).         nReturn = SPNEGO_E_SUCCESS;      }   }  // FOR enum elements   //   // We should always run down to 0 remaining bytes in the token.  If not, we've got   // a bad token.   //   if ( SPNEGO_E_SUCCESS == nReturn && nRemainingTokenLength != 0L )   {      nReturn = SPNEGO_E_INVALID_TOKEN;   }   LOG(("InitSpnegoTokenElements returned %d\n",nReturn));   return nReturn;}///////////////////////////////////////////////////////////////////////////////// Function://    FindMechOIDInMechList//// Parameters://    [in]  pSpnegoElement          -  SPNEGO_ELEMENT for MechList//    [in]  MechOID                 -  OID we're looking for.//    [out] piMechTypeIndex         -  Index in the list where OID was//                                     found//// Returns://    int   Success - SPNEGO_E_SUCCESS//          Failure - SPNEGO API Error code//// Comments ://    Walks the MechList for MechOID.  When it is found, the index in the//    list is written to piMechTypeIndex.//////////////////////////////////////////////////////////////////////////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清不卡二三区| 色综合久久久久综合99| 成人美女在线视频| 欧美日韩成人激情| 中文字幕一区二区三区四区 | 欧美第一区第二区| 国产精品色噜噜| 一区二区久久久久久| 国产精品一区二区三区99| 欧美日韩精品二区第二页| 国产精品动漫网站| 极品美女销魂一区二区三区免费| 亚洲日本青草视频在线怡红院| 国产亚洲欧美日韩日本| 天堂久久一区二区三区| 日本国产一区二区| 亚洲欧美另类图片小说| 成人午夜伦理影院| 亚洲国产精品传媒在线观看| 国模少妇一区二区三区| 日韩一卡二卡三卡四卡| 一区二区在线观看不卡| 99re热这里只有精品视频| 国产性做久久久久久| 国产一区二区导航在线播放| 精品国产91洋老外米糕| 麻豆精品视频在线观看视频| 日韩欧美资源站| 奇米一区二区三区| 欧美一卡2卡三卡4卡5免费| 秋霞成人午夜伦在线观看| 欧美亚洲自拍偷拍| 亚洲国产精品麻豆| 欧美军同video69gay| 亚洲18色成人| 日韩一区二区三区免费观看| 麻豆精品在线播放| 久久精品亚洲麻豆av一区二区 | 韩国一区二区视频| 精品蜜桃在线看| 国产剧情一区在线| 欧美成人r级一区二区三区| 日本不卡一二三| 91亚洲午夜精品久久久久久| 久久精品国产在热久久| 精品少妇一区二区| 国产成人精品三级麻豆| 国产精品久久久久久福利一牛影视 | 中文字幕亚洲区| 色婷婷久久久综合中文字幕| 亚洲图片欧美视频| 日韩精品一区二区三区四区 | 成人国产精品免费网站| 久久久久久9999| 国产精品538一区二区在线| 欧美国产精品劲爆| 在线观看区一区二| 免费在线观看视频一区| 久久先锋影音av| 一本久久综合亚洲鲁鲁五月天| 久久久午夜电影| 99国产精品久| 性做久久久久久久免费看| 日韩欧美国产一二三区| 不卡的av网站| 免费看日韩a级影片| 国产精品成人午夜| 6080国产精品一区二区| 不卡的av网站| 蜜桃av一区二区在线观看| 国产精品短视频| 欧美一级黄色大片| 色综合视频一区二区三区高清| 国产午夜精品一区二区三区四区| 奇米四色…亚洲| 中文字幕av资源一区| 欧美日韩国产一级| 丁香另类激情小说| 午夜电影网一区| 中文在线一区二区| 欧美一级xxx| 色婷婷综合在线| 国产很黄免费观看久久| 日韩一区精品字幕| 亚洲精品伦理在线| 国产三级精品视频| 日韩欧美www| 亚洲一区二区黄色| 欧洲av一区二区嗯嗯嗯啊| 成人中文字幕合集| 日本不卡1234视频| 亚洲高清视频的网址| 国产精品久久久久久久久免费相片| 国内一区二区视频| 亚洲妇熟xx妇色黄| 亚洲男人的天堂一区二区| 日本一区二区成人在线| 精品国产欧美一区二区| 欧美美女直播网站| 在线观看亚洲精品| 91丨九色丨黑人外教| 高清久久久久久| 国产一区二区免费看| 久久91精品国产91久久小草| 秋霞av亚洲一区二区三| 午夜av一区二区| 夜夜亚洲天天久久| 一区二区三区精品| 亚洲视频在线观看三级| 亚洲日本一区二区| 一区二区在线观看免费视频播放| 91超碰这里只有精品国产| 91年精品国产| 91丨porny丨蝌蚪视频| eeuss国产一区二区三区| av电影在线不卡| 91丝袜美女网| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 水蜜桃久久夜色精品一区的特点| 日韩一区二区免费电影| 欧美精品99久久久**| 717成人午夜免费福利电影| 欧美一区二区视频网站| 在线成人免费观看| 日韩精品最新网址| 久久精品亚洲麻豆av一区二区| 欧美亚洲禁片免费| 欧美日韩国产123区| 欧美一区二区三区免费观看视频| 粗大黑人巨茎大战欧美成人| 99久久夜色精品国产网站| 99久久精品免费看国产| 色8久久人人97超碰香蕉987| 欧美伦理视频网站| 久久无码av三级| 中文字幕一区二区在线观看| 亚洲狠狠爱一区二区三区| 久久99久久精品欧美| 毛片av中文字幕一区二区| 激情综合亚洲精品| 99这里只有精品| 欧美精品在线一区二区三区| 日韩精品一区二区三区在线播放 | 亚洲美女精品一区| 一区二区三区欧美视频| 天天亚洲美女在线视频| 久久99精品久久久久久| 国产91精品一区二区麻豆亚洲| 黄色成人免费在线| 国产成人免费网站| 91九色02白丝porn| 精品国产精品网麻豆系列| 中文字幕在线不卡视频| 亚洲国产成人av| 丁香婷婷综合色啪| 欧美日韩一本到| 国产欧美综合在线| 亚洲午夜精品17c| 国产综合色视频| 欧美色窝79yyyycom| 久久尤物电影视频在线观看| 亚洲精品视频免费看| 激情综合网天天干| 欧美亚洲自拍偷拍| 欧美韩国日本不卡| 日韩高清欧美激情| 99r精品视频| 国产欧美久久久精品影院| 亚洲一区二区三区四区在线免费观看 | 国产专区综合网| 欧美三级日韩在线| 亚洲私人影院在线观看| 麻豆91精品视频| 91行情网站电视在线观看高清版| 色综合夜色一区| 久久久av毛片精品| 爽好多水快深点欧美视频| 91最新地址在线播放| 久久久久久夜精品精品免费| 琪琪久久久久日韩精品| 91蝌蚪国产九色| 中文一区一区三区高中清不卡| 中文字幕一区二区三区精华液| 国产精品久久久久久久久免费樱桃| 中文字幕精品在线不卡| 久久国产精品色| 5月丁香婷婷综合| 亚洲国产精品一区二区www| 91免费观看国产| 亚洲天堂网中文字| 成人国产精品视频| 国产亚洲一二三区| 国产乱人伦偷精品视频不卡| 依依成人精品视频| 久久av老司机精品网站导航| 欧美一区二区三区在线视频| 亚洲成av人综合在线观看| 欧美在线一二三| 亚洲国产日韩av| 7777精品伊人久久久大香线蕉完整版 |