0

我正在尝试获取所有客户端的数据库 ID,但我一直无法使用 foreach 等,因为它总是将值返回为 NULL。我需要获取一个带有数据库 ID 的 foreach 并将其放入一个数组中

$userchannel = $clients->cid->clientList["client_database_id"];
4

2 回答 2

1

经过一番摆弄,我设法让它工作,请验证。如果您对代码有疑问。随意问他们。

我所做的基本工作是从 teampeak php 框架站点中显示的示例中修改现有代码。我使用 Android 用户列表获取最多的代码。从那里开始它只是尝试和调试;)

此代码将打印用户的数据库 ID 和用户名。(当然,从这一点开始,你可以用它做任何你想做的事情。)

另外,也许可以快速查看一下 php 框架的 api 文档。它有很多有用的编码技巧和窍门。

https://docs.planetteamspeak.com/ts3/php/framework/

编辑 (07-01-17) 我还注意到,确保查询用户有足够的权限,为方便起见,我做了我的服务器管理员查询(授予对所有选项的访问权限,请注意,这在活动站点中可能是不安全的! )

<?php
// load framework files
require_once("libraries/TeamSpeak3/TeamSpeak3.php");

try {
  // connect to local server, authenticate and spawn an object for the virtual server on port 9988
  $ts3_ServerInstance = TeamSpeak3::factory("serverquery://###:##@####:##/?server_port=9987");
  $selected_sid = $ts3_ServerInstance->serverList();
  $ts3_VirtualServer = $ts3_ServerInstance->serverGetById($selected_sid);

  /* walk through list of clients */
  echo "<table class=\"list\">\n";
  echo "<tr>\n" .
       "  <th>DB id</th>\n" .
       "  <th>Nickname</th>\n" .
       "</tr>\n";
  foreach($ts3_VirtualServer->clientList() as $client) {
    echo "<tr>\n" .
         "  <td>" . $client['client_database_id'] . "</td>" .
         "  <td>" . htmlspecialchars($client) . "</td>" .
         "</tr>\n";
  }
  echo "</table>\n";
}
catch(Exception $e) {
  /* catch exceptions and display error message if anything went wrong */
  echo "<span class='error'><b>Error " . $e->getCode() . ":</b> " . $e->getMessage() . "</span>\n";
}
于 2017-01-07T21:02:40.283 回答
0

我设法修复它。

$ts3_VirtualServer->channelGetById(152) // 152 is the channel ID
于 2017-01-08T13:43:02.670 回答