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:
Duvida com animação
[TUTORIAL] Criar jogo Colors/Genius com C#
Utilizar o mesmo botão para duas ações. (if e else)
[____ADMINISTRAÇÃO____] PRECISO DE AJUDA [DICA PARA SER AJUDADO]
[____APOIE O FÓRUM E O CANAL E GANHE RECOMPENSAS____]
Ajuda com AI Inimigo.
[Script] Mudar a orientação em runtime
Como mover dois objetos juntos.
[TUTORIAL] Third Person Shooter
[PEDIDOS DE TUTORIAIS]
Google Play Games
Como fazer um jogo nesse estilo?
Como apagar Proceduram material da pista, quando for recarregar a cena?
PROBLEMA NULL REFERENCE EXCEPTION
Calculo de previsão de coordenada
[____TÓPICO LIVRE____] FALE O QUE QUISER (Parte 2)
Unity - Rodar 2 cenas ao mesmo tempo
Sons na Unity 2017
| AJUDA DISCORD | Descubra aqui como fazer para o link do seu servidor nunca expirar.
Servidores sem limite por usuário.
Trigger detectando apenas o character controller
seguir 2 objetos com a mesma tag
Zezin Na Copa da Russia Realidade Aumentada
[PROJETO MOBILE] Defeat the Illuminatis
DISCORD
Novo jogo - Astero - PlayStore
Variável receber valor de uma array
erro no script
[RESOLVIDO] Bug de wallpaper preto no windows.
[TUTORIAL] Movimento de camera em primeira pessoa e sons de passos ou HeadBob
Tomar dano do inimigo e causar dano no mesmo
[RESOLVIDO] Texto se encaixar dentro de uma imagem.
[Projeto] Line Battle
Jogo Maria Bella
Spawner de Inimigo n preenche todas as posições
[TUTORIAL] AI Enemy ( Jogos de terror )
Como corrigir o box collider do unity?
SPAWN Baseado na Posição (UNITY)
[RESOLVIDO] Problema em um script
Unity - executável não roda banco de dados
Como criar um sistema de Ranking simples.
Animação Humanoid
Blender - Erro ao aplicar influência automática nos ossos de personagem
Objetos duplicados ao instanciar
Duvida com collider
[RESOLVIDO] Problemas com API
Pegar e Jogar armas no chão (estilo CS 1.6)
[RESOLVIDO] Projeteis Online
[TUTORIAL] Zone Wall - ESTILO BATTLE ROYALE
| DÚVIDA | - Como aprender C#?
Como criar um ranking online na Unity usando a PlayFab e o Facebook?
Dúvida sobre método de acesso as variáveis
checkpoint
Como faço para otimizar meu projeto da Unity 3D?
[RESOLVIDO] Alguém me explica isso? (Animator script)
[RESOLVIDO] Duvida com GameManager
duvidas com marcas reais em jogos
Objeto na UI
Minimap/Radar/GPS Estilo GTA V
Problemas com a câmera
PROBLEMAS COM O NAVIGATION
[TUTORIAL] Serialização - JSON
Textura de luzes rosa
Banco de dados android
Girar arma
Qual o melhor meio de iluminar essa scene?
[Jogo] Flap OCO (Android & PC)
[TUTORIAL] Android - Sistema de controle third person shooter, Joystick + Swipe camera
ANIMAÇÃO INIMIGO AI
[RESOLVIDO] Menu Pause Dúvida
Unity 5: Object reference not set to an instance of an object
Como saber se o controle foi conectado?
[ENQUETE OFICIAL] Você está vendo o CHAT DO FÓRUM?????
Onde posso aprender a fazer uma IA estilo a do jogo de tabuleiro Zombicide?
[RESOLVIDO] Erro -> Android SDK is missing required API level 23
Sprites com mesmas cores.
[Formação de Equipe] Battles of Worlds
Como fazer para sair do jogo apertando uma tecla?
VAGA MODELADOR
[Em Desenvolvimento] Battles of Worlds
[RESOLVIDO]Colocar dois fundos diferentes em um mesmo canvas dependendo do menu carregado.
[TUTORIAL] 42 ÓTIMAS DICAS DE OTIMIZAÇÃO PARA JOGOS MOBILE (Android)
[____REGRAS DO FÓRUM____]
SetPartner
Como eu posso criar uma rede social semelhante ao NEAKI?
Como colocar dois backgrounds diferentes para dois canvas diferentes?
Botões Android
[TUTORIAL] MENU PRINCIPAL - UNITY 5 (5.3 ou superior) (Com UI)
problema com Script
Efeitos de particulas
Duvidas/ideias sobre o forum
[RESOLVIDO] Camera e posição do sprite animator
VAGA EM EQUIPE PARA APREDIZAGEM
Como criar sombra em objeto transparente?
Modificação de scripts em cenas diferentes
The Angels of Tomorrow - Projeto no qual estou trabalhando
[RESOLVIDO] Como uso esse script
MODELAGEM 3D PARA PERSONAGEM.
Vale a pena atualizar o Unity?
Hoje à(s) 9:46 pm
Hoje à(s) 7:35 pm
Hoje à(s) 7:29 pm
Hoje à(s) 6:46 pm
Hoje à(s) 6:45 pm
Hoje à(s) 6:43 pm
Hoje à(s) 6:38 pm
Hoje à(s) 4:36 pm
Hoje à(s) 3:42 pm
Hoje à(s) 3:33 pm
Hoje à(s) 1:26 pm
Hoje à(s) 1:10 pm
Hoje à(s) 7:23 am
Ontem à(s) 11:54 pm
Ontem à(s) 11:50 pm
Ontem à(s) 9:44 pm
Ontem à(s) 8:49 pm
Ontem à(s) 6:23 pm
Ontem à(s) 5:21 pm
Ontem à(s) 4:40 pm
Ontem à(s) 2:37 pm
Ontem à(s) 12:48 pm
Ontem à(s) 11:34 am
Ontem à(s) 11:20 am
Sab Jun 16, 2018 10:40 pm
Sab Jun 16, 2018 9:43 pm
Sab Jun 16, 2018 9:28 pm
Sab Jun 16, 2018 8:48 pm
Sab Jun 16, 2018 5:13 pm
Sab Jun 16, 2018 5:05 pm
Sab Jun 16, 2018 4:51 pm
Sab Jun 16, 2018 4:33 pm
Sab Jun 16, 2018 4:14 pm
Sab Jun 16, 2018 3:39 pm
Sab Jun 16, 2018 1:48 pm
Sex Jun 15, 2018 10:15 pm
Sex Jun 15, 2018 8:31 pm
Sex Jun 15, 2018 8:24 pm
Sex Jun 15, 2018 8:02 pm
Sex Jun 15, 2018 5:08 pm
Sex Jun 15, 2018 2:46 pm
Sex Jun 15, 2018 12:08 pm
Sex Jun 15, 2018 10:46 am
Qui Jun 14, 2018 6:41 pm
Qui Jun 14, 2018 4:25 pm
Qui Jun 14, 2018 2:34 pm
Qui Jun 14, 2018 6:19 am
Qua Jun 13, 2018 10:08 pm
Qua Jun 13, 2018 9:59 pm
Qua Jun 13, 2018 6:48 pm
Qua Jun 13, 2018 3:16 pm
Qua Jun 13, 2018 3:11 pm
Qua Jun 13, 2018 9:12 am
Qua Jun 13, 2018 6:25 am
Qua Jun 13, 2018 1:00 am
Qua Jun 13, 2018 12:40 am
Ter Jun 12, 2018 11:08 pm
Ter Jun 12, 2018 8:00 pm
Ter Jun 12, 2018 5:17 pm
Ter Jun 12, 2018 2:25 pm
Ter Jun 12, 2018 9:00 am
Seg Jun 11, 2018 11:57 pm
Seg Jun 11, 2018 7:17 pm
Seg Jun 11, 2018 2:51 pm
Seg Jun 11, 2018 2:42 pm
Seg Jun 11, 2018 10:18 am
Seg Jun 11, 2018 10:05 am
Dom Jun 10, 2018 10:52 pm
Dom Jun 10, 2018 7:18 pm
Dom Jun 10, 2018 6:29 pm
Dom Jun 10, 2018 6:23 pm
Dom Jun 10, 2018 3:53 pm
Dom Jun 10, 2018 12:32 pm
Dom Jun 10, 2018 9:32 am
Sab Jun 09, 2018 5:36 pm
Sab Jun 09, 2018 5:14 pm
Sab Jun 09, 2018 5:09 pm
Sab Jun 09, 2018 11:44 am
Sab Jun 09, 2018 10:49 am
Sab Jun 09, 2018 8:27 am
Sex Jun 08, 2018 4:23 pm
Sex Jun 08, 2018 3:35 pm
Sex Jun 08, 2018 3:22 pm
Sex Jun 08, 2018 8:24 am
Sex Jun 08, 2018 1:02 am
Qui Jun 07, 2018 11:48 pm
Qui Jun 07, 2018 9:09 pm
Qui Jun 07, 2018 8:56 pm
Qui Jun 07, 2018 8:47 pm
Qui Jun 07, 2018 5:24 pm
Qua Jun 06, 2018 11:22 pm
Qua Jun 06, 2018 7:49 pm
Qua Jun 06, 2018 4:33 pm
Qua Jun 06, 2018 3:32 pm
Qua Jun 06, 2018 8:51 am
Ter Jun 05, 2018 11:46 pm
Ter Jun 05, 2018 10:47 pm
Ter Jun 05, 2018 8:12 pm
Ter Jun 05, 2018 7:53 pm
Zack2
NKKF
DevTerror
dstaroski
dstaroski
dstaroski
dstaroski
Dom3000
Phph09
Zack2
NKKF
Callyde Jr
guimaraf
fecirineu
fecirineu
FelipeSouza11
ismarspn
thancor
SuperGamer
MRX
MRX
NKKF
natanael.olimpio
dstaroski
Carlos Mesquita
Édipo
Flávio
dstaroski
M4theuz
dstaroski
kenau
NKKF
MRX
foxtenn
NKKF
BrazaTattoo
lesgoy
dstaroski
Dom3000
Midoriiiiii
BRGC
Dom3000
Dom3000
Dom3000
Zack2
yVIEIRA
Phph09
fecirineu
IanLuan
IanLuan
natanael.olimpio
guimaraf
NyeTiSS
francisco barroso
MRX
Zack2
dstaroski
MRX
Duarte
NKKF
dstaroski
igorobm
JonathanDiego
mafipt
Zack2
fecirineu
Dom3000
francisco barroso
bertarele
Magnatah
ZeroTuhnder
FelipeSouza11
francisco barroso
YmKx
francisco barroso
NKKF
Dom3000
Isabela
Dom3000
Dom3000
kenau
FelipeSouza11
FelipeSouza11
NyeTiSS
Callyde Jr
FelipeSouza11
dstaroski
kenau
kenau
Phph09
Zack2
NKKF
Carlos Mesquita
lesgoy
fecirineu
Priste_Hell
NyeTiSS
Dom3000
Carlos Mesquita

[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.
avatar
jasondavin
Programador

Masculino Posts : 106
Pontos : 334
Reputação : 16
Registro : 13/12/2017
Idade : 19
Áreas de atuação : Programação Web
GitHub : www.github.com/jasondavindev
Projeto: www.teamdev.pe.hu
Respeito as regras :

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
avatar
fabriciorsz34
Programador

Posts : 149
Pontos : 980
Reputação : 23
Registro : 08/06/2016
Idade : 18
Áreas de atuação : C#,unity,cinema 4D, SketchUp

Respeito as regras :

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
avatar
Dom3000
Programador

Masculino Posts : 868
Pontos : 2055
Reputação : 175
Registro : 18/06/2016
Idade : 22
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Blender, C#, Unity, Escritor, Game Disiner,...
Respeito as regras :

Ver perfil do usuário

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
Membro Junior
Membro Junior

Masculino Posts : 60
Pontos : 755
Reputação : 26
Registro : 07/09/2016
Respeito as regras :

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?
avatar
Dom3000
Programador

Masculino Posts : 868
Pontos : 2055
Reputação : 175
Registro : 18/06/2016
Idade : 22
Áreas de atuação : canal https://www.youtube.com/watch?v=yvmQEJUfbhQ
Blender, C#, Unity, Escritor, Game Disiner,...
Respeito as regras :

Ver perfil do usuário

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
avatar
NKKF
ProgramadorMaster

Masculino Posts : 997
Pontos : 1573
Reputação : 324
Registro : 24/01/2018
Idade : 13
Áreas de atuação : Não uso foto de perfil porque não tenho autoestima suficiente.
Respeito as regras :

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
Newbie
Newbie

Posts : 1
Pontos : 473
Reputação : 0
Registro : 04/03/2017
Respeito as regras :

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
Newbie
Newbie

Posts : 1
Pontos : 813
Reputação : 0
Registro : 29/03/2016
Respeito as regras :

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
Newbie
Newbie

Posts : 6
Pontos : 604
Reputação : 0
Registro : 02/11/2016
Respeito as regras :

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);
    }
}
avatar
Callyde Jr
Programador

Masculino Posts : 1088
Pontos : 2407
Reputação : 327
Registro : 16/06/2016
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

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
Newbie
Newbie

Posts : 6
Pontos : 604
Reputação : 0
Registro : 02/11/2016
Respeito as regras :

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);
        }
    }
avatar
Callyde Jr
Programador

Masculino Posts : 1088
Pontos : 2407
Reputação : 327
Registro : 16/06/2016
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

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
Newbie
Newbie

Posts : 6
Pontos : 604
Reputação : 0
Registro : 02/11/2016
Respeito as regras :

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
avatar
Callyde Jr
Programador

Masculino Posts : 1088
Pontos : 2407
Reputação : 327
Registro : 16/06/2016
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

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");
avatar
Callyde Jr
Programador

Masculino Posts : 1088
Pontos : 2407
Reputação : 327
Registro : 16/06/2016
Idade : 39
Áreas de atuação : Iniciante em modelagem Blender,ScketSHUP
Progamador
Ideialista

Meu Canal
https://www.youtube.com/ch
Respeito as regras :

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

Voltar ao Topo Ir em baixo

Voltar ao Topo


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