我正在尝试获取所有客户端的数据库 ID,但我一直无法使用 foreach 等,因为它总是将值返回为 NULL。我需要获取一个带有数据库 ID 的 foreach 并将其放入一个数组中
$userchannel = $clients->cid->clientList["client_database_id"];
我正在尝试获取所有客户端的数据库 ID,但我一直无法使用 foreach 等,因为它总是将值返回为 NULL。我需要获取一个带有数据库 ID 的 foreach 并将其放入一个数组中
$userchannel = $clients->cid->clientList["client_database_id"];
经过一番摆弄,我设法让它工作,请验证。如果您对代码有疑问。随意问他们。
我所做的基本工作是从 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";
}
我设法修复它。
$ts3_VirtualServer->channelGetById(152) // 152 is the channel ID