Пример #1
0
 protected static bool verify(TcpInternalSimpleServer.ServerSocket socket, ulong randomPrefix, byte[] md5Data, ref long ticks)
 {
     TcpServer.ServerBase server = socket.Server;
     if (server.CheckVerifyString())
     {
         return(true);
     }
     if (md5Data != null && md5Data.Length == 16)
     {
         if (!timeVerifyTick.Check(ref ticks, ref socket.TimeVerifyTicks))
         {
             return(false);
         }
         TcpServer.ServerBaseAttribute attribute = server.Attribute;
         if (md5 == null)
         {
             md5 = new MD5CryptoServiceProvider();
         }
         if (TcpServer.TimeVerifyServer.IsMd5(TcpServer.TimeVerifyServer.Md5(md5, attribute.VerifyString, randomPrefix, ticks), md5Data) == 0)
         {
             timeVerifyTick.Set(ticks);
             if (attribute.IsMarkData)
             {
                 socket.MarkData = server.ServerAttribute.VerifyHashCode ^ randomPrefix;
             }
             return(true);
         }
     }
     ticks = 0;
     return(false);
 }
Пример #2
0
 protected static bool verify(TcpInternalServer.ServerSocketSender sender, string userID, ulong randomPrefix, byte[] md5Data, ref long ticks)
 {
     TcpServer.ServerBase server = sender.Server;
     return(server.CheckVerifyString() || verify(sender, randomPrefix, server.Attribute.VerifyString, md5Data, ref ticks));
 }