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:
Preciso de Professor Particular para Unity3D e Programação
2 Artistas procuram Programador experiente em UNITY 2D
Erro Blender - Peso automatico ossos
Player olhar para direção em que se movimenta
[____TÓPICO LIVRE____] FALE O QUE QUISER (Parte 2)
Futuro dos Games e suas tecnologias
Mostrar tempo na tela no formato Dia Hora Segundos
Bug com Dropdown
Algumas Maneiras de Ganhar Dinheiro Com o Blender e Modelagem 3D
CommandInvokationFailure: Gradle build failed.
Como eu faço pra quando o tempo chegar em 14 segundos ele fazer algo
problema de gerenciamento de memoria na unity
Objeto child independente
Atualização Text
ASSETS do UNITY 3D - posso usar as assets gratuitas do unity em um jogo pago?
Problema com Sistema de Sanidade
Trading Card Game (TCG) de "Fantasia Medieval"
Shader - Campo de Força
[RESOLVIDO] como eu continuo o game a partir de save
Som de queda
Alguém que mexa com otimização mobile? Trabalho Remunerado!
Como fazer um chão quebrar ao passar por cima no Unity 3D
Duvida Sobre a colisao dos objetos
pegar o primeiro pai de um gameObject
Mercado MMO
Barra de Pontos com Slider usando Mathf.Lerp
Criar um poder de água, o que devo usar?
Movimento de BoxCollider com RigidBody
Sistema de Nota Personalizada
Procuro ROTEIRISTA
LWRP Mobile
Jogo de Tiro em 3° pessoa mais com mira
[EQUIPE] VAGAS ABERTAS
Duvida sobre Time.deltaTime
Formação de Equipe
Sprite Renderer
[TUTORIAL] AI Enemy 2.0 + animações ( Jogos de terror )
Desativar Capsule Collider
Quero saber se tem na unity alguma funçao  que seja um trigger?
Inimigo segue o player mesmo morto!!!
Como adicionar códigos nativos de 64 bits em um app Android? 64 bits do Google Play
[Dúvida] Multiplayer via roteador
Como programar um sistema para fazer o Player puxar um objetos no Unity
Chamar objeto em jogo em um modelo prefab
'Smooth Move'!?
DAR AÇÃO A UM BOTÃO
[RESOLVIDO] Problema no mesh collider após exportar para Desktop
Adicionar um botão!!
Site de animações
TurboSquid e licenças Free Royalty
ALGUEM DE PORTO ALEGRE OU ELDORADO DO SUL?
Como deixar o projeto mais leve Unity
clicar com o botão direito do mouse em um BOTÃO
Jogo - Conexão com Servidor
Problema com Global Ilumination Unity 2019
[TUTORIAL] Unity 5 - Como criar o próprio FPS Controller
Como coloco interações num objeto de um jogo da Unity 4?
[PHOTON] instanciando 2 players(repetidos) na cena.
Existe outras formas de multiplayer sem ser pelo Photon ou Unet?
GetComponet em Array
Script pesado
A escala do objeto importa ?
Erro: all compiler errors have to be fixed before you can enter play mode
Erro ?
Animação de arma
[TUTORIAL] Script de arma completo! [FREE]
ERRO: O nome de tipo ou namespace "UI" não existe no namespace "UnityEngine"
Skill não se move com o Jogador!!
Amoeba / Gosma - Unity
Player sobreviver desde as 00h ás 04:00
[RESOLVIDO] Publicar no PlayStore um app de Realidade Aumentada
Script de Tempo
[RESOLVIDO] Problema ao arrastar imagens, músicas ou modelos 3D para a UNITY
alguem sabe como atualizar o c#
como fazer um objeto seguir o player 2D
Jogo de Galo e de Galinha também
[TUTORIAL] Controle 3ª pessoa com animações mecânicas (root motion)
Alquem pode me explicar como funciona essa funçao
Como fazer o botão de tiro com touch nao com tecla
Como mover um objeto sem usar collider ou rigidbody?
[RESOLVIDO] Audio Stop e PlayOneShot
[RESOLVIDO] Não posso chamar uma matriz por outra?
[RESOLVIDO] Colisão
Mesh bugada no Android
Rotação animação
[RESOLVIDO] Sombras pixeladas (Android)
Como posso fazer pra atirar onde o cursor do mouse está (UNITY 2D)
[DIVULGAÇÃO] Venha aprender C# jogando!
[RESOLVIDO] Erro com "Instantiate"
Migração de Projetos no Unity
Unity: Como otimizar automaticamente o app para o GooglePlay
as sombras da minha sena esta sendo renderizadas longe de aonde deveria começar
Cena para fim do jogo
Podcast de desenvolvedores de jogos
Alguem cria jogos pagos para PLAY STORE?
[DUVIDA] Problema para "spawnar" os players no PhotonNetwork
[RESOLVIDO] Rotacionar modelo ou eixo de orientaçao (iniciante)
Animaçoes
Entou com duvida com on trigger Enter e Exit - UNITY
Hoje à(s) 7:49 pm
Hoje à(s) 7:36 pm
Hoje à(s) 5:02 pm
Hoje à(s) 2:52 pm
Hoje à(s) 1:42 am
Hoje à(s) 1:19 am
Hoje à(s) 12:48 am
Ontem à(s) 8:09 pm
Ontem à(s) 5:13 pm
Ontem à(s) 3:29 am
Seg Fev 24, 2020 10:03 pm
Seg Fev 24, 2020 1:54 pm
Seg Fev 24, 2020 10:44 am
Seg Fev 24, 2020 9:13 am
Dom Fev 23, 2020 10:20 pm
Dom Fev 23, 2020 10:09 pm
Dom Fev 23, 2020 9:42 pm
Dom Fev 23, 2020 9:13 pm
Dom Fev 23, 2020 8:35 pm
Dom Fev 23, 2020 7:53 pm
Dom Fev 23, 2020 7:45 pm
Dom Fev 23, 2020 7:43 pm
Dom Fev 23, 2020 7:23 pm
Dom Fev 23, 2020 6:06 pm
Dom Fev 23, 2020 5:01 pm
Dom Fev 23, 2020 4:51 pm
Dom Fev 23, 2020 6:39 am
Sab Fev 22, 2020 11:43 pm
Sab Fev 22, 2020 9:52 pm
Sab Fev 22, 2020 5:17 pm
Sab Fev 22, 2020 2:41 pm
Sab Fev 22, 2020 2:25 pm
Sab Fev 22, 2020 1:06 pm
Sab Fev 22, 2020 12:50 pm
Sab Fev 22, 2020 11:14 am
Sex Fev 21, 2020 7:55 pm
Sex Fev 21, 2020 6:21 pm
Sex Fev 21, 2020 4:44 pm
Sex Fev 21, 2020 4:26 pm
Sex Fev 21, 2020 1:55 pm
Sex Fev 21, 2020 1:02 pm
Sex Fev 21, 2020 9:05 am
Qui Fev 20, 2020 7:20 pm
Qui Fev 20, 2020 4:51 pm
Qui Fev 20, 2020 12:48 pm
Qui Fev 20, 2020 8:47 am
Qua Fev 19, 2020 8:13 pm
Qua Fev 19, 2020 6:49 pm
Qua Fev 19, 2020 3:51 pm
Qua Fev 19, 2020 1:04 am
Ter Fev 18, 2020 11:22 pm
Ter Fev 18, 2020 10:10 pm
Ter Fev 18, 2020 5:28 pm
Seg Fev 17, 2020 11:46 pm
Seg Fev 17, 2020 10:43 pm
Seg Fev 17, 2020 3:28 pm
Seg Fev 17, 2020 3:19 pm
Seg Fev 17, 2020 2:55 pm
Seg Fev 17, 2020 1:07 pm
Seg Fev 17, 2020 11:00 am
Seg Fev 17, 2020 9:54 am
Seg Fev 17, 2020 9:02 am
Seg Fev 17, 2020 4:50 am
Seg Fev 17, 2020 12:12 am
Dom Fev 16, 2020 4:29 pm
Dom Fev 16, 2020 12:42 pm
Dom Fev 16, 2020 3:50 am
Sab Fev 15, 2020 7:28 pm
Sab Fev 15, 2020 3:19 pm
Sab Fev 15, 2020 10:36 am
Sab Fev 15, 2020 12:29 am
Sex Fev 14, 2020 7:41 pm
Sex Fev 14, 2020 4:59 pm
Sex Fev 14, 2020 2:19 pm
Qua Fev 12, 2020 11:17 am
Ter Fev 11, 2020 7:26 am
Ter Fev 11, 2020 1:07 am
Ter Fev 11, 2020 1:03 am
Seg Fev 10, 2020 10:30 pm
Seg Fev 10, 2020 8:57 pm
Seg Fev 10, 2020 8:32 pm
Seg Fev 10, 2020 4:38 pm
Seg Fev 10, 2020 4:15 pm
Dom Fev 09, 2020 8:24 pm
Dom Fev 09, 2020 6:32 pm
Dom Fev 09, 2020 6:27 pm
Dom Fev 09, 2020 6:22 pm
Dom Fev 09, 2020 6:17 pm
Dom Fev 09, 2020 5:55 pm
Dom Fev 09, 2020 3:24 pm
Dom Fev 09, 2020 2:18 pm
Dom Fev 09, 2020 2:11 pm
Dom Fev 09, 2020 11:22 am
Sab Fev 08, 2020 2:40 pm
Sab Fev 08, 2020 1:03 pm
Sab Fev 08, 2020 12:10 pm
Sab Fev 08, 2020 11:40 am
Sab Fev 08, 2020 11:18 am
Sab Fev 08, 2020 4:46 am
pedrordep
Diguinho
IOOI
luizrbizzio
PauloFR
PauloFR
MayLeone
JoelMJunior
Magnatah
LucasFranco
iToddy
diegopds
Batataaaa
xandeqs
thiago000192
BlesseD
MayLeone
guimaraf
Magnatah
Magnatah
Magnatah
Magnatah
Magnatah
Nalfam
xandeqs
joffersoju
ronigleydson
BlesseD
BlesseD
ovoPentelho
Fagner
Fagner
guimaraf
Fagner
Douglas2020A
Diguinho
speedluk
Magnatah
Dom3000
speedluk
cultzone
Xamangue
Samuquis
Batataaaa
speedluk
samuelpaulino
guimaraf
BlesseD
Edivandro2706
Gabriel M
frozen
lesgoy
Batataaaa
danielPedra90
Fagner
pipipipo
pipipipo
daniel123163
artplayer
Batataaaa
Fagner
FelixTedesco
Fabio424
RafaelSquid1
Edivandro2706
Edu4rdogx
juansup
Nalfam
Fagner
SherDown
joffersoju
joffersoju
MarcosSchultz
diegopds
palestinus
dstaroski
pedroorf
ffabim
estuartyy
diegopds
BlesseD
Snickers1020
maxwarnava
Duarte
MayLeone
MRX
MayLeone
poyser
BlesseD
Fagner
lesgoy
lesgoy
Nightos
hendrick22
lesgoy
daniel123163
HEINZ4K
hendrick22
Felipe42

[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 : 947
REPUTAÇÃO : 16
Idade : 20
Á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

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 : 1607
REPUTAÇÃO : 25
Idade : 20
Áreas de atuação : C#,unity,cinema 4D, SketchUp

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

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 : 2840
REPUTAÇÃO : 231
Idade : 24
Á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

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 : 1372
REPUTAÇÃO : 26
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 2840
REPUTAÇÃO : 231
Idade : 24
Á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

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 : 2835
REPUTAÇÃO : 499
Idade : 15
Áreas de atuação : Resolver problemas
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) Aad8pUi

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 : 1101
REPUTAÇÃO : 4
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 1430
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 1221
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 3297
REPUTAÇÃO : 408
Idade : 41
Áreas de atuação : Iniciante em modelagem Blender,Sketchup
Programador
Idealista

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

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 : 1221
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 3297
REPUTAÇÃO : 408
Idade : 41
Áreas de atuação : Iniciante em modelagem Blender,Sketchup
Programador
Idealista

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

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 : 1221
REPUTAÇÃO : 0
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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 : 3297
REPUTAÇÃO : 408
Idade : 41
Áreas de atuação : Iniciante em modelagem Blender,Sketchup
Programador
Idealista

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

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 : 3297
REPUTAÇÃO : 408
Idade : 41
Áreas de atuação : Iniciante em modelagem Blender,Sketchup
Programador
Idealista

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

http://unnygames.000webhostapp.com/

Voltar ao Topo Ir em baixo

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

Mensagem por Diguinho em Dom Nov 03, 2019 3:14 pm

Primeira vez mechendo com php + mysql, Então o registro e login ta funcionando corretamente, Mas como eu faria se foste pra adcionar "Coins" via db ?, O codigo em si, OBS: já criei uma nova tabela chamada moedas na db, mas queria saber como fazer o player "Getar" e aparecer em um txt os "coins" ?
Diguinho
Diguinho
MembroAvançado

Masculino PONTOS : 853
REPUTAÇÃO : 13
Idade : 18
Áreas de atuação : Programação
Respeito as regras : [TUTORIAL] Unity + PHP + Mysql (com PDO) WvDYdlf

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