Avatar billede jkn83 Praktikant
05. maj 2010 - 10:52 Der er 4 kommentarer og
1 løsning

bruger med admin rettigheder og dem uden

Jeg har med hjælp her inde fra fået lavet et fungerende login system der tjekker brugerne på user.php om de har admin rettigheder. Problemmet ligger så i at jeg har nogle news add scripts også, men dem kan alle access... Og det vil jeg gerne have lavet om på så kun dem med admin rettigheder ( 1 ) kan access siden...

newsadd.php ser sådan ud, og giver mig en meddelelse når jeg går ind på siden, at jeg ingen administrative rettigheder har!

table users ser sådan ud: user_id, username, password, admin.

Løsning ønskes:

<?php
session_start();
?>

<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" >
<link href="style/style.css" rel="stylesheet" type="text/css" />
</head>

<body bgcolor="#4d4a37">
<div id="main">
<?

include("connect.php");

  if(isset($_POST['submit']))
  {
      $title = mysql_escape_string($_POST['title']);
      $text1 = mysql_escape_string($_POST['text1']);
      $text2 = mysql_escape_string($_POST['text2']);

              if(!$title){ 
                    echo "Fejl. Du skal skrive en overskrift!";
                    exit();
              }

        $tid = time();
        $result = mysql_query("INSERT INTO news (title, dtime, text1, text2, owner)
        VALUES ('$title','$tid','$text1','$text2','$_SESSION[userid]')")
        or die(mysql_error());

          echo "<b>Nyhed tilføjet!<br>Sender dig til forsiden!";
          echo "<meta http-equiv=Refresh content=4;url=nyheder.php>";
  }
else
  {
    $userid = $_SESSION["userid"];
    $q = mysql_query("SELECT * FROM users WHERE username='$userid'")or die(mysql_error());
    $n = mysql_num_rows($q);
    $res = mysql_fetch_assoc($q);
   
    if($res["admin"] == 1)
    {
      ?>

<form method='post' action='<?php echo $PHP_SELF ?>'>
    <font class='caption'>Overskrift:</font><br />
    <input type='text' name='title' size='29' maxlength='255' /><br /><br />
    <font class='caption'>Teaser:</font><br />
    <input type='text' name='text1' size='29' maxlength='255' /><br /><br />
    <font class='caption'>Nyhed:</font><br />
    <textarea name='text2' rows='7' cols='26'></textarea><br />
    <input type='submit' value='Tilføj nyhed' name='submit' />
</form>
</div>
      <?
  }
else
    {
    echo 'Du har ingen administrative rettigheder!';
    }
}

?>
Avatar billede showsource Seniormester
05. maj 2010 - 11:01 #1
Er username og $_SESSION["userid"] ?
Lyder som om $_SESSION["userid"] er et tal, og username en streng.

Du kan jo også tjekke at du rent faktisk får 1 row i sqlkald.
Avatar billede showsource Seniormester
05. maj 2010 - 11:04 #2
Der skulle selvf. stå "ens" i første linie
Avatar billede jkn83 Praktikant
05. maj 2010 - 11:05 #3
Kan være du vil se hvor session bliver registreret ?
altså user.php filen
Avatar billede inctor Nybegynder
05. maj 2010 - 11:13 #4
Ret
$q = mysql_query("SELECT * FROM users WHERE username='$userid'")or die(mysql_error());

til
$q = mysql_query("SELECT * FROM users WHERE user_id='$userid'")or die(mysql_error());

eller hvad den nu hedder..
Avatar billede jkn83 Praktikant
05. maj 2010 - 11:22 #5
Præcis hvad jeg havde brug for !!! Tak inctor ;)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester