JML

net.sf.jqql.packets
Class BasicOutPacket

java.lang.Object
  extended by net.sf.jqql.packets.Packet
      extended by net.sf.jqql.packets.OutPacket
          extended by net.sf.jqql.packets.BasicOutPacket
Direct Known Subclasses:
AddFriendAuthResponsePacket, AddFriendExPacket, AddFriendPacket, AdvancedSearchUserPacket, AuthorizePacket, BasicDebugPacket, ChangeStatusPacket, ClusterCommandPacket, DeleteFriendPacket, DownloadGroupFriendPacket, FriendDataOpPacket, FriendLevelOpPacket, GetFriendListPacket, GetOnlineOpPacket, GetUserInfoPacket, GroupDataOpPacket, KeepAlivePacket, LoginPacket, LogoutPacket, ModifyInfoPacket, PrivacyDataOpPacket, ReceiveIMReplyPacket, RemoveSelfPacket, RequestKeyPacket, RequestLoginTokenPacket, SearchUserPacket, SendIMPacket, SendSMSPacket, SignatureOpPacket, TempSessionOpPacket, UnknownOutPacket, UploadGroupFriendPacket, UserPropertyOpPacket, WeatherOpPacket

public abstract class BasicOutPacket
extends OutPacket

 output packet base class of basic protocol family
 packet of basic protocol family have format like:
 1. packet header sign, 1 byte, 0x02
 2. client version code, 2 byte
 3. command, 2 byte
 4. packet sequence number, 2 byte
 5. user QQ number, 4 byte
 6. packet body
 7. packet tail sign, 1 byte, 0x03

 Note: 6 part will use session key encrypt.log in packet exception, 6 part will use Cipher Key encrypt. 
 request log in token packet exception, 6 part not need encrypt.

 基本协议族的输出包基类
 基本协议族的包都具有以下的格式:
 1. 包头标志,1字节,0x02
 2. 客户端版本代码,2字节
 3. 命令,2字节
 4. 包序号, 2字节
 5. 用户QQ号,4字节
 6. 包体
 7. 包尾标志,1字节,0x03
 Note: 6部分将用会话密钥加密, 登录包例外,6部分要用密码密钥加密。请求登录令牌包例外,6部分不需加密
 

Author:
notxx, luma

Field Summary
 
Fields inherited from class net.sf.jqql.packets.OutPacket
ack, key, resendCountDown, sendCount, seq, timeout
 
Fields inherited from class net.sf.jqql.packets.Packet
bodyBuf, bodyDecrypted, command, crypter, ds, duplicated, header, log, sequence, source, user
 
Constructor Summary
protected BasicOutPacket(ByteBuffer buf, int length, QQUser user)
           
protected BasicOutPacket(ByteBuffer buf, QQUser user)
           
protected BasicOutPacket(char command, boolean ack, QQUser user)
          create a Specify Parameters packet.
 
Method Summary
protected  byte[] decryptBody(byte[] body, int offset, int length)
          decrypt packet body 解密包体
protected  byte[] encryptBody(byte[] b, int offset, int length)
          encrypt packet body 加密包体
protected  byte[] getBodyBytes(ByteBuffer buf, int length)
          get byte array of packet body 得到包体的字节数组
protected  int getCryptographStart()
           
 int getFamily()
           
protected  int getHeadLength()
           
protected  int getLength(int bodyLength)
          get total length of UDP form packet, rule out TCP form 得到UDP形式包的总长度,不考虑TCP形式
 String getPacketName()
           
protected  int getTailLength()
           
protected  void parseHeader(ByteBuffer buf)
          parse packet header from current position of buf 从buf的当前位置解析包头
protected  void parseTail(ByteBuffer buf)
          parse packet tail from current position of buf 从buf的当前未知解析包尾
protected  void postFill(ByteBuffer buf, int startPos)
          backfill, some field must fill whole packet to make sure its content, for example length field, then this method will be used after tail filling.
protected  void putHead(ByteBuffer buf)
          change packet header to byte stream, and write into appointed ByteBuffer object.
protected  void putTail(ByteBuffer buf)
          change packet tail to byte stream, and write into appointed ByteBuffer object.
 String toString()
           
protected  boolean validateHeader()
          checkout header 校验头部
 
Methods inherited from class net.sf.jqql.packets.OutPacket
dump, fill, getKey, getNextSeq, getSendCount, getTimeout, needAck, needResend, parseBody, setKey, setSendCount, setTimeout
 
Methods inherited from class net.sf.jqql.packets.Packet
equals, getCommand, getHeader, getSequence, getSource, hash, hashCode, isDuplicated, putBody, setDuplicated, setHeader, setSequence
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
 

Constructor Detail

BasicOutPacket

protected BasicOutPacket(char command,
                         boolean ack,
                         QQUser user)
create a Specify Parameters packet. 构造一个参数指定的包.

Parameters:
command - command 命令.
ack - whether need answer 是否需要回应.

BasicOutPacket

protected BasicOutPacket(ByteBuffer buf,
                         QQUser user)
                  throws PacketParseException
Throws:
PacketParseException

BasicOutPacket

protected BasicOutPacket(ByteBuffer buf,
                         int length,
                         QQUser user)
                  throws PacketParseException
Throws:
PacketParseException
Method Detail

validateHeader

protected boolean validateHeader()
Description copied from class: Packet
checkout header 校验头部

Specified by:
validateHeader in class Packet
Returns:
true means header usable true表示头部有效

getBodyBytes

protected byte[] getBodyBytes(ByteBuffer buf,
                              int length)
Description copied from class: Packet
get byte array of packet body 得到包体的字节数组

Specified by:
getBodyBytes in class Packet
Parameters:
buf - ByteBuffer
length - packet total length 包总长度
Returns:
byte array of packet body 包体字节数组

getLength

protected int getLength(int bodyLength)
Description copied from class: Packet
get total length of UDP form packet, rule out TCP form 得到UDP形式包的总长度,不考虑TCP形式

Specified by:
getLength in class Packet
Parameters:
bodyLength - packet body length 包体长度
Returns:
packet length 包长度

parseTail

protected void parseTail(ByteBuffer buf)
                  throws PacketParseException
Description copied from class: Packet
parse packet tail from current position of buf 从buf的当前未知解析包尾

Specified by:
parseTail in class Packet
Parameters:
buf - ByteBuffer
Throws:
PacketParseException - if parse error 如果解析出错

getPacketName

public String getPacketName()
Overrides:
getPacketName in class OutPacket
Returns:
descriptive name of packet 包的描述性名称

decryptBody

protected byte[] decryptBody(byte[] body,
                             int offset,
                             int length)
Description copied from class: Packet
decrypt packet body 解密包体

Specified by:
decryptBody in class Packet
Parameters:
body - byte array of packet body 包体字节数组
offset - offset of packet body begin 包体开始偏移
length - packet length 包体长度
Returns:
解密的包体字节数组 // byte array of decrypted packet body

encryptBody

protected byte[] encryptBody(byte[] b,
                             int offset,
                             int length)
Description copied from class: Packet
encrypt packet body 加密包体

Specified by:
encryptBody in class Packet
Parameters:
b - unencrypt byte array 未加密的字节数组
offset - offset of packet body begin 包体开始的偏移
length - packet body length 包体长度
Returns:
encrypted packet body 加密的包体

putHead

protected void putHead(ByteBuffer buf)
Description copied from class: Packet
change packet header to byte stream, and write into appointed ByteBuffer object. 将包头部转化为字节流, 写入指定的ByteBuffer对象.

Specified by:
putHead in class Packet
Parameters:
buf - ByteBuffer object whicn packet need to write into 写入的ByteBuffer对象.

postFill

protected void postFill(ByteBuffer buf,
                        int startPos)
Description copied from class: OutPacket
backfill, some field must fill whole packet to make sure its content, for example length field, then this method will be used after tail filling. 回填,有些字段必须填完整个包才能确定其内容,比如长度字段,那么这个方法将在 尾部填充之后调用

Specified by:
postFill in class OutPacket
Parameters:
buf - ByteBuffer
startPos - packet initial position 包起始位置

putTail

protected void putTail(ByteBuffer buf)
Description copied from class: Packet
change packet tail to byte stream, and write into appointed ByteBuffer object. 将包尾部转化为字节流, 写入指定的ByteBuffer对象.

Specified by:
putTail in class Packet
Parameters:
buf - ByteBuffer object whicn packet need to write into 写入的ByteBuffer对象.

parseHeader

protected void parseHeader(ByteBuffer buf)
                    throws PacketParseException
Description copied from class: Packet
parse packet header from current position of buf 从buf的当前位置解析包头

Specified by:
parseHeader in class Packet
Parameters:
buf - ByteBuffer
Throws:
PacketParseException - if parse error 如果解析出错

getHeadLength

protected int getHeadLength()
Specified by:
getHeadLength in class Packet
Returns:
packet header length 包头长度

getTailLength

protected int getTailLength()
Specified by:
getTailLength in class Packet
Returns:
packet tail length 包尾长度

toString

public String toString()
Overrides:
toString in class Object

getCryptographStart

protected int getCryptographStart()
Specified by:
getCryptographStart in class Packet
Returns:
start position of cryptograph, relative to the first byte of packet body. if this packet is unknown packet, return -1, this method only available to some protocol family. 密文的起始位置,这个位置是相对于包体的第一个字节来说的,如果这个包是未知包, 返回-1,这个方法只对某些协议族有意义

getFamily

public int getFamily()
Specified by:
getFamily in class Packet
Returns:
sign this packet belong which protocol family 标识这个包属于哪个协议族

JML