PHP और MySQL के साथ यूनिटी लॉगिन सिस्टम

इस ट्यूटोरियल में, मैं दिखाऊंगा कि PHP और MySQL का उपयोग करके Unity में लॉगिन सिस्टम कैसे बनाया जाए।

इस ट्यूटोरियल के लिए PHP और MySQLi (MySQL का एक उन्नत संस्करण) के साथ cPanel वाले सर्वर की आवश्यकता है।

बेझिझक किफायती प्रीमियम VPS होस्टिंग या सस्ता साझा होस्टिंग विकल्प देखें।

चरण 1: MySQL डेटाबेस सेट करें

  • cPanel में लॉग इन करें
  • डेटाबेस अनुभाग में MySQL डेटाबेस पर क्लिक करें

  • "Create New Database" अनुभाग के अंतर्गत अपने डेटाबेस का नाम टाइप करें और फिर क्लिक करें "Create Database"

डेटाबेस बनने के बाद हमें एक उपयोगकर्ता बनाना होगा जो इसके साथ जुड़ा होगा:

  • "MySQL Users" अनुभाग के अंतर्गत उपयोगकर्ता नाम टाइप करें, फिर पासवर्ड टाइप करें (या एक मजबूत पासवर्ड बनाने के लिए पासवर्ड जेनरेटर का उपयोग करें)। पासवर्ड को कहीं सेव करना न भूलें, बाद में इसकी जरूरत पड़ेगी।

अंत में, हमें एक उपयोगकर्ता को अनुमतियों के एक विशिष्ट सेट के साथ डेटाबेस में असाइन करने की आवश्यकता है।

  • "Add User To Database" अनुभाग के अंतर्गत नव निर्मित उपयोगकर्ता और डेटाबेस का चयन करें और फिर क्लिक करें "Add"

"Add" पर क्लिक करने के बाद आपके सामने विशेषाधिकारों की एक सूची प्रस्तुत की जाएगी। केवल उन्हीं विशेषाधिकारों का चयन करें जिनका आप भविष्य में उपयोग करने की योजना बना रहे हैं। सबसे आम हैं हटाएं, चुनें, डालें और अद्यतन करें:

  • अंतिम रूप देने के लिए "Make Changes" पर क्लिक करें

चरण 2: MySQL तालिका बनाएं

MySQL तालिका उपयोगकर्ताओं द्वारा प्रदान किए गए मानों को संग्रहीत करेगी, जैसे उपयोगकर्ता नाम, ईमेल, पासवर्ड इत्यादि।

  • डेटाबेस अनुभाग के अंतर्गत "phpMyAdmin" पर क्लिक करें

  • नए बनाए गए डेटाबेस पर क्लिक करें और फिर SQL टैब पर क्लिक करें

  • नीचे दिए गए कोड को क्वेरी एडिटर में पेस्ट करें और फिर क्लिक करें "Go"
SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET AUTOCOMMIT = 0;
START TRANSACTION;
SET time_zone = "+00:00";

--
-- Table structure for table `sc_users`
--

CREATE TABLE `sc_users` (
  `user_id` int(11) NOT NULL,
  `username` varchar(20) CHARACTER SET utf8 NOT NULL,
  `email` varchar(254) CHARACTER SET utf8 NOT NULL,
  `password` char(60) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `registration_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Indexes for table `sc_users`
--
ALTER TABLE `sc_users`
  ADD PRIMARY KEY (`user_id`),
  ADD UNIQUE KEY `username` (`username`),
  ADD UNIQUE KEY `email` (`email`);

--
-- AUTO_INCREMENT for table `sc_users`
--
ALTER TABLE `sc_users`
  MODIFY `user_id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=1;
COMMIT;

उपरोक्त क्वेरी एक नई तालिका 'sc_users' बनाएगी जो उपयोगकर्ता डेटा संग्रहीत करेगी।

चरण 3: प्रोग्राम सर्वर-साइड लॉजिक

सर्वर-साइड लॉजिक में PHP स्क्रिप्ट शामिल होंगी जो Unity से पोस्ट डेटा प्राप्त और संसाधित करेंगी।

पहली फ़ाइल डेटाबेस.php है जो PHP MySQLi एक्सटेंशन का उपयोग करके MySQL डेटाबेस से कनेक्ट होगी।

डेटाबेस.php

<?php
	$host = "localhost"; // Host name 
	$db_username = "DATABASE_USER"; // Mysql username 
	$db_password = "USER_PASSWORD"; // Mysql password 
	$db_name = "DATABASE_NAME"; // Database name 

	$mysqli_conection = mysqli_connect($host, $db_username, $db_password, $db_name)or die("cannot connect"); 
?>

DATABASE_USER, USER_PASSWORD, और DATABASE_NAME को अपने मानों से बदलें।

दूसरी फ़ाइल रजिस्टर.php है। यह फ़ाइल Unity से पोस्ट डेटा प्राप्त करेगी और डेटाबेस तालिका में एक नया उपयोगकर्ता रिकॉर्ड सम्मिलित करेगी।

रजिस्टर.php

<?php
	if(isset($_POST["email"]) && isset($_POST["username"]) && isset($_POST["password1"]) && isset($_POST["password2"])){
		$errors = array();
		
		$emailMaxLength = 254;
		$usernameMaxLength = 20;
		$usernameMinLength = 3;
		$passwordMaxLength = 19;
		$passwordMinLength = 5;
		
		$email = strtolower($_POST["email"]);
		$username = $_POST["username"];
		$password1 = $_POST["password1"];
		$password2 = $_POST["password2"];
		
		//Validate email
		if(preg_match('/\s/', $email)){
			$errors[] = "Email can't have spaces";
		}else{
			if(!validate_email_address($email)){
				$errors[] = "Invalid email";
			}else{
				if(strlen($email) > $emailMaxLength){
					$errors[] = "Email is too long, must be equal or under " . strval($emailMaxLength) . " characters";
				}
			}
		}
		
		//Validate username
		if(strlen($username) > $usernameMaxLength || strlen($username) < $usernameMinLength){
			$errors[] = "Incorrect username length, must be between " . strval($usernameMinLength) . " and " . strval($usernameMaxLength) . " characters";
		}else{
			if(!ctype_alnum ($username)){
				$errors[] = "Username must be alphanumeric";
			}
		}
		
		//Validate password
		if($password1 != $password2){
			$errors[] = "Passwords do not match";
		}else{
			if(preg_match('/\s/', $password1)){
				$errors[] = "Password can't have spaces";
			}else{
				if(strlen($password1) > $passwordMaxLength || strlen($password1) < $passwordMinLength){
					$errors[] = "Incorrect password length, must be between " . strval($passwordMinLength) . " and " . strval($passwordMaxLength) . " characters";
				}else{
					if(!preg_match('/[A-Za-z]/', $password1) || !preg_match('/[0-9]/', $password1)){
						$errors[] = "Password must contain atleast 1 letter and 1 number";
					}
				}
			}
		}
		
		//Check if there is user already registered with the same email or username
		if(count($errors) == 0){
			//Connect to database
			require dirname(__FILE__) . '/database.php';
			
			if ($stmt = $mysqli_conection->prepare("SELECT username, email FROM sc_users WHERE email = ? OR username = ? LIMIT 1")) {
				
				/* bind parameters for markers */
				$stmt->bind_param('ss', $email, $username);
					
				/* execute query */
				if($stmt->execute()){
					
					/* store result */
					$stmt->store_result();

					if($stmt->num_rows > 0){
					
						/* bind result variables */
						$stmt->bind_result($username_tmp, $email_tmp);

						/* fetch value */
						$stmt->fetch();
						
						if($email_tmp == $email){
							$errors[] = "User with this email already exist.";
						}
						else if($username_tmp == $username){
							$errors[] = "User with this name already exist.";
						}
					}
					
					/* close statement */
					$stmt->close();
					
				}else{
					$errors[] = "Something went wrong, please try again.";
				}
			}else{
				$errors[] = "Something went wrong, please try again.";
			}
		}
		
		//Finalize registration
		if(count($errors) == 0){
			$hashedPassword = password_hash($password1, PASSWORD_BCRYPT);
			if ($stmt = $mysqli_conection->prepare("INSERT INTO sc_users (username, email, password) VALUES(?, ?, ?)")) {
				
				/* bind parameters for markers */
				$stmt->bind_param('sss', $username, $email, $hashedPassword);
					
				/* execute query */
				if($stmt->execute()){
					
					/* close statement */
					$stmt->close();
					
				}else{
					$errors[] = "Something went wrong, please try again.";
				}
			}else{
				$errors[] = "Something went wrong, please try again.";
			}
		}
		
		if(count($errors) > 0){
			echo $errors[0];
		}else{
			echo "Success";
		}
	}else{
		echo "Missing data";
	}
	
	function validate_email_address($email) {
		return preg_match('/^([a-z0-9!#$%&\'*+-\/=?^_`{|}~.]+@[a-z0-9.-]+\.[a-z0-9]+)$/i', $email);
	}
?>

और अंतिम फ़ाइल लॉगिन.php है जो क्रेडेंशियल प्राप्त करेगी और उन्हें sc_users तालिका के विरुद्ध जांचेगी।

लॉगिन.php

<?php
	if(isset($_POST["email"]) && isset($_POST["password"])){
		$errors = array();
		
		$email = $_POST["email"];
		$password = $_POST["password"];
		
		//Connect to database
		require dirname(__FILE__) . '/database.php';
		
		if ($stmt = $mysqli_conection->prepare("SELECT username, email, password FROM sc_users WHERE email = ? LIMIT 1")) {
			
			/* bind parameters for markers */
			$stmt->bind_param('s', $email);
				
			/* execute query */
			if($stmt->execute()){
				
				/* store result */
				$stmt->store_result();

				if($stmt->num_rows > 0){
					/* bind result variables */
					$stmt->bind_result($username_tmp, $email_tmp, $password_hash);

					/* fetch value */
					$stmt->fetch();
					
					if(password_verify ($password, $password_hash)){
						echo "Success" . "|" . $username_tmp . "|" .  $email_tmp;
						
						return;
					}else{
						$errors[] = "Wrong email or password.";
					}
				}else{
					$errors[] = "Wrong email or password.";
				}
				
				/* close statement */
				$stmt->close();
				
			}else{
				$errors[] = "Something went wrong, please try again.";
			}
		}else{
			$errors[] = "Something went wrong, please try again.";
		}
		
		if(count($errors) > 0){
			echo $errors[0];
		}
	}else{
		echo "Missing data";
	}
?>
  • सभी 3 फ़ाइलें अपने public_html फ़ोल्डर में अपलोड करें।

चरण 4: प्रोग्राम क्लाइंट लॉजिक इन Unity

क्लाइंट लॉजिक में एक C# स्क्रिप्ट शामिल होगी जो डेटा को PHP स्क्रिप्ट में पोस्ट करेगी।

SC_LoginSystem.cs

using System.Collections;
using UnityEngine;
using UnityEngine.Networking;

public class SC_LoginSystem : MonoBehaviour
{
    public enum CurrentWindow { Login, Register }
    public CurrentWindow currentWindow = CurrentWindow.Login;

    string loginEmail = "";
    string loginPassword = "";
    string registerEmail = "";
    string registerPassword1 = "";
    string registerPassword2 = "";
    string registerUsername = "";
    string errorMessage = "";

    bool isWorking = false;
    bool registrationCompleted = false;
    bool isLoggedIn = false;

    //Logged-in user data
    string userName = "";
    string userEmail = "";

    string rootURL = "http://YOUR_SITE.COM/"; //Path where php files are located

    void OnGUI()
    {
        if (!isLoggedIn)
        {
            if (currentWindow == CurrentWindow.Login)
            {
                GUI.Window(0, new Rect(Screen.width / 2 - 125, Screen.height / 2 - 115, 250, 230), LoginWindow, "Login");
            }
            if (currentWindow == CurrentWindow.Register)
            {
                GUI.Window(0, new Rect(Screen.width / 2 - 125, Screen.height / 2 - 165, 250, 330), RegisterWindow, "Register");
            }
        }

        GUI.Label(new Rect(5, 5, 500, 25), "Status: " + (isLoggedIn ? "Logged-in Username: " + userName + " Email: " + userEmail : "Logged-out"));
        if (isLoggedIn)
        {
            if (GUI.Button(new Rect(5, 30, 100, 25), "Log Out"))
            {
                isLoggedIn = false;
                userName = "";
                userEmail = "";
                currentWindow = CurrentWindow.Login;
            }
        }
    }

    void LoginWindow(int index)
    {
        if (isWorking)
        {
            GUI.enabled = false;
        }

        if (errorMessage != "")
        {
            GUI.color = Color.red;
            GUILayout.Label(errorMessage);
        }
        if (registrationCompleted)
        {
            GUI.color = Color.green;
            GUILayout.Label("Registration Completed!");
        }

        GUI.color = Color.white;
        GUILayout.Label("Email:");
        loginEmail = GUILayout.TextField(loginEmail);
        GUILayout.Label("Password:");
        loginPassword = GUILayout.PasswordField(loginPassword, '*');

        GUILayout.Space(5);

        if (GUILayout.Button("Submit", GUILayout.Width(85)))
        {
            StartCoroutine(LoginEnumerator());
        }

        GUILayout.FlexibleSpace();

        GUILayout.Label("Do not have account?");
        if (GUILayout.Button("Register", GUILayout.Width(125)))
        {
            ResetValues();
            currentWindow = CurrentWindow.Register;
        }
    }

    void RegisterWindow(int index)
    {
        if (isWorking)
        {
            GUI.enabled = false;
        }

        if (errorMessage != "")
        {
            GUI.color = Color.red;
            GUILayout.Label(errorMessage);
        }

        GUI.color = Color.white;
        GUILayout.Label("Email:");
        registerEmail = GUILayout.TextField(registerEmail, 254);
        GUILayout.Label("Username:");
        registerUsername = GUILayout.TextField(registerUsername, 20);
        GUILayout.Label("Password:");
        registerPassword1 = GUILayout.PasswordField(registerPassword1, '*', 19);
        GUILayout.Label("Password Again:");
        registerPassword2 = GUILayout.PasswordField(registerPassword2, '*', 19);

        GUILayout.Space(5);

        if (GUILayout.Button("Submit", GUILayout.Width(85)))
        {
            StartCoroutine(RegisterEnumerator());
        }

        GUILayout.FlexibleSpace();

        GUILayout.Label("Already have an account?");
        if (GUILayout.Button("Login", GUILayout.Width(125)))
        {
            ResetValues();
            currentWindow = CurrentWindow.Login;
        }
    }

    IEnumerator RegisterEnumerator()
    {
        isWorking = true;
        registrationCompleted = false;
        errorMessage = "";

        WWWForm form = new WWWForm();
        form.AddField("email", registerEmail);
        form.AddField("username", registerUsername);
        form.AddField("password1", registerPassword1);
        form.AddField("password2", registerPassword2);

        using (UnityWebRequest www = UnityWebRequest.Post(rootURL + "register.php", form))
        {
            yield return www.SendWebRequest();

            if (www.result != UnityWebRequest.Result.Success)
            {
                errorMessage = www.error;
            }
            else
            {
                string responseText = www.downloadHandler.text;

                if (responseText.StartsWith("Success"))
                {
                    ResetValues();
                    registrationCompleted = true;
                    currentWindow = CurrentWindow.Login;
                }
                else
                {
                    errorMessage = responseText;
                }
            }
        }

        isWorking = false;
    }

    IEnumerator LoginEnumerator()
    {
        isWorking = true;
        registrationCompleted = false;
        errorMessage = "";

        WWWForm form = new WWWForm();
        form.AddField("email", loginEmail);
        form.AddField("password", loginPassword);

        using (UnityWebRequest www = UnityWebRequest.Post(rootURL + "login.php", form))
        {
            yield return www.SendWebRequest();

            if (www.result != UnityWebRequest.Result.Success)
            {
                errorMessage = www.error;
            }
            else
            {
                string responseText = www.downloadHandler.text;

                if (responseText.StartsWith("Success"))
                {
                    string[] dataChunks = responseText.Split('|');
                    userName = dataChunks[1];
                    userEmail = dataChunks[2];
                    isLoggedIn = true;

                    ResetValues();
                }
                else
                {
                    errorMessage = responseText;
                }
            }
        }

        isWorking = false;
    }

    void ResetValues()
    {
        errorMessage = "";
        loginEmail = "";
        loginPassword = "";
        registerEmail = "";
        registerPassword1 = "";
        registerPassword2 = "";
        registerUsername = "";
    }
}

http://YOUR_SITE.COM/ को अपने मान से बदलें (यह एक रूट पथ होना चाहिए जहां आपने PHP फ़ाइलें अपलोड की हैं)। साथ ही, यदि आपके सर्वर पर एसएसएल प्रमाणपत्र स्थापित है तो HTTPS का उपयोग करना सुनिश्चित करें।

Play दबाएँ, फिर नया खाता बनाने या लॉग इन करने के लिए क्रेडेंशियल प्रदान करने के लिए रजिस्टर पर क्लिक करें।

हमारे पास ऑनलाइन लीडरबोर्ड बनाने के तरीके पर इस ट्यूटोरियल की निरंतरता है।

सुझाए गए लेख
एकता ऑनलाइन लीडरबोर्ड ट्यूटोरियल
यूनिटी में मल्टीप्लेयर नेटवर्क गेम्स का निर्माण
PUN 2 के साथ एक मल्टीप्लेयर कार गेम बनाएं
यूनिटी में फोटॉन फ्यूजन 2 का परिचय
मल्टीप्लेयर डेटा संपीड़न और बिट हेरफेर
यूनिटी PUN 2 रूम में मल्टीप्लेयर चैट जोड़ रही है
PUN 2 का उपयोग करके यूनिटी में एक मल्टीप्लेयर गेम बनाएं