Ir para conteúdo
Faça parte da equipe! (2024) ×
Conheça nossa Beta Zone! Novas áreas a caminho! ×

Crazy Player-1

Bronze Member
  • Total de Posts

    111
  • Registro em

  • Última visita

  • WCoins

    79

9 Seguidores

  • 3118886
  • nerotlb1
  • JosueChagas
  • uchih4amdara
  • keyrita
  • Devon8762
  • nostart
  • klaudino
  • GameOv3r

Últimos Visitantes

O bloco dos últimos visitantes está desativado e não está sendo visualizado por outros usuários.

Crazy Player-1's Achievements

Dedicado

Dedicado (5/15)

  • Suporte Excelente Rara
  • Notado Rara
  • Usuário Notório Rara
  • Terceirão
  • Senhor do tempo Rara

Emblemas Recentes

490

Reputação

  1. duvido muito que vá te servir para alguma coisa mais o código relevante da api em c#: levando em consideração que o site esta salvando os itens no banco onde o campo Game_Id seria o id da conta do jogador. //Class representação da tabela no banco: public class GameItem : AuditedEntity<int> { public int ItemId { get; set; } public int Game_Id { get; set; } [Range(0, 255)] public int EF1 { get; set; } [Range(0, 255)] public int EFV1 { get; set; } [Range(0, 255)] public int EF2 { get; set; } [Range(0, 255)] public int EFV2 { get; set; } [Range(0, 255)] public int EF3 { get; set; } [Range(0, 255)] public int EFV3 { get; set; } public int Status { get; set; } public DateTime Created_At { get; set; } public GameItem() { Status = 0; Created_At = DateTime.Now; } } //metodo para gerar o import text private async Task<bool> SaveFileAsync(ImportAccountGame import) { //o vem de um config json que configura o diretório do importItem da db _importItem = configuration.GetSection("ImportGame:ImportItem").Value; int currentTimestamp = (int)DateTimeOffset.UtcNow.ToUnixTimeSeconds(); var filePath = Path.Combine(_importItem, import.Name + currentTimestamp + ".txt"); if (File.Exists(filePath)) { return false; // O arquivo já existe, não substitua. } using (var stream = new StreamWriter(filePath, false)) { await stream.WriteAsync($"{import.Name} {import.GameItem.ItemId} " + $"{import.GameItem.EF1} {import.GameItem.EFV1} " + $"{import.GameItem.EF2} {import.GameItem.EFV2} " + $"{import.GameItem.EF3} {import.GameItem.EFV3} "); } return true; } //metodo job que verifica se tem item pendete de entrega, sendo status 0 pendente e 1 entregue public async Task<List<ResponseTaskJob>> ExportItem() { var response = new List<ResponseTaskJob>(); string status = string.Empty; string description = string.Empty; var gameitems = await _context.GameItems .Where(d => d.Status == 0) .ToListAsync(); foreach (var item in gameitems) { var name = GetGameAccountName(item.Game_Id); if (string.IsNullOrEmpty(name)) continue; var importItem = new ImportAccountGame { Name = name, GameItem = new GameItem { ItemId = item.ItemId, EF1 = item.EF1, EF2 = item.EF2, EF3 = item.EF3, EFV1 = item.EFV1, EFV2 = item.EFV2, EFV3 = item.EFV3, } }; { var isSave = await SaveFileAsync(importItem); if (isSave) { item.Status = 1; status = "Success"; description = $"Item[Id:{item.ItemId} ef1:{item.EF1} efv1:{item.EFV1} ef2:{item.EF2} efv2:{item.EFV2} " + $"ef3:{item.EF3} efv3:{item.EFV3}, importado para a conta[{name}]"; } else { status = "Error"; description = $"Item[Id:{item.ItemId} ef1:{item.EF1} efv1:{item.EFV1} ef2:{item.EF2} efv2:{item.EFV2} " + $"ef3:{item.EF3} efv3:{item.EFV3}, não importado para a conta[{name}]"; } } _context.GameItems.Update(item); await _context.SaveChangesAsync(); response.Add(new ResponseTaskJob { Status = status, Name = "ExportItemJob", Description = description, }); } return response; }
  2. eu fiz algo similar no meu site, voce pode cadastrar um pacote de itens, mais quando a api vai enviar para o import, gera um import para cada item.
  3. Acho que quem te passou a ideia do bau, deveria estar falando de um item customizado na src na qual voce pode configurar quais itens ele entrega ao abrir o bau, tem algumas srcs postada com sistemas similares, então em vez de tu enviar os itens no import voce envia o bau que quando jogador abrir no jogo vai entregar os itens configurados. porem surgi uma pequena dúvida, porque voce não poderia enviar em 2 imports separados?
  4. pse, até "asiático" já entrou em contato querendo conteúdo de wyd, parece até que o wyd é br, sobre como eu consegui baixar, eu tenho uma conta que já deve ter uns 10 anos, os foruns que eu frequentava atrás de conteúdo geralmente disponibilizavam conteudo la, como o link é tenebroso, net de 600 M, levou quase 5 horas pra baixar esse zip pequeno.
  5. Para baixar voce precisa ter uma conta, e ter o app, se não me engano hj em dia é complicado criar uma conta la porque pede validação por celular ou algo do tipo, baixei o segundo link pra tu, dei uma olhada superficial e me parece que esses dados são de origem br. Link Mega
  6. link atualizado, guardem ou re-upem o link pois sempre que meu mega fica cheio eu limpo qualquer coisa nele que eu não esteja mais usando
  7. Posso está bêbado, mais existem varias variantes na sua questão. então vamos tentar resumir. Essa é a source do client, se tu não pegar um projeto inteiro funcional que inclua source de servidor e client que já venha com as suas respectivas releases(arquivos externos necessários para funcionamento). voce provavelmente vai ter que entender bastante sobre o código de ambos, pois pode e vai ter muita estrutura incompatível. sobre comunidade para trocar ideia, não tenho uma para te recomendar, não faço parte de nenhuma. porem se quiser trocar ideia no one to one, pode me achar no telegram @newsgames12
  8. bom dia, são só exemplos, o numero de conexões vc consegue limitar isso no próprio socket, dei duas alternativas a solução manual, eu particularmente não uso a manual, a vps faz esse serviço, só dei um exemplo basico para quem tiver interesse. tmj....
  9. um host com proteção ddos syn, e ou um programa de bloqueio, como o ataque acontece no socket o flood pode acontecer na hora que o socket se conecta, o atacante pode ficar enviando varias aberturas de conexão, oque vai inundar a fila do seu socket fazendo com que novas conexão não sejam estabelecidas e faz com que os jogadores não consigam logar no seu jogo, se você preferir pode implementar algo no accept do socket. Exemplo: defina uma variavel do tipo fd_set e uma array ou vetor de string para armazenar os ips conectados na estrutura do seu servidor de forma que ela seja acessivel no socket exemplo: no meu caso em cServer.h typedef struct MyServer { //socket list fd_set readfds; //ip list std::vector<std::string> IpBlockList; }stServer em cServer.cpp stServer myServer; em Basedef ou no local que tu achar mais adequado crie um método para verificação bool CheckIpSpam(char* ip) { struct sockaddr_in addr {}; int addrlen = sizeof(addr); bool isflood = false; bool ipIsBlock = false; int connectCount = 0; int maxPending = 3; //Iterar pelos soquetes pendentes for (int i = 0; i < sServer.readfds.fd_count; i++) { SOCKET s = sServer.readfds.fd_array[i]; // Obter o endereço IP do soquete getsockname(s, (struct sockaddr*)&addr, &addrlen); // Compare o endereço IP com o que estamos procurando if (addr.sin_addr.s_addr == inet_addr(ip)) { //se a contagem de conexão for maior que o maximo permitido // remove ele da fila e aplica um ip block if (connectCount > maxPending) { FD_CLR(s, &sServer.readfds); Log(SERVER_SIDE, LOG_HACK, "Flood connection. IP: %s", ip); closesocket(s); //verifica se o ip ainda não foi bloqueado if (!ipIsBlock) { // faz o bloqueio BlockIp(ip); ipIsBlock = true; } isflood = true; } else { connectCount++; } } } return isflood; } metodo que faz o bloqueio pode ser adicionado tambem no basedef estamos usando o firewall do windows para efetuar o bloqueio pois seria a unica forma de não receber mais flood desse endereço void BlockIp(char* ip) { HRESULT hr = S_OK; INetFwPolicy2* pNetFwPolicy2 = NULL; INetFwRules* pFwRules = NULL; INetFwRule* pFwRule = NULL; hr = CoInitializeEx(0, COINIT_APARTMENTTHREADED); if (FAILED(hr)) { Log(SERVER_SIDE, LOG_HACK, "CoInitializeEx failed: %lx", hr); return; } // Recupere a política de firewall. hr = CoCreateInstance(__uuidof(NetFwPolicy2), NULL, CLSCTX_INPROC_SERVER, __uuidof(INetFwPolicy2), (void**)&pNetFwPolicy2); if (FAILED(hr)) { Log(SERVER_SIDE, LOG_HACK, "CoCreateInstance for INetFwPolicy2 failed: %lx", hr); CoUninitialize(); return; } // Recupere as regras do firewall. hr = pNetFwPolicy2->get_Rules(&pFwRules); if (FAILED(hr)) { Log(SERVER_SIDE, LOG_HACK, "get_Rules failed: %lx", hr); pNetFwPolicy2->Release(); CoUninitialize(); return; } // Criar uma nova regra de firewall. hr = CoCreateInstance(__uuidof(NetFwRule), NULL, CLSCTX_INPROC_SERVER, __uuidof(INetFwRule), (void**)&pFwRule); if (FAILED(hr)) { Log(SERVER_SIDE, LOG_HACK, "CoCreateInstance for INetFwRule failed: %lx", hr); pFwRules->Release(); pNetFwPolicy2->Release(); CoUninitialize(); return; } // definir as propriedades da regra. BSTR bstrRuleName = _com_util::ConvertStringToBSTR("BlockIP"); BSTR bstrRuleDescription = _com_util::ConvertStringToBSTR("Block IP address"); pFwRule->put_Name(bstrRuleName); pFwRule->put_Description(bstrRuleDescription); pFwRule->put_Protocol(NET_FW_IP_PROTOCOL_ANY); pFwRule->put_Direction(NET_FW_RULE_DIR_IN); pFwRule->put_Action(NET_FW_ACTION_BLOCK); // Converter o endereço IP para BSTR. BSTR bstrIp = _com_util::ConvertStringToBSTR(ip); pFwRule->put_RemoteAddresses(bstrIp); // Adicione a regra à coleção de regras de firewall. hr = pFwRules->Add(pFwRule); if (FAILED(hr)) { Log(SERVER_SIDE, LOG_HACK, "Failed to add firewall rule: %lx", hr); } else { Log(SERVER_SIDE, LOG_HACK, "IP %s blocked.", ip); } // limpar toda essa tranqueira. SysFreeString(bstrRuleName); SysFreeString(bstrRuleDescription); SysFreeString(bstrIp); pFwRule->Release(); pFwRules->Release(); pNetFwPolicy2->Release(); CoUninitialize(); } agora onde esta o accept do seu socket caso não tenha voce adiciona. { SOCKADDR_IN acc_sin{}; int Size = sizeof(acc_sin); int tSock = accept(ListenSocket, (struct sockaddr FAR*) & acc_sin, (int FAR*) & (Size)); //aqui vamos armazenar dados do socket que fez a conexão // bem junto o ip que vai ser a forma que vamos identificar o atacante FD_SET(ListenSocket, &sServer.readfds); //armazena o ip na estrutura do socket do server snprintf(Socket.IP, 16, "%s", inet_ntoa(acc_sin.sin_addr)); if(CheckIpSpam(inet_ntoa(acc_sin.sin_addr))){ Log("IP %s tentou se conectar ao servidor, mas esta na lista de ip's bloqueados.", Socket.IP); } } o std::vector<std::string> IpBlockList; seria para tu armazenar os ips bloqueados para vc salvar em algum lugar para seu controle de ips bloqueados, e até mesmo para desboquer ips. Atenção: isso é um exemplo de como voce poderia fazer manualmente, não é para copiar e colar no seu servidor achando que vai funcionar. a ideia aqui é capturar as conexões por ip, definir um limite de conexões pendentes por ip, cuidado que um limite baixo voce pode pegar jogadores que não estejam atacando, por isso repito isso é um exemplo para talvez te dar uma ideia. talvez seu exe precise de permissão de admin para conseguir executar a rotina de bloqueio no firewall voce vai precisar da lib netfw
  10. Obrigado pela sugestão, por vários motivos eu particularmente não gosto da ideia de ter tudo junto principalmente tudo na unity que foi projetada para ser um motor gráfico, um dos motivos seria ter o código do servidor junto do client. Acho interessante o conceito de kcp mais ainda me sinto mais seguro com o TCP, por isso uso uma versão customizada do Telepathy que foi projetada para o fim que eu realmente preciso e foi criada pelo próprio MirrorNetwork.
  11. Talvez não tenha ajudado da forma que você esperava, mais de certa forma ajudou a ter interesse pela engine, na época baixei analisei e dei uma estudada no projeto e na engine, a alguns meses atrás resolvi iniciar um projeto usando a engine. nesse caso obrigado pelo conteúdo postado que serviu como estudo.
  12. acho bem ousado vir com 4 reinos em tempos que wyd private "geralmente" não passa de 2 guilds, espero que que dê bom.... boa sorte!!
  13. verifica se só acontece quando tem bm com evocação por perto, se for vc já tem uma dica de onde começar a procurar o problema.
  14. Eu Tenho, mais não é barato, entra em contato no pm qualquer coisa.
  15. Boa noite, segue repositório github, com uma src 762 com algumas modificações (base w2pp) Obs: recomendo apenas para retirar conteúdo/ideias que achem interessante. [Hidden Content] Release Base: Server-Eternal
×
×
  • Criar Novo...

Informação Importante

Nós fazemos uso de cookies no seu dispositivo para ajudar a tornar este site melhor. Você pode ajustar suas configurações de cookies , caso contrário, vamos supor que você está bem para continuar.