好吧,我有个大问题。
让我解释一下。
我需要列出一些输入中的所有模式(复选框),然后我们可以选择要操作的模式,以便为特定用户提供特权。
不管怎样,我明白了,正如你所见:
<div id="list-schemas">
<?php
foreach ($schemas as $elt) {
echo '<input type="checkbox" name="schemas[]" value="' . $elt->getSchema() . '"/>' . $elt->getSchema() . '<br />';
}
?>
</div>
然后,我还需要设置一些具有特权的复选框,我做到了:
<div id="div-privileges">
<?php
foreach ($schemas as $elt) {
echo '<div class="list">';
echo '<label for="list">' . $elt->getSchema() . ' :</label><br />';
echo '<input type="checkbox" name="privileges[]" value="REVOKE"/> REVOKE ? <br />';
echo '<input type="checkbox" name="privileges[]" value="ALL"/> ALL PRIVILEGES ? <br />';
echo '<hr>';
echo '<input type="checkbox" name="privileges[]" value="SELECT"/> SELECT ? <br />';
echo '<input type="checkbox" name="privileges[]" value="INSERT"/> INSERT ? <br />';
echo '<input type="checkbox" name="privileges[]" value="UPDATE"/> UPDATE ? <br />';
echo '<input type="checkbox" name="privileges[]" value="DELETE"/> DELETE ? <br />';
echo '<hr>';
echo '<input type="checkbox" name="privileges[]" value="CREATE"/>CREATE ? <br />';
echo '</div>';
}
?>
</div>
也就是说,这里是我在UserManager.class.php中的函数更新:
public static function update(User $newPerso){
$db = DbConnect::getDb();
$newLogin= pg_escape_string($newPerso->getLogin());
$schemas=$newPerso->getSchemas();
$privileges=$newPerso->getPrivileges();
if (isset($schemas)){
foreach($schemas as $schema){
if (isset($privileges)){
foreach($privileges as $privilege){
if($privilege=="REVOKE"){
pg_query("{$privilege} ALL ON ALL TABLES IN SCHEMA {$schema} FROM {$newLogin};");
}
else if($privilege=="CREATE"){
pg_query("GRANT {$privilege} ON SCHEMA {$schema} TO {$newLogin};");
}
else if($privilege=="ALL" || $privilege=="INSERT" || $privilege=="SELECT" || $privilege=="UPDATE" || $privilege=="DELETE"){
pg_query("GRANT {$privilege} ON ALL TABLES IN SCHEMA {$schema} TO {$newLogin};");
}
}
}
}
}
}
事实上,它是有效的,但是,
当我选择示例2模式时(比如说“schema1”和“schema2”),
&当我为“schema1”选择“SELECT”和为“schema2”选择“INSERT”时,
结果:用户将在schema1和schema2中有'SELECT'+'INSERT'。。。
我真的被卡住了,我真的不知道该怎么办。。。
最佳答案
只需将输入修改为
<input type="checkbox" name="privileges[schema1][]" value="REVOKE"/> REVOKE ? <br />
看到这个了吗?它将在
[schema1]
数组中为您提供另一个级别。因此,您可以这样迭代:
foreach ($_POST['privileges'] as $schema => $privileges) {
foreach ($privileges as $privilege) {
// you know what privilege is for what schema
}
}