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

📄 base64.cpp

📁 该段源码是用VC实现了BASE64算法
💻 CPP
字号:
// Base64.cpp: 实现CBase64类.
//
#include "stdafx.h"
#include "Base64.h"

// 静态成员初始化,7-bit 字母表.
CString CBase64::m_sBase64Alphabet = 
_T( "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" );

//---------------------------------------------------------------------------
CBase64::CBase64()
{
}

//---------------------------------------------------------------------------
CBase64::~CBase64()
{
}

//---------------------------------------------------------------------------
CString CBase64::Encode(LPCTSTR szEncoding,int nSize)
{
	CString sOutput = _T( "" );
	int nNumBits;
	UINT nDigit;
	int lp = 0;

	if( szEncoding == NULL )
		return sOutput;

	m_szInput = szEncoding;
	m_nInputSize = nSize;

	m_nBitsRemaining = 0;
	nDigit = ReadBits(&nNumBits, lp );
	while( nNumBits > 0 )
	{
		sOutput += m_sBase64Alphabet[ (int)nDigit ];
		nDigit = ReadBits(&nNumBits, lp );
	}

	while( sOutput.GetLength() % 4 != 0 )
	{
		sOutput += '=';
	}
	return sOutput;
}

//---------------------------------------------------------------------------
// 输出缓冲区大小不小于 3/4 输入缓冲区大小. 为了简便,它们的大小取为一致.
int CBase64::Decode(LPCTSTR szDecoding, LPTSTR szOutput)
{
    int c, lp =0;
	int nDigit;
    int nDecode[ 256 ];

	ASSERT( szDecoding != NULL );
	ASSERT( szOutput != NULL );
	if( szOutput == NULL )  	
		return 0;
	
	if( szDecoding == NULL )
		return 0;

	CString sInput = szDecoding;
	if( sInput.GetLength() == 0 )
		return 0;

	// 建立解码表.
	for( int i = 0; i < 256; i++ ) 
		nDecode[i] = -2; // 非法数字.
	for( i=0; i < 64; i++ )
	{
		nDecode[ m_sBase64Alphabet[ i ] ] = i;
		nDecode[ m_sBase64Alphabet[ i ] | 0x80 ] = i; // 忽略8th bit.
		nDecode[ '=' ] = -1; 
		nDecode[ '=' | 0x80 ] = -1; 
    }

	// 清除输出缓冲区.
	memset( szOutput, 0, sInput.GetLength() + 1 );

	// 对输入数据进行解码.
	for( lp = 0, i = 0; lp < sInput.GetLength(); lp++ )
	{
		c = sInput[ lp ];
		nDigit = nDecode[ c & 0x7F ];
		if( nDigit < -1 ) 
		{
			return 0;
		} 
		else if( nDigit >= 0 ) 
			WriteBits( nDigit & 0x3F, szOutput, i );
    }	
	return i;
}

//---------------------------------------------------------------------------
UINT CBase64::ReadBits(int * pBitsRead, int& lp)
{
    ULONG lScratch;
    while( ( m_nBitsRemaining < 6 ) && 
		   ( lp < m_nInputSize ) ) 
	{
		int c = m_szInput[ lp++ ];
        m_lBitStorage <<= 8;
        m_lBitStorage |= (c & 0xff);
		m_nBitsRemaining += 8;
    }

    if( m_nBitsRemaining < 6 ) 
	{
		lScratch = m_lBitStorage << ( 6 - m_nBitsRemaining );
		*pBitsRead = m_nBitsRemaining;
		m_nBitsRemaining = 0;
    } 
	else 
	{
		lScratch = m_lBitStorage >> ( m_nBitsRemaining - 6 );
		*pBitsRead = 6;
		m_nBitsRemaining -= 6;
    }

    return (UINT)lScratch & 0x3F;
}

//---------------------------------------------------------------------------
void CBase64::WriteBits(UINT nBits, LPTSTR szOutput, int& i)
{
	UINT nScratch;

	m_lBitStorage = (m_lBitStorage << 6) | nBits;
	m_nBitsRemaining += 6;
	while( m_nBitsRemaining > 7 ) 
	{
		nScratch = m_lBitStorage >> (m_nBitsRemaining - 8);
		szOutput[ i++ ] = nScratch & 0xFF;
		m_nBitsRemaining -= 8;
	}
}

⌨️ 快捷键说明

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