0

我正在使用 php 和 ajax 开发基于回合的多人游戏。这些功能允许玩家使用用户信息登录游戏,并选择允许他们与 AI 或对手对战的游戏模式。每个用户可以从一个列表中选择一个字符,这个功能已经完成了。我想创建一个搜索功能,以便玩家可以搜索并与其他玩家战斗,类似于国际象棋。但是,目前我想让玩家输入另一个用户的用户名,以便进行搜索。我搜索了开源以找到一种创建搜索函数的方法,但我发现的当前函数破坏了我的代码。这是我当前的模式代码:

// Define Mode
if (isset($_GET['mode'])) {
    $mode = $secure->clean($_GET['mode']);
} else {
    $mode = '';
}
if ($mode == 'selection') {

    $page_title .=' > Character Selection';
    $page_titles .= ' Character Selection - Power Bond';

}
else if ($mode == 'search') {


if (isset($_GET['type'])) {
    $type = $secure->clean($_GET['type']);
} else {
    $type = '';
}

    if ($type == 'private') { 
        if (isset($_POST['pbsubmit']))  {
             $name = $secure->clean($_POST['name']);


        }
    }


} 

现在这是我的ajax。我找到的功能是检查匹配以找到用户名。该功能破坏了我的游戏。

//Check the match.
if (isset($_POST['f']) && $_POST['f'] == 'checkMatch')  {
$checkMatch = $db->query("SELECT * FROM accounts WHERE `id` = '".$account['id']."'");
    while ($info = mysql_fetch_array($checkMatch)) {
        $status = $info['status'];
        $gameid = $info['gameid'];
    }

$getGame = $db->fetch("SELECT * FROM Games WHERE `gameid` = '$gameid'");

        $status = $info['status'];
        $gameid = $info['gameid'];

if(!$getGame = 'NULL') {
    $data = 'testaeta';
} else {
    $data = '<h1> Who do you want to battle against? </h1>
<br />
<form action="" method="post" id="form-pb" name="pb" target="_self">
USERNAME:<input name="name" type="text" size="40" maxlength="40" />

<input name="pbsubmit" type="submit" value="Search"/>
</form>
<a class="goback" href="#">Cancel</a>';
}

echo $data;

}`

这是我的Javascripit:

`var match = null;
function popUp(what){
if(!what) errorMessage('Error: params', 'params', 'none');
switch(what){
    case 'search':
        preLoad('Loading please wait . . .');
        $('#main_container').prepend('<div id="popup"><div class="opacity"></div><div class="search"></div></div>');
        $('.search').load('./?page=game&mode=search&type=private', function(){
            $('#preloader').fadeOut('slow',function(){
                $('#preloader').remove();
            });         
        });
    break;
    case 'match':
        $.ajax({
            url : _path + "/core/ajax.php",
            type : 'POST',
            data : { f: 'checkMatch'},
            dataType : 'text',
            success :  function(data) {
                if(data){
                    $('#main_container').prepend(data);
                    match = setInterval(function(){
                        if(!$('.search').length){
                            $('#main_container').prepend('<div id="popup"><div class="opacity"></div><div class="search"></div></div>');
                        }
                        $('.search').load('./?page=game&mode=search&type=private', function(){

                            var meta = $('#stopMe').attr('content');
                            if(meta){
                                meta = meta.split("URL="), meta = meta[1];
                                window.location = meta;                                             
                            }

                        });                                     
                    },1000);
                }
            }
        });
    break;
    case 'submit':
        $.post('./?page=game&mode=search&type=private', $("#form-pb").serialize(), function(data){
            var $response=$(data);
            var error = $response.filter('h3').text();
            $('.search').html(data);                
            if(!error){
                match = setInterval(function(){
                if(!$('.search').length){
                    $('#main_container').prepend('<div id="popup"><div class="opacity"></div><div class="search"></div></div>');
                }
                $('.search').load('./?page=game&mode=search&type=private', function(){
                    var meta = $('#stopMe').attr('content');                                var meta = $('#stopMe').attr('content');
                    if(meta){
                        meta = meta.split("URL="), meta = meta[1];
                        window.location = meta;                                         
                    }                           
                });                             
                },1000);                    
            }
        });         
    break;
}
}

` 除了 mysql 之外,我主要关注的是允许它工作。有没有人可以解决我如何解决这个问题?另外,如果可能的话,我想要一个开源示例。

4

2 回答 2

0

无需搜索已编码的搜索解决方案,通常这对您的应用程序非常具体,并不复杂。

寻找一个自动完成工具(jQuery 提供它),一种获取安全数据的方法(GET 或 POST,但要检查它)和一种搜索方法:LIKE %...%(简单)或MATCH(...) AGAINST(.. .)(更完整)

于 2013-10-17T20:03:29.083 回答
0

好像是一个匹配系统。您可以在 mysql 中创建一个表并将其命名为积极的战斗。然后它获取用户 A 的信息并将其与用户 B 匹配,将他们置于战斗中。我认为您也可以为战斗动作制作一张表格。该表显示了用户在战斗中所做的事情。

于 2013-10-18T17:47:19.047 回答