0

现在我已经把我的高分板保存为一个 SQL 数据库,我通过 Unity 使用一些 PHP 脚本来访问它。我原来的记分板允许我存储用户名和他们的分数,但我正在尝试添加额外的字段,如准确性等。但是,我的新字段没有显示或传递到我的服务器。

我有两个名为 display.php 和 addcrore.php 的 PHP 脚本(拼写错误我会修复)。Display.php 如下所示:

<?php
// Send variables for the MySQL database class.
$database = mysql_connect('localhost', 'dark', 'dark') or die('Could not connect: ' . mysql_error());
mysql_select_db('dark') or die('Could not select database');

$query = "SELECT * FROM `scores` ORDER by `score` DESC LIMIT 5";
$result = mysql_query($query) or die('Query failed: ' . mysql_error());

$num_results = mysql_num_rows($result);  

for($i = 0; $i < $num_results; $i++)
{
     $row = mysql_fetch_array($result);
     echo $row['name'] . "\t" . $row['score'] . "\t" . $row['accuracy'] . "\n";
}
?>

Addscrore.php 看起来像这样:

<?php 
        $db = mysql_connect('localhost', 'dark', 'dark') or die('Could not connect: ' . mysql_error()); 
        mysql_select_db('dark') or die('Could not select database');

        // Strings must be escaped to prevent SQL injection attack. 
        $name = mysql_real_escape_string($_GET['name'], $db); 
        $score = mysql_real_escape_string($_GET['score'], $db); 
     $accuracy = mysql_real_escape_string($_GET['accuracy'], $db);
        $hash = $_GET['hash']; 

        $secretKey="mySecretKey"; # Change this value to match the value stored in the client javascript below 

        $real_hash = md5($name . $score . $accuracy . $secretKey); 
        if($real_hash == $hash) 
     { 
            // Send variables for the MySQL database class. 
            $query = "insert into scores values (NULL, '$name', '$score', '$accuracy');"; 
            $result = mysql_query($query) or die('Query failed: ' . mysql_error()); 
        } 
?>

然后,在我的 Unity 程序中,我使用以下代码创建了 HSController 类:

using UnityEngine;
using System.Collections;

public class HSController : MonoBehaviour 
{
private string secretKey = "mySecretKey"; // Edit this value and make sure it's the same as the one stored on the server
public string addScoreURL = "/score/addscrore.php?"; //be sure to add a ? to your url
public string highscoreURL = "highscoretable/display.php";

void Start()
{


    StartCoroutine(GetScores());
}

    // remember to use StartCoroutine when calling this function!
    public IEnumerator PostScores(string name, int score, float accuracy)
    {
        //This connects to a server side php script that will add the name and score to a MySQL DB.
        // Supply it with a string representing the players name and the players score.
        string hash = MD5.Md5Sum(name + score + accuracy + secretKey);

        string post_url = addScoreURL + "name=" + WWW.EscapeURL(name) + "&score=" + score + "&accuracy" + accuracy + "&hash=" + hash;

        // Post the URL to the site and create a download object to get the result.
        WWW hs_post = new WWW(post_url);
        yield return hs_post; // Wait until the download is done

        if (hs_post.error != null)
        {
            print("There was an error posting the high score: " + hs_post.error);
        }
    }

    // Get the scores from the MySQL DB to display in a GUIText.
    // remember to use StartCoroutine when calling this function!
   public IEnumerator GetScores()
    {
        gameObject.guiText.text = "Loading Scores";
        WWW hs_get = new WWW(highscoreURL);
        yield return hs_get;

        if (hs_get.error != null)
        {
            print("There was an error getting the high score: " + hs_get.error);
        }
        else
        {
            gameObject.guiText.text = hs_get.text; // this is a GUIText that will display the scores in game.
        }


     }
    }

然后,当我想向我的表中添加一些新信息时,我调用以下代码行:

  string name = "Rawr";
    int score = 1325;
    float accuracy = 40.0f;
    HSController _test;


    // Use this for initialization
    void Start()
    {
        _test = new HSController();
        StartCoroutine(_test.PostScores(name, score,accuracy));
    }

然而,尽管如此,我的新领域,准确性,仍然没有被展示出来。谁能看到我做错了什么以及为什么我调用它时没有显示我的新字段?

4

1 回答 1

1

可能根本不是原因,但是在 C# 中,当您构建帖子 URL 时,您缺少等号"&accuracy"

于 2013-04-11T09:35:55.430 回答