⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cookhlpr.cpp

📁 著名的 helix realplayer 基于手机 symbian 系统的 播放器全套源代码
💻 CPP
字号:
/* ***** BEGIN LICENSE BLOCK ***** 
 * Version: RCSL 1.0/RPSL 1.0 
 *  
 * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved. 
 *      
 * The contents of this file, and the files included with this file, are 
 * subject to the current version of the RealNetworks Public Source License 
 * Version 1.0 (the "RPSL") available at 
 * http://www.helixcommunity.org/content/rpsl unless you have licensed 
 * the file under the RealNetworks Community Source License Version 1.0 
 * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
 * in which case the RCSL will apply. You may also obtain the license terms 
 * directly from RealNetworks.  You may not use this file except in 
 * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
 * applicable to this file, the RCSL.  Please see the applicable RPSL or 
 * RCSL for the rights, obligations and limitations governing use of the 
 * contents of the file.  
 *  
 * This file is part of the Helix DNA Technology. RealNetworks is the 
 * developer of the Original Code and owns the copyrights in the portions 
 * it created. 
 *  
 * This file, and the files included with this file, is distributed and made 
 * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
 * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
 * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
 * 
 * Technology Compatibility Kit Test Suite(s) Location: 
 *    http://www.helixcommunity.org/content/tck 
 * 
 * Contributor(s): 
 *  
 * ***** END LICENSE BLOCK ***** */ 

#include "hlxclib/string.h"
//#include <stdio.h>

#include "hxcom.h"
#include "hxtypes.h"
#include "hxresult.h"
#include "chxpckts.h"
#include "hxstrutl.h"
#include "ihxcookies.h"
#include "cookhlpr.h"

#if defined(_AIX )
#include <ctype.h>      // for isspace()
#endif

HXCookiesHelper::HXCookiesHelper()
	: m_lRefCount(0)
{    
}

HXCookiesHelper::~HXCookiesHelper()
{
}

STDMETHODIMP
HXCookiesHelper::QueryInterface(REFIID riid, void**ppvObj)
{
	QInterfaceList qiList[] =
	{
		{ GET_IIDHANDLE(IID_IUnknown), this },
		{ GET_IIDHANDLE(IID_IHXCookiesHelper), (IHXCookiesHelper*) this },
	};	
    return QIFind(qiList, QILISTSIZE(qiList), riid, ppvObj);
}

/////////////////////////////////////////////////////////////////////////
//  Method:
//	IUnknown::AddRef
//  Purpose:
//	Everyone usually implements this the same... feel free to use
//	this implementation.
//
STDMETHODIMP_(ULONG32) 
HXCookiesHelper::AddRef()
{
    return InterlockedIncrement(&m_lRefCount);
}

/////////////////////////////////////////////////////////////////////////
//  Method:
//	IUnknown::Release
//  Purpose:
//	Everyone usually implements this the same... feel free to use
//	this implementation.
//
STDMETHODIMP_(ULONG32) 
HXCookiesHelper::Release()
{
    if (InterlockedDecrement(&m_lRefCount) > 0)
    {
        return m_lRefCount;
    }

    delete this;
    return 0;
}

STDMETHODIMP
HXCookiesHelper::Pack(IHXBuffer*	pCookies,
		       REF(IHXValues*)	pCookiesHeader)
{
    HX_RESULT	    hr = HXR_OK;
    char*	    ptr = NULL;
    char*	    semi_colon = NULL;
    char*	    set_cookie_header = NULL;
    char*	    slash = NULL;
    char*	    equal = NULL;    
    char*	    date = NULL;
    char*	    path_from_header = NULL;
    char*	    domain_from_header = NULL;
    char*	    name_from_header = NULL;
    char*	    cookie_from_header = NULL;
    IHXBuffer*	    pBuffer = NULL;

    if (!pCookies)
    {
	hr = HXR_FAILED;
	goto cleanup;
    }

    pCookiesHeader = new CHXHeader();

    if (!pCookiesHeader)
    {
	hr = HXR_FAILED;
	goto cleanup;
    }

    pCookiesHeader->AddRef();

    set_cookie_header = (char*)pCookies->GetBuffer();
    	
    // terminate at any carriage return or linefeed
    for(ptr = set_cookie_header; *ptr; ptr++)
    {
	if(*ptr == LF || *ptr == CR) 
	{
	    *ptr = '\0';
	    break;
	}
    }

    // parse path and expires attributes from header if
    // present
    semi_colon = strchr(set_cookie_header, ';');

    if(semi_colon)
    {
	// truncate at semi-colon and advance 	 
	*semi_colon++ = '\0';

	// look for the path attribute	 
	ptr = StrStrCaseInsensitive(semi_colon, "path=");

	if(ptr) 
	{	    	    
	    // allocate more than we need
	    ::StrAllocCopy(path_from_header, ::StripLine(ptr+5));

	    // terminate at first space or semi-colon	     
	    for(ptr = path_from_header; *ptr != '\0'; ptr++)
	    {
		if(IS_SPACE(*ptr) || *ptr == ';' || *ptr == ',') 
		{
		    *ptr = '\0';
		    break;
		}
	    }
	    
	    hr = ::SaveStringToHeader(pCookiesHeader, "path", path_from_header);
	    if (HXR_OK != hr)
	    {
		goto cleanup;
	    }	  
    	}

	// look for a domain attribute
        ptr = StrStrCaseInsensitive(semi_colon, "domain=");

        if(ptr) 
	{
	    // allocate more than we need
	    ::StrAllocCopy(domain_from_header, ::StripLine(ptr+7));

            // terminate at first space or semi-colon
            for(ptr = domain_from_header; *ptr != '\0'; ptr++)
	    {
                if(IS_SPACE(*ptr) || *ptr == ';' || *ptr == ',') 
		{
                    *ptr = '\0';
                    break;
		}
	    }

	    hr = ::SaveStringToHeader(pCookiesHeader, "domain", domain_from_header);
	    if (HXR_OK != hr)
	    {
		goto cleanup;
	    }	  
	}

	// now search for the expires header 
	// NOTE: that this part of the parsing
	// destroys the original part of the string
	ptr = StrStrCaseInsensitive(semi_colon, "expires=");

	if(ptr) 
	{
	    date = ptr+8;

	    // terminate the string at the next semi-colon
	    for(ptr = date; *ptr != '\0'; ptr++)
	    {
		if(*ptr == ';') 
		{
		    *ptr = '\0';
		    break;
		}
	    }

	    hr = ::SaveStringToHeader(pCookiesHeader, "expires", date);
	    if (HXR_OK != hr)
	    {
		goto cleanup;
	    }	  
	}
    }
    
    // keep cookies under the max bytes limit
    if(strlen(set_cookie_header) > MAX_BYTES_PER_COOKIE)
    {
	set_cookie_header[MAX_BYTES_PER_COOKIE-1] = '\0';
    }

    // separate the name from the cookie
    equal = strchr(set_cookie_header, '=');

    if(equal) 
    {
	*equal = '\0';
	::StrAllocCopy(name_from_header, ::StripLine(set_cookie_header));
	::StrAllocCopy(cookie_from_header, ::StripLine(equal+1));
    } 
    else 
    {
	::StrAllocCopy(name_from_header, "");
	::StrAllocCopy(cookie_from_header, ::StripLine(set_cookie_header));  
    }

    hr = ::SaveStringToHeader(pCookiesHeader, "name", name_from_header);
    if (HXR_OK != hr)
    {
	goto cleanup;
    }	  

    hr = ::SaveStringToHeader(pCookiesHeader, "value", cookie_from_header);
    if (HXR_OK != hr)
    {
	goto cleanup;
    }	  

cleanup:

    if (HXR_OK != hr)
    {
	HX_RELEASE(pCookiesHeader);
    }

    HX_VECTOR_DELETE(path_from_header);
    HX_VECTOR_DELETE(domain_from_header);
    HX_VECTOR_DELETE(name_from_header);
    HX_VECTOR_DELETE(cookie_from_header);

    return hr;
}

STDMETHODIMP
HXCookiesHelper::UnPack(IHXValues*	    pCookiesHeader,
			 REF(IHXBuffer*)   pCookies)
{
    HX_RESULT	hr = HXR_OK;
    const char*	pPropName=NULL;
    CHXString*	pCookiesValue = NULL;
    IHXBuffer* pBuffer=NULL;

    if (!pCookiesHeader)
    {
	hr = HXR_FAILED;
	goto cleanup;
    }

    if (!(pCookiesValue = new CHXString()))
    {
	hr = HXR_OUTOFMEMORY;
	goto cleanup;
    }

    if (HXR_OK == pCookiesHeader->GetFirstPropertyBuffer(pPropName, pBuffer) &&
	pPropName && pBuffer)
    {
	*pCookiesValue += pPropName;	
	*pCookiesValue += "=";
	*pCookiesValue += pBuffer->GetBuffer();
    }    
    HX_RELEASE(pBuffer);
        
    while (HXR_OK == pCookiesHeader->GetNextPropertyBuffer(pPropName, pBuffer) &&
	   pPropName && pBuffer)
    {
	*pCookiesValue += "; ";
	*pCookiesValue += pPropName;	
	*pCookiesValue += "=";
	*pCookiesValue += pBuffer->GetBuffer();

	HX_RELEASE(pBuffer);
    }

    if (pCookiesValue && pCookiesValue->GetLength())
    {
	pCookies = new CHXBuffer();
	pCookies->AddRef();

	pCookies->Set((const unsigned char*)(const char*)*(pCookiesValue), pCookiesValue->GetLength() + 1);
    }

cleanup:

    if (HXR_OK != hr)
    {
	HX_RELEASE(pCookies);
    }

    HX_DELETE(pCookiesValue);

    return hr;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -