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

📄 cstring.h.svn-base

📁 很有名的一款用于组织DDoS的恶意机器人程序。仅供研究学习
💻 SVN-BASE
字号:
/*	Agobot3 - a modular IRC bot for Win32 / Linux
	Copyright (C) 2003 Ago

	This program is free software; you can redistribute it and/or
	modify it under the terms of the GNU General Public License
	as published by the Free Software Foundation; either version 2
	of the License, or (at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU General Public License for more details.

	You should have received a copy of the GNU General Public License
	along with this program; if not, write to the Free Software
	Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */

#ifndef __CSTRING_H__
#define __CSTRING_H__

/*
	from sapphire.h -- Interface for the Saphire II stream cipher.

	Dedicated to the Public Domain the author and inventor
	(Michael Paul Johnson).  This code comes with no warranty.
	Use it at your own risk.
*/

class CSapphire {
public:
	CSapphire(unsigned char *key=NULL,			// Calls initialize if a real
        unsigned char keysize=0);				// key is provided.  If none
												// is provided, call initialize
												// before encrypt or decrypt.
    ~CSapphire();								// Destroy cipher state information.

    void initialize(unsigned char *key,			// User key is used to set
		unsigned char keysize);					// up state information.
    void hash_init(void);						// Set up default hash.
    
	unsigned char encrypt(unsigned char b=0);	// Encrypt byte
												// or get a random byte.
    unsigned char decrypt(unsigned char b);		// Decrypt byte.

	void hash_final(unsigned char *hash,		// Copy hash value to hash
		unsigned char hashlength=20);			// Hash length (16-32)
    void burn(void);							// Destroy cipher state information.

private:
	unsigned char cards[256];					// A permutation of 0-255.
	unsigned char rotor,						// Index that rotates smoothly
		ratchet,								// Index that moves erratically
        avalanche,								// Index heavily data dependent
        last_plain,								// Last plain text byte
        last_cipher;							// Last cipher text byte
	
	unsigned char keyrand(int limit, unsigned char *user_key,
		unsigned char keysize, unsigned char *rsum, unsigned *keypos);
};

class CString
{
public:
			 CString();
			 CString(const char *szString);
			 CString(const CString &pString);
			 CString(const int iValue);
	virtual	~CString();

	void	 Assign(const char *szString);
	void	 Assign(const CString &pString);
	void	 Assign(const int iValue);

	void	 Append(const char *szString);
	void	 Append(const CString &pString);
	void	 Append(const int iValue);

	int		 Compare(const char *szString) const;
	int		 Compare(const CString &pString) const;

	int		 CompareNoCase(const char *szString) const;
	int		 CompareNoCase(const CString &pString) const;

	CString	 Decrypt() const;
	CString	 Encrypt(const char *szKey) const;

	void	 Empty();

	int		 Find(const char cChar) const;
	int		 Find(const char cChar, int iStart) const;
	int		 Find(const CString &pString) const;
	int		 Find(const CString &pString, int iStart) const;
	int		 Find(const char *szString) const;
	int		 Find(const char *szString, int iStart) const;

	void	 Format(const char *szFormat, ...);

	char	*GetBuffer(int iBufLen);

	int		 GetLength() const;
	int		 GetLength();
	
	CString	 Mid(int iFirst, int iCount) const;
	CString	 Mid(int iFirst) const;

	CString	 Token(int iNum, const char *szDelim, bool bUseQuotes);
	CString	 Token(int iNum, const char *szDelim);

	void operator=(const CString &sStr);
	void operator=(const char *szStr);
	char &operator[](int iPos);
	const char &operator[](int iPos) const;
	operator const char *() const;
	operator char *();

	const char	*CStr() const;
	const char	*CStr();
	char		*Str();

	bool		 m_bIsCryptStr;
	char		*m_szString;
	char		*m_szTemp;
	int			 m_iLength;
	char		 m_szKey[256];
	CSapphire	 m_cSapphire;
};

typedef struct token_data_s {
	unsigned char		 szMD5[16];
	char				*szString;
	char				*szDelim;
	std::vector<char*>	 vTokens;
} token_data;

#endif // __CSTRING_H__

⌨️ 快捷键说明

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