• Login
  • Register
  • Zoek
This Thread
  • Everywhere
  • This Thread
  • This Forum
  • Articles
  • Pages
  • Forum
  • Filebase Entry
  • More Options

ICTscripters

Dé plek voor IT

Dé plek voor IT

Login

Geavanceerde opties
  1. Home
  2. Forum
    1. Alle berichten
    2. Recente activiteiten
  3. ICT Nieuws
  4. Blog
  5. Marktplaats
    1. Werk
    2. Advertenties
    3. Domeinnamen
    4. Websites
    5. Design & lay-outs
    6. Scripts
    7. Overige
  6. Design
  7. Leden
    1. Actieve bezoekers
    2. Team
    3. Leden zoeken
  8. Downloads
  9. Goedkope domeinnamen
  1. Home
  2. Forum
    1. Alle berichten
    2. Recente activiteiten
  3. ICT Nieuws
  4. Blog
  5. Marktplaats
    1. Werk
    2. Advertenties
    3. Domeinnamen
    4. Websites
    5. Design & lay-outs
    6. Scripts
    7. Overige
  6. Design
  7. Leden
    1. Actieve bezoekers
    2. Team
    3. Leden zoeken
  8. Downloads
  9. Goedkope domeinnamen
  1. Home
  2. Forum
    1. Alle berichten
    2. Recente activiteiten
  3. ICT Nieuws
  4. Blog
  5. Marktplaats
    1. Werk
    2. Advertenties
    3. Domeinnamen
    4. Websites
    5. Design & lay-outs
    6. Scripts
    7. Overige
  6. Design
  7. Leden
    1. Actieve bezoekers
    2. Team
    3. Leden zoeken
  8. Downloads
  9. Goedkope domeinnamen
  1. Dé plek voor IT - ICTscripters
  2. Forum
  3. Scripting & programmeren
  4. PHP + SQL

Forum

  • Beta-testers gezocht voor Crypto-oefenplatform

    Syntax 29 januari 2026 om 16:11
  • Na 15 jaar terug van weggeweest: iCriminals.nl is terug (BETA)!

    Syntax 19 januari 2026 om 09:34
  • Developer Gezocht

    Mikevdk 10 januari 2026 om 18:57
  • Op zoek naar de legends

    Syntax 5 januari 2026 om 13:50
  • [FREE] WeFact Hosting module

    Jeroen.G 13 oktober 2025 om 14:09
  • Help testers nodig voor android app Urgent

    urgentotservices 26 september 2025 om 10:21
  • Versio vervanger

    Jeroen.G 25 augustus 2025 om 15:56
  • Afspraken systeem met planbeperking

    Lijno 1 augustus 2025 om 23:04

Marktplaats

  • 321 Nieuwe Domeinnamen December 2025

    shiga 1 januari 2026 om 10:26
  • Meerdere mafia game template te koop

    Syntax 26 december 2025 om 00:07
  • Van een pixelige afbeelding naar een strakke, moderne website

    Syntax 21 december 2025 om 17:05

[PHP] Bericht verwijderen

  • galo
  • 12 oktober 2012 om 00:16
  • galo
    Beginner
    Berichten
    45
    • 12 oktober 2012 om 00:16
    • #1

    Hallo ik heb een probleem

    ik wil een bericht verwijderen maar dat doet hij niet hij zegt dat mn bericht verwijdert.
    Verder krijg ik geen foutmeldingen.

    message.php?p=del

    dat is wat er komt te staan wnnr er op delete gedrukt word

    PHP
    print "<td class=\"mainTxt\" align=\"center\" width=100><a href=\"message.php?p=del&id=[]{$message->id}\">Delete</a></td></tr></table>\n";
          }
        }
        else if($_GET['p'] == "del") {
          if(isset($_GET['id']))
            $_POST['id']			= $_GET['id'];
          foreach($_POST['id'] as $msgid) {
            $dbres				= mysql_query("SELECT `outbox`,`inbox`,`from`,`to` FROM `messages` WHERE `id`='$msgid' AND (`from`='{$user->login}' OR `to`='{$user->login}')")  or die (mysql_error());
            if($message = mysql_fetch_object($dbres)) {
              if($message->from == $user->login)
                mysql_query("UPDATE `messages` SET `outbox`=0 WHERE `id`='$msgid'");
              else
                mysql_query("UPDATE `messages` SET `inbox`=0 WHERE `id`='$msgid'");
            }
          }
    Toon Meer
  • A.Bijlsma
    Web Developer
    Ontvangen Reacties
    3
    Berichten
    1.795
    • 12 oktober 2012 om 00:30
    • #2

    Dit zou moeten werken:

    PHP
    print "<td class=\"mainTxt\" align=\"center\" width=100><a href=\"message.php?p=del&id=[]{$message->id}\">Delete</a></td></tr></table>\n";
          }
        }
        else if($_GET['p'] == "del") {
          if(isset($_GET['id'])){
            $_POST['id']            = $_GET['id'];
          foreach($_POST['id'] as $msgid) {
            $dbres                = mysql_query("SELECT `outbox`,`inbox`,`from`,`to` FROM `messages` WHERE `id`='$msgid' AND (`from`='{$user->login}' OR `to`='{$user->login}')")  or die (mysql_error());
            if($message = mysql_fetch_object($dbres)) {
              if($message->from == $user->login){
                mysql_query("UPDATE `messages` SET `outbox`=0 WHERE `id`='$msgid'");
              } else{
                mysql_query("UPDATE `messages` SET `inbox`=0 WHERE `id`='$msgid'");
              }
              }
              }
            }
          }
    Toon Meer

    Met vriendelijke groet,

    A.Bijlsma
    Venimo

  • galo
    Beginner
    Berichten
    45
    • 12 oktober 2012 om 00:37
    • #3

    nee het werkt nog steeds niet?:O

  • sander.bruggers
    Web Developer
    Berichten
    56
    • 12 oktober 2012 om 14:07
    • #4
    PHP
    print "<td class=\"mainTxt\" align=\"center\" width=100><a href=\"message.php?p=del&id=[{$message->id}]\">Delete</a></td></tr></table>\n";
          }
        }
        else if($_GET['p'] == "del") {
          if(isset($_GET['id'])){
            $_POST['id']            = $_GET['id'];
          foreach($_POST['id'] as $msgid) {
            $dbres                = mysql_query("SELECT `outbox`,`inbox`,`from`,`to` FROM `messages` WHERE `id`='$msgid' AND (`from`='{$user->login}' OR `to`='{$user->login}')")  or die (mysql_error());
            if($message = mysql_fetch_object($dbres)) {
              if($message->from == $user->login){
                mysql_query("UPDATE `messages` SET `outbox`=0 WHERE `id`='$msgid'");
              } else{
                mysql_query("UPDATE `messages` SET `inbox`=0 WHERE `id`='$msgid'");
              }
              }
              }
            }
          }
    Toon Meer

    Probeer dit eens voor de grap

    http://www.webfub.nl

  • galo
    Beginner
    Berichten
    45
    • 12 oktober 2012 om 16:29
    • #5

    nee ik snap er niks van als ik een ander berichten script gebruik is het zelfde probleem? zou het probleem misschien ergens anders kunnen liggen???

  • sander.bruggers
    Web Developer
    Berichten
    56
    • 12 oktober 2012 om 16:33
    • #6
    PHP
    print "<td class=\"mainTxt\" align=\"center\" width=100><a href=\"message.php?p=del&id=[{$message->id}]\">Delete</a></td></tr></table>\n";
          }
        }
        else if($_GET['p'] == "del") {
          if(isset($_GET['id'])){
        
            $dbres                = mysql_query("SELECT `outbox`,`inbox`,`from`,`to` FROM `messages` WHERE `id`='$msgid' AND (`from`='{$user->login}' OR `to`='{$user->login}')")  or die (mysql_error());
            if($message = mysql_fetch_object($dbres)) {
              if($message->from == $user->login){
                mysql_query("UPDATE `messages` SET `outbox`=0 WHERE `id`='$msgid'");
              } else{
                mysql_query("UPDATE `messages` SET `inbox`=0 WHERE `id`='$msgid'");
              }
              
              }
            }
          }
    Toon Meer


    Stuur anders even de hele pagina, dan kijk ik er even naar.

    http://www.webfub.nl

  • galo
    Beginner
    Berichten
    45
    • 12 oktober 2012 om 16:49
    • #7

    kan hem hier niet posten hij is te lang .

    http://pastebin.com/XMr8i3w4

  • cakemasher
    Developer
    Ontvangen Reacties
    2
    Berichten
    225
    • 12 oktober 2012 om 22:33
    • #8

    Galo,

    Het gene wat je nu gaat lezen moet je opvatten als feedback en niet om je de grond in te rammen!


    Ik kan je nu vertellen.. Als iemand erachter komt dat jij je script zo draait. Ben je binne no-time je hele database kwijt ;).

    Waarom?

    • De values die jij in je database gebruikt, kunnen worden gemanipuleerd door de gebruiker. Dit als gevolg dat je script zeer gevoelig is voor mysql injecties. Maak gebruik van mysql_real_escape_string.
    • Je haalt ID via GET op, dit is geen array (volgens mij), daarna zet je 'm om in post wat geen nut heeft. Daarna heb je een foreach loop wat nog minder nut heeft. Probeer dit te vermijden.
    • Je snap niet waarom het systeem niet werkt. Kijk mijn 2e punt, en DENK OM JE FOUT AFHANDELING. Fout afhandeling is echt super belangrijk. Je gaat er bijv. nu van uit dat de query's lukken. Wie zegt dat dat ook zo is?
    • Hou strings buiten de quotes. Dus bijvoorbeeld: echo "Welkom $speler hoe is het?" word: echo "Welkom " . $speler . " hoe is het?".

    Als ik iets fout heb begrepen moet je 't me even verduidelijken =).

    Hieronder staat een code die ik voor je gemaakt hebt. Deze is wat netter.. Probeer er van te leren en misschien dat deze je gewenste resultaat geeft.

    PHP
    <?php
    	// Kijken of $_GET['p'] niet leeg is, en of deze 'del' is. Daarnaast word er gekeken of $_GET['id'] ook bestaat.
    	else if (!empty ($_GET['p']) && strtolower ($_GET['p']) == 'del' && !empty ($_GET['id']))
    	{	
    		// Omdat ik niet weet waar dit vandaan komt, ga ik ervanuit dat het onveilig is. Met deze functies word het veilig om de value in een query te gebruiken.
    		$msgid	= mysql_real_escape_string ($msgid);
    		
    		// Hier gebeurt het zelfde.
    		$login	= mysql_real_escape_string ($user->login);
    		
    		
    		// We voeren de query uit, en checken op fouten.
    		$query	= mysql_query ("SELECT `outbox`, `inbox`, `from`, `to` FROM `messages` WHERE `id` = '" . $msgid . "' AND (`from` = '" . $user->login . "' OR `to` = '" . $user->login . "')")  or die (mysql_error());
    		
    		// Omdat vanaf dit punt de query is gelukt, maken we er een array van zodat we met de value's kunnen spelen.
    		$array	= mysql_fetch_assoc ($query);
    		
    		
    			// We gaan nu kijken of de msg van de ingelogde gebruiker komt. Zoja word de ene query uitgevoerd, zo nee de andere.
    			if ($array['from'] == $login)
    				mysql_query ("UPDATE `messages` SET `outbox` = 0 WHERE `id` = '" . mysql_real_escape_string ($_GET['id']) . "'") or die (mysql_error ());
    			else
    				mysql_query ("UPDATE `messages` SET `inbox` = 0 WHERE `id` = '" . mysql_real_escape_string ($_GET['id']) . "'") or die (mysql_error ());
    	
    	
    	// einde if.
    	}
    ?>
    Toon Meer
  • DirkZz
    Intermediate
    Ontvangen Reacties
    29
    Berichten
    213
    • 13 oktober 2012 om 00:46
    • #9

    cakemasher
    mysql_real_escape string is inderdaad wel het minimum van wat je dient toe te passen.

    galo
    Als je op basis van cakemasher zijn commentaar nog verder wil kijken dan zou jij je ook kunnen verdiepen in Prepared statements/stored procedures.

    http://php.net/manual/en/pdo.prepared-statements.php

Participate now!

Heb je nog geen account? Registreer je nu en word deel van onze community!

Maak een account aan Login

ICT Nieuws

  • Fijne feestdagen

    tcbhome 28 december 2025 om 13:55
  • Kritieke update voor Really Simple Security-plug-in

    K.Rens 16 november 2024 om 16:12
  • ING Nederland streeft naar ondersteuning van Google Pay tegen eind februari

    K.Rens 2 november 2024 om 16:09

Blogs

  • Functioneel ontwerp

    Dees 28 december 2014 om 12:38
  • Access Control List implementatie in PHP/MySQL - deel 1/2

    FangorN 28 december 2018 om 12:35
  • Access Control List implementatie in PHP/MySQL - deel 2/2

    FangorN 29 december 2018 om 12:37
  1. Marktplaats
  2. Design
  3. Voorwaarden
  4. Ons team
  5. Leden
  6. Geschiedenis
  7. Regels
  8. Links
  9. Privacy Policy
ICTscripters ©2005 - 2026 , goedkope hosting door DiMoWeb.com, BE0558.915.582
Sponsors: Beste kattenhotel provincie Antwerpen | Beste Zetes eid kaartlezer webshop
Style: Nexus by cls-design
Stylename
Nexus
Manufacturer
cls-design
Licence
Commercial styles
Help
Supportforum
Visit cls-design