SchultzGames
Para tirar dúvidas, crie um tópico especifico na área "Dúvidas em Geral" e aguarde ser respondido. Evite comentar em tópicos não relacionados a sua dúvida :D
TÓPICOS RECENTES:
Tópico:
Postado em:
Postado por:
[TUTORIAL] Controle 3ª pessoa com animações mecânicas (root motion)
Como Configurar a Unity, para que modifique o seu Eixo?
Por que a UI da esse "BUG"?
POSSO PUBLICAR MEUS JOGOS USANDO VERSÃO GRATUITA DESSA ENGINE...
Movimentação com RigidBOdy2D dando travadinhas
Motos Brasil - Jogo de Motos Brasileiras
onde esta o sun shaft na unity 2019?
Retirar Limites Do HINGE JOINT
Volleyguys - jogo de vôlei
Hinge Joint
caixa de som
[TUTORIAL] - 8 Dicas de otimização para mobile (Tópico 2) (Android)
Novo Trailer do jogo 13º Andar
[DUVIDA] UV MAPPING EM VÁRIOS OBJETOS - BLENDER
problemas com movimentação do personagem com root motion
Como fazer o fov reduzir quando a telca não estiver sendo pressionada ?
Loop Event Onclick
[Em Desenvolvimento] Battles of Worlds
[DÚVIDA] Modelo do Sketchup não importa corretamente
Tem como texturizar apenas uma face do cubo no Unity?
[TUTORIAL] Sistema de DIA E NOITE completo, com luzes noturnas e SISTEMA DE NUVENS
Como fazer pro meu tiro matar o inimigo?
[DUVIDA] Perlin Noise 3d?
The freddy krueger's pie (Game)
Como fazer um sistema de conetar objetos 3d ao passar proximo de um Trigger?
Árvores sem billboard
distancia
Porque meu objeto não está sendo ativado? unity 2D
[TUTORIAL] Third Person Shooter
Como ativar som ao passar por cima de um objeto?
[PROJETO] A ULTIMA CASA DA RUA
Meu novo game
[DUVIDA SIMPLES]
Projeto Game de Terror
probleminha ao usar o Platform Effector2d
Criar game multi player unity 3d
[TUTORIAL] Banco de dados || MySQL
Touch para 2 Jogadores
Set Height do terreno
XML, suporte e utilização.
Travar animação
[DIVULGAÇÃO DE AULA] Como criar jogos sem saber programação
[RESOLVIDO] Como fazer o canvas ficar atrás do personagem? Unity 2D
[TUTORIAL] Controlador em Primeira Pessoa "compacto" FPS
Tem como modificar a textura em tempo real?
TEXTO DO BUTTON
ALTERAR A VELOCIDADE APENAS DE UMA ANIMAÇÃO VIA SCRIPT
Valor de App de Realidade Aumentada.
Como Fasso Para O HingeJoint Virar em Duas Direçoes?
Pegar objeto tocado em dispositivo mobile
[TUTORIAL] Criar Analógico Virtual UI Para Mobile.
Arquivos com Casa, arvores, Gramas, Objetos3d Etc...
Unity 2019.1.1 não entra em Modo Play
Fazer personagem descer uma tirolesa
Duvida script de loading com controle
Como implementar Gyroscope no FPSController ?
Bug de Iluminação Unity 2019
Não consigo dar dano nem destruir um objeto
SCRIPT DE MOVIMENTAÇÃO E CÂMERA
[PEDIDO DE TUTORIAL] Schultz fazer uma série *jogo de corrida*
[FAZER TUTORIAL] Como faço para clicar em um objeto e visualizar, girar...
Como finalizar a textura no blender
É possivel detectar colisão de um objeto filho pelo objeto pai?
Como atrasar uma animação Unity 2D
AJUDA COM SCRIPT DE LOAD DE CENA
[RESOLVIDO] Como mudar a cor do Text?
[PEDIDOS DE TUTORIAIS]
saber se os objetos colidiram
navmeshagent Duvida sobre a distancia percorrida
[TUTORIAL] Mover objetos 2D e conectar em lugares específicos
Balão de Conversação
[TUTORIAL] Como usar FREE EASY CRIATURA CONTROLE IA
Vale apena colocar esse Asset na Asset Store?
Como faço para que mostre algo que vai instanciar?
TRANSFORM DA POSIÇÃO NÃO SEGUE A ANIMAÇÃO
[TUTORIAL] Sistema de Lanterna com Pilhas
[TUTORIAL] Sistema simples para VOLTAR NO TEMPO, Unity 3D
UNITY, TRANSFORM.TRANSLATE ATRAVESSA PAREDES
Como Fazer Agregação via script do Unity?
( Ajuda) gráficos longe ruim
Verificar se objeto ja existe em um Lista
Fog of War
Scope Script
Animar um Número de Vezes
AJUDA COM MUDANÇA DE CENA
Porque meu aúdio não funciona na colisao do player com o objeto?
[RESOLVIDO] UNITY OBJETOS COM MESMO SCRIPT DE FORMA INDEPENDENTE
Comunicação entre scripts
[TUTORIAL] Script de pulo para jogos 3D em geral (Unity - C#)
[____TÓPICO LIVRE____] FALE O QUE QUISER (Parte 2)
Esse erro de código é da Unity ou da versão do Script?
Game Take All
PRESSIONAR BOTÃO TOUCH NO ANDROID SERÁ O MESMO QUE PRESSIONAR UMA TECLA DO TECLADO REAL
PROBLEMAS AO DAR BUILD
PRESSIONAR BOTÃO TOUCH NO ANDROID SERÁ O MESMO QUE PRESSIONAR UMA TECLA DO TECLADO FÍSICO
Duvida seleção de personagemsn
Como faço para distanciar um objeto do outro pelo script?
Ajuda com Ragdoll (Ta muito bugado)!!!
AJUDA - TUTORIAL Unity 2017 - Mover e rotacionar para a POSIÇÃO do MOUSE
Ontem à(s) 8:47 pm
Ontem à(s) 6:39 pm
Ontem à(s) 12:25 pm
Ontem à(s) 10:40 am
Ontem à(s) 2:42 am
Ontem à(s) 12:41 am
Ter Maio 21, 2019 9:58 pm
Ter Maio 21, 2019 8:03 pm
Ter Maio 21, 2019 7:38 pm
Ter Maio 21, 2019 7:13 pm
Ter Maio 21, 2019 5:38 pm
Ter Maio 21, 2019 5:22 pm
Ter Maio 21, 2019 4:03 pm
Ter Maio 21, 2019 3:44 pm
Ter Maio 21, 2019 1:21 pm
Ter Maio 21, 2019 10:17 am
Ter Maio 21, 2019 1:13 am
Seg Maio 20, 2019 11:46 pm
Seg Maio 20, 2019 11:27 pm
Seg Maio 20, 2019 9:24 pm
Seg Maio 20, 2019 8:28 pm
Seg Maio 20, 2019 7:44 pm
Seg Maio 20, 2019 7:15 pm
Seg Maio 20, 2019 7:10 pm
Seg Maio 20, 2019 9:59 am
Seg Maio 20, 2019 9:57 am
Seg Maio 20, 2019 9:11 am
Seg Maio 20, 2019 9:04 am
Seg Maio 20, 2019 5:54 am
Dom Maio 19, 2019 10:34 pm
Dom Maio 19, 2019 7:57 pm
Dom Maio 19, 2019 2:51 pm
Sab Maio 18, 2019 10:26 pm
Sab Maio 18, 2019 9:45 pm
Sab Maio 18, 2019 2:27 pm
Sab Maio 18, 2019 1:59 pm
Sex Maio 17, 2019 10:30 am
Qui Maio 16, 2019 8:14 pm
Qui Maio 16, 2019 8:10 pm
Qui Maio 16, 2019 6:46 pm
Qui Maio 16, 2019 5:31 pm
Qui Maio 16, 2019 4:08 pm
Qui Maio 16, 2019 12:14 pm
Qui Maio 16, 2019 9:30 am
Qua Maio 15, 2019 4:13 pm
Qua Maio 15, 2019 3:03 pm
Qua Maio 15, 2019 10:17 am
Qua Maio 15, 2019 12:45 am
Seg Maio 13, 2019 7:34 pm
Seg Maio 13, 2019 3:06 pm
Dom Maio 12, 2019 7:52 pm
Dom Maio 12, 2019 7:13 pm
Dom Maio 12, 2019 1:27 pm
Sab Maio 11, 2019 2:03 pm
Sab Maio 11, 2019 1:12 pm
Sab Maio 11, 2019 12:58 pm
Sab Maio 11, 2019 9:06 am
Sex Maio 10, 2019 6:46 pm
Sex Maio 10, 2019 1:34 pm
Sex Maio 10, 2019 12:39 pm
Sex Maio 10, 2019 9:47 am
Qui Maio 09, 2019 8:18 pm
Qui Maio 09, 2019 7:41 pm
Qui Maio 09, 2019 11:44 am
Qui Maio 09, 2019 10:38 am
Qua Maio 08, 2019 9:49 pm
Qua Maio 08, 2019 1:56 pm
Qua Maio 08, 2019 12:55 pm
Qua Maio 08, 2019 9:33 am
Qua Maio 08, 2019 9:23 am
Qua Maio 08, 2019 8:52 am
Qua Maio 08, 2019 7:24 am
Ter Maio 07, 2019 11:00 pm
Ter Maio 07, 2019 6:46 pm
Ter Maio 07, 2019 5:06 pm
Ter Maio 07, 2019 3:23 pm
Ter Maio 07, 2019 12:50 am
Seg Maio 06, 2019 11:58 pm
Seg Maio 06, 2019 9:27 pm
Seg Maio 06, 2019 2:06 pm
Seg Maio 06, 2019 1:52 pm
Seg Maio 06, 2019 9:43 am
Dom Maio 05, 2019 9:41 pm
Dom Maio 05, 2019 9:00 pm
Dom Maio 05, 2019 7:41 pm
Dom Maio 05, 2019 10:53 am
Sab Maio 04, 2019 4:30 pm
Sab Maio 04, 2019 1:33 pm
Sex Maio 03, 2019 8:41 pm
Sex Maio 03, 2019 4:59 pm
Sex Maio 03, 2019 4:34 pm
Sex Maio 03, 2019 3:40 pm
Sex Maio 03, 2019 4:59 am
Qui Maio 02, 2019 11:23 pm
Qui Maio 02, 2019 8:41 pm
Qui Maio 02, 2019 8:13 pm
Qui Maio 02, 2019 7:23 pm
Qui Maio 02, 2019 6:11 pm
Qui Maio 02, 2019 1:52 pm
dstaroski
glauco
glauco
guimaraf
Nabuco
dkrazor
diegopds
williangamesbr4021
Daniel Pires da Silva
williangamesbr4021
JhoowGamer
marcos4503
hendrick22
osiasbezerra
hendrick22
diegopds
ffabim
dkrazor
gcs13
diegopds
fabricadegame
hendrick22
NKKF
Patrick
diegopds
diegopds
diegopds
diegopds
fabricadegame
diegopds
guimaraf
thales.ulisses
rafaelllsd
thales.ulisses
nando07
artplayer
Khrys
GabriG07
SuperGamer
Tegh
MarcioGSouza
igorsp3
darkrj
gabrieldeelay
glauco
lTHINGl
artplayer
numb123
williangamesbr4021
Marcelo Santos
Édipo
Callyde Jr
ronigleydson
SergioDB
loganout
loganout
MarcosSchultz
NKKF
JohnRambo
JohnRambo
lidog
diegopds
LucasRangel
darkrj
Diego Felix
dkrazor
Gabryellx007
rafaelholanda
UesleiUsl
eljkb
artplayer
kraulim
glauco
NKKF
osiasbezerra
robertodf
guimaraf
ronigleydson
osiasbezerra
deikson
numb123
Valakinhas
NKKF
osiasbezerra
BrazaTattoo
dstaroski
diegodiego01
Callyde Jr
jogador432
glauco
Tegh
Tegh
richardfalcos
BrazaTattoo
richardfalcos
Tonny3DM
NKKF
joveem
daniel123163

[TUTORIAL] Unity + PHP + Mysql (com PDO)

Ir em baixo

TUTORIAL [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por jasondavin em Ter Fev 27, 2018 11:14 am

Olá galera...

Hoje vim postar um tutorial bem direto que várias pessoas tem dúvidas: Como integrar Unity + PHP + Mysql ?
Vou explicar em passos, colocando o trecho de código e dando uma breve resumida da lógica do algoritmo. Também não vou fazer a parte de UI no Unity pois não é o foco.

Tecnologias utilizadas:
- Appserv 8.6.0 (Servidor PHP) ~> Link aqui
- PHP 7.0
- Mysql 5.7

Script do banco de dados Mysql

Código:
CREATE DATABASE minhadb;
USE minhadb;

CREATE TABLE usuarios
(
    _id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
    _username VARCHAR(25) NOT NULL UNIQUE,
    _password VARCHAR(25) NOT NULL
);


Lado servidor PHP


1. Criando arquivo de configuração



Código:
<?php
// Configuracoes mysql
DEFINE("HOST","127.0.0.1");
DEFINE("USER","root");
DEFINE("PASSWORD","teste");
DEFINE("DATABASE","minhadb");
?>


Esse código define constantes contendo o HOST (IP), usuário, senha do banco de dados e a database que será utilizada na conexão Mysql.


2. Criando classe de Conexão PDO com um banco de dados (não necessariamente Mysql, pois estamos tratando de conexão PDO)



Código:
<?php
if(!class_exists("Connector"))
{
   class Connector
   {
      private $con = NULL;

      public function __construct()
      {
         $this->connect();
      }

      protected function connect()
      {
         try {
            $this->con = new PDO("mysql:host=".HOST.";dbname=".DATABASE, USER, PASSWORD);
         }
         catch(PDOException $e)
         {
            die($e->getMessage());
         }
         return $this->con;
      }

      public function execute($sql)
      {
         return $sql->execute();
      }

      public function prepare($stmt)
      {
         return $this->con->prepare($stmt);
      }

      public function fetch($stmt)
      {
         return $stmt->fetch(PDO::FETCH_ASSOC);
      }

      public function numRow($stmt)
      {
         return $stmt->rowCount();
      }

      public function close() {
         try {
            $this->con = NULL;
         }
         catch(PDOException $e) {
            exit($e->getMessage());
         }
      }
   }
}
?>


Essa classe contem os métodos básicos e principais para conexão com um banco de dados e manipulação de instruções sql. Não vou me explicar muito sobre essa classe, mas se quiser dar uma olhada em um projeto de TCC que eu fiz no meu curso ~> FastTCC


3. Criando arquivos de registro e login


login.php
Código:
<?php
// Importando arquivos de configuracao e classe de conexao
require "config.php";
require "Connector.class.php";

$conn = new Connector();

// Declaracao da variavel que ira conter a mensagem de erro
$result = array(
    "error" => true,
    "message" => ""
);

// Verificando se existe variaveis POST
if(isset($_POST["username"], $_POST["password"]))
{
    // Prepara instrucao SQL
    $stmt = $conn->prepare("SELECT * FROM usuarios WHERE _username = ? AND _password = ?");
    // Configura os parametros da instrucao
    $stmt->bindValue(1, $_POST["username"], PDO::PARAM_STR);
    $stmt->bindValue(2, $_POST["password"], PDO::PARAM_STR);

    // Executa instrucao
    if($stmt->execute())
    {
          // Verifica se houve resultados da instrucao
          if($conn->numRow($stmt) > 0)
          {
              // Guarda o resultado
              $row = $conn->fetch($stmt);
              $result["error"] = false;
              $result["message"] = "login successful.";
              $result["_userid"] = (int)$row["_id"];
              $result["_username"] = $row["_username"];
          }
          else {
              $result["message"] = "user incorrect.";
          }
    }
    else {
          $result["message"] = "error in server.";
    }
}
else
{
    $result["message"] = "fill all fields.";
}

// Decodifica a variavel contendo a mensagem de erro para JSON
$result_json = json_encode($result);
// Fecha conexao Mysql
$conn->close();
// Retorna dados para o client
exit($result_json);
?>

register.php
Código:
<?php
require "config.php";
require "Connector.class.php";

$conn = new Connector();

$result = array(
    "error" => true,
    "message" => ""
);

if(isset($_POST["username"], $_POST["password"]))
{
    $stmt = $conn->prepare("INSERT INTO usuarios SET _username = ?, _password = ?");
    /*
    * Tambem podendo ser:
    * "INSERT INTO usuarios (_username,_password) VALUES (?,?)"
    */
    $stmt->bindValue(1, $_POST["username"], PDO::PARAM_STR);
    $stmt->bindValue(2, $_POST["password"], PDO::PARAM_STR);

    if($stmt->execute())
    {
          $result["error"] = false;
          $result["message"] = "registered with success.";
    }
    else {
          $result["message"] = "not registered.";
    }
}
else
{
    $result["message"] = "fill all fields.";
}

$result_json = json_encode($result);
$conn->close();
exit($result_json);
?>

Os dois arquivos são bem parecidos, mudando apenas na instrução SQL e o tratamento das informações. Ambos importam o arquivo de configuração (citado no 1º passo) e a classe de conexão (citado no 2º passo). Verificam se existe as variáveis POST "username" e "password" para a construção da instrução SQL.
A instrução é executada e com as informações retornadas, é criada uma variável contendo o resultado da instrução e logo em seguida, é convertido em JSON e finalmente retornada para o cliente.

Lado cliente C#



Código:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Manager : MonoBehaviour {

    private void Start()
    {
        StartCoroutine("Register");
        StartCoroutine("Login");
    }

    IEnumerator Login()
    {
        // Criando formulario e configurando variaveis de parametro
        WWWForm form = new WWWForm();
        form.AddField("username", "jason"); // Parametro username
        form.AddField("password", "123");  // Parametro password

        // Chamando e enviando variaveis para uma URL
        WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

        yield return www;

        // Verificando se nao houve erro na requisicao
        if(www.error == null)
        {
            // Cria um objeto do tipo Message contendo a resposta da requisicao
            Message jsonReturn = Message.decodify(www.text);
            // Mostra a mensagem de retorno
            Debug.Log(jsonReturn.message);
        }
    }

    IEnumerator Register()
    {
        WWWForm form = new WWWForm();
        form.AddField("username", "jason");
        form.AddField("password", "123");

        WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

        yield return www;

        if (www.error == null)
        {
            Message jsonReturn = Message.decodify(www.text);
            Debug.Log(jsonReturn.message);
        }
    }
}

// Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
[System.Serializable]
public class Message
{
    public string message;
    public bool error;
    public int _userid;
    public string _username;

    public static Message decodify(string _text)
    {
        return JsonUtility.FromJson<Message>(_text);
    }
}



Esse arquivo C# possui duas Coroutines e uma classe serializada.

Classe Message


Essa classe é criada com objetivo de converter o retorno do PHP (que é uma string no formato JSON) para um objeto em PHP.
Obs: os atributos criados nesta classe deve conter exatamente o mesmo nome das propriedades criada no PHP.

Coroutine Login & Register


Cria um WWWForm contendo os parâmetros username e password que são utilizados para fazer a instrução SQL no arquivo PHP. Tal formulário é enviado como parâmetro na chamada da URL pelo objeto WWW.
Depois de instanciado, é feito uma verificação se não houve erro na requisição. Caso não houver, é criado um objeto do tipo Message que converte as informações retornadas do PHP para um objeto em C#.

Ponto importante:

Caso você queira acessar um banco de dados externo, você deverá mudar apenas na URL passada na instância do Objeto WWW. Por exemplo:
Código:
WWW www = new WWW("http://seusite.com/sua_pasta/arquivo.php", form);


Caso este tutorial não foi claro o bastante (pois não sou bom em explicar) poste sua dúvida que tentarei responde-la.
jasondavin
jasondavin
MembroAvançado

Masculino PONTOS : 672
REPUTAÇÃO : 16
Idade : 19
Áreas de atuação : Programação Web
GitHub : www.github.com/jasondavindev
Projeto: www.teamdev.pe.hu
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário http://jasondavin.xyz

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por fabriciorsz34 em Ter Fev 27, 2018 12:33 pm

Wow
fabriciorsz34
fabriciorsz34
Programador

PONTOS : 1327
REPUTAÇÃO : 24
Idade : 19
Áreas de atuação : C#,unity,cinema 4D, SketchUp

Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Dom3000 em Ter Fev 27, 2018 2:59 pm

muito bom parabens  Laughing
Dom3000
Dom3000
Programador

Masculino PONTOS : 2540
REPUTAÇÃO : 228
Idade : 23
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Page: https://www.facebook.com/BatlesofWorlds/

Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário https://www.instagram.com/battlesofworlds/?hl=pt-br

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Cezar2016 em Ter Fev 27, 2018 5:40 pm

Parabéns pelo tutorial.

Cezar2016
Avançado
Avançado

Masculino PONTOS : 1093
REPUTAÇÃO : 26
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Dom3000 em Qua Fev 28, 2018 9:33 am

tenho uma duvida tipo eu tenho um game quase pronto, mas é single uso C# normal, para eu fazer ele ser multiplayer vou ter que mudar os scripts dele?
Dom3000
Dom3000
Programador

Masculino PONTOS : 2540
REPUTAÇÃO : 228
Idade : 23
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Page: https://www.facebook.com/BatlesofWorlds/

Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário https://www.instagram.com/battlesofworlds/?hl=pt-br

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por NKKF em Qua Fev 28, 2018 2:10 pm

Sim, com certeza você terá que mudar muita coisa. Caso contrário, poderá ter problemas. Lembre-se de sempre fazer um BKUP do jogo singleplayer e do progresso dele.  :D
NKKF
NKKF
ProgramadorMaster

Masculino PONTOS : 2421
REPUTAÇÃO : 462
Idade : 14
Áreas de atuação : Error 404 Not Found.
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) Aad8pUi

Ver perfil do usuário http://www.projetounity.esy.es

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Andeton em Ter Mar 27, 2018 7:13 am

bom tutorial, fiz algo assim há alguns meses mais em vez de usar PDO usei mysqli, e em vez de json usei xml

Andeton
Iniciante
Iniciante

PONTOS : 822
REPUTAÇÃO : 4
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por amchacon em Ter Mar 27, 2018 9:02 pm

Muito bom. Eu mudaria apenas poucas coisas.

O campo password no banco, colocaria VARCHAR(255)
_password VARCHAR(255) NOT NULL
E adicionaria o campo '_status' como tinyint(1) para podermos rapidamente desativar um usuáro para que não possa mais logar.


E, no C#, antes de adicionar a senha no WWWForm, converteria para MD5. Assim, a senha já vai mais segura no pacote do POST.

amchacon
Iniciante
Iniciante

PONTOS : 1151
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Sab Maio 19, 2018 8:54 pm

Estou na duvida para configurar os  input fields.
Alguém pra explicar.

Yan
Iniciante
Iniciante

PONTOS : 942
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Dom Maio 20, 2018 8:58 am

Se voce for usar input fields ele fica assim
Código:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Manager : MonoBehaviour {
 
    public InputField InputUsername;//Adicione o input
    public InputField InputPassword;//Adicione o input
 

    private void Start()
    {
        StartCoroutine("Register");
        StartCoroutine("Login");
    }

    IEnumerator Login()
    {
        // Criando formulario e configurando variaveis de parametro
        WWWForm form = new WWWForm();
        form.AddField("username", InputUsername.text); // Parametro username
        form.AddField("password", InputPassword.text);   // Parametro password

        // Chamando e enviando variaveis para uma URL
        WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

        yield return www;

        // Verificando se nao houve erro na requisicao
        if(www.error == null)
        {
            // Cria um objeto do tipo Message contendo a resposta da requisicao
            Message jsonReturn = Message.decodify(www.text);
            // Mostra a mensagem de retorno
            Debug.Log(jsonReturn.message);
        }
    }

    IEnumerator Register()
    {
        WWWForm form = new WWWForm();
        form.AddField("username", InputUsername.text);
        form.AddField("password", InputPassword.text);

        WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

        yield return www;

        if (www.error == null)
        {
            Message jsonReturn = Message.decodify(www.text);
            Debug.Log(jsonReturn.message);
        }
    }
}

// Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
[System.Serializable]
public class Message
{
    public string message;
    public bool error;
    public int _userid;
    public string _username;

    public static Message decodify(string _text)
    {
        return JsonUtility.FromJson<Message>(_text);
    }
}
Callyde Jr
Callyde Jr
Programador

Masculino PONTOS : 2976
REPUTAÇÃO : 394
Idade : 40
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Dom Maio 20, 2018 3:36 pm

Ainda não foi muito claro.
Sou iniciante.
Não sei como dizer para apertar no botão e logar só se as informações estiverem corretas.
O mesmo para o botão registrar.
Facilitaria usando o OnClick.

Yan
Iniciante
Iniciante

PONTOS : 942
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Dom Maio 20, 2018 6:53 pm

Bom ele colocou tudo no start
Bom eu fiz umas alteraçoes no script mais acho que fica mais facil de enteder
Código:
using System.Collections;
    using System.Collections.Generic;
    using UnityEngine;
    using UnityEngine.UI;

    public class Manager : MonoBehaviour {
   
        public InputField InputUsername;//Adicione o input
        public InputField InputPassword;//Adicione o input
        public Text textoRetorno = null;//UI textpara aparecer o retorno
        public GameObject canvasLogin,canvasRegister;//Os canvas para separar
      
        private void Start()
        {
            canvasLogin.SetActive(true);
            canvasRegister.SetActive(false);
        }
      
      public void Register()//ir para canvas registro
        {
            canvasRegister.SetActive(true);
            canvasLogin.SetActive(false);
      }
      public void ReturnToLogin()//ir para canvas login
        {
            canvasLogin.SetActive(true);
            canvasRegister.SetActive(false);
      }
      
      public void LogarUsuario(){//Funçao para fazer login
       if(InputUsername.text == "" || InputPassword.text == ""){//Para nao cadrastar usuariosvazios
      textoRetorno.text = "Nao pode existir campo vasios";
      print("Nao pode existir campo vasios");
      return;
   }   
    StartCoroutine("Login");
   }
   public void registrarNovoUsuario()//Funçao para cadrato
    {
        if(InputUsername.text == "" || InputPassword.text == "")
        {
            textoRetorno.text = "Prencha todos os campos!";
            print("Prencha todos os campos!");
            return;
        }
        StartCoroutine("Register");
    }   
      

        IEnumerator Login()
        {
            // Criando formulario e configurando variaveis de parametro
            WWWForm form = new WWWForm();
            form.AddField("username", InputUsername.text); // Parametro username
            form.AddField("password", InputPassword.text);  // Parametro password

            // Chamando e enviando variaveis para uma URL
            WWW www = new WWW("http://127.0.0.1/tutorial/login.php", form);

            yield return www;

            // Verificando se nao houve erro na requisicao
            if(www.error == null)
            {
                // Cria um objeto do tipo Message contendo a resposta da requisicao
                Message jsonReturn = Message.decodify(www.text);
                // Mostra a mensagem de retorno
                Debug.Log(jsonReturn.message);
            }
        }

        IEnumerator Register()
        {
            WWWForm form = new WWWForm();
            form.AddField("username", InputUsername.text);
            form.AddField("password", InputPassword.text);

            WWW www = new WWW("http://127.0.0.1/tutorial/register.php", form);

            yield return www;

            if (www.error == null)
            {
                Message jsonReturn = Message.decodify(www.text);
                Debug.Log(jsonReturn.message);
            }
        }
    }

    // Classe criada para converter a resposta da requisicao (string / JSON) em um objeto em C#
    [System.Serializable]
    public class Message
    {
        public string message;
        public bool error;
        public int _userid;
        public string _username;

        public static Message decodify(string _text)
        {
            return JsonUtility.FromJson<Message>(_text);
        }
    }
Callyde Jr
Callyde Jr
Programador

Masculino PONTOS : 2976
REPUTAÇÃO : 394
Idade : 40
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Yan em Seg Maio 21, 2018 4:55 pm

Exelente estou conseguindo conectar ao banco de dado efetuando registro e fazendo login.
Porém... Tentei fazer com que quando aperto para logar vá para a outra cena e não consegui.
Utilizei algo como.
Código:
IEnumerator CarregarCena () {
      yield return new WaitForSeconds (3);
      Application.LoadLevel ("Nome da cena");
   }


mas quando colocava o
StartCoroutine (CarregaScene());
no
IEnumerator Login()
passava sem precisar de senha.
Como disse sou iniciante, script não é muito comigo, mas eu tento. É muita coisa de uma vez, fazer modelos, texturas, animações, scripts... Desculpa o incomodo. E muito obrigado por me ajudar. Olhando aprendi métodos.

Yan
Iniciante
Iniciante

PONTOS : 942
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Seg Maio 21, 2018 6:51 pm

Use
Código:
using UnityEngine.SceneManagement;

SceneManager.LoadScene ("Login");//Para chamar a scene
Callyde Jr
Callyde Jr
Programador

Masculino PONTOS : 2976
REPUTAÇÃO : 394
Idade : 40
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

TUTORIAL Re: [TUTORIAL] Unity + PHP + Mysql (com PDO)

Mensagem por Callyde Jr em Ter Maio 22, 2018 5:56 am

Para verificar o retorno e aplicar a passagem de scene voce tem que ver o retorno do PHP Veja no exemplo abaixo.
Código:
if( mensage == "registered with success" ){
      
      yield return new WaitForSeconds (5);
              SceneManager.LoadScene ("Login");
Callyde Jr
Callyde Jr
Programador

Masculino PONTOS : 2976
REPUTAÇÃO : 394
Idade : 40
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

Ver perfil do usuário http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

Voltar ao Topo

- Tópicos similares

 
Permissão deste fórum:
Você não pode responder aos tópicos neste fórum