Assoziative Arrays und Variablen

Collapse
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • Assoziative Arrays und Variablen

    Moin moin da draußen,

    ich bin kurz davor den Rechner aus dem Fenster zu werfen. Deshalb bitte keine "im Forum suchen"-Antworten. Ich suche bereits seit mehreren Stunden... :-(

    Hier also mein Problem:
    Ich möchte gerne einen Assoziativen Array erstellen, in dem 'dir_cache' und 'dir_upload' variabel gehalten werden. Dies scheint so aber offensichtlich nicht zu funktionieren.

    PHP Code:
    $userconfig = array(
        
    'overwrite_cache' => 'off',                 //Cache bei jedem Aufruf neu erstellen: on = an, off = aus 
        
    'pic_image_quality' => 90,                  //Bildqualitaet: 0 = schlechteste , 100 = beste
        
    'show_metadata_iptc' => 'on',               //IPTC-Ausgabe: on = an, off = aus
        
    'show_metadata_exif' => 'off',              //EXIF-Ausgabe: on = an, off = aus 
        
    'dir_cache' => dirname(__FILE__).'/../img/news/'.$id.'/cache',          //Pfad zum Cache Verzeichnis
        
    'dir_upload' => dirname(__FILE__).'/../img/news/'.$id,        //Pfad zum Upload Verzeichnis
        
    'http_method' => 'GET',                     //Uebermittlungsmethode der Query-Variable: PATHINFO oder GET
        
    'http_var_name' => 'q',                     //Name der Query-Variablen die per http_method uebergeben wird
        
    'response_type' => 'json'                   //Art der Antwort: direkt = json, include = php
    ); 
    Mein Lösungsansatz:
    Es hat wohl was damit zu tun, dass $id kein string ist. Wenn ich in den array direkt z.b.
    PHP Code:
    'dir_cache' => dirname(__FILE__).'/../img/news/33/cache' 
    schreibe, funktioniert alles. Ist aber leider wieder nur statisch.

    Vielen Dank für eure Hilfe

  • #2
    Was steht denn in $id? Und was heißt
    Dies scheint so aber offensichtlich nicht zu funktionieren.
    ? Die Syntax sieht korrekt aus.

    Comment


    • #3
      $id ist ein Übergabeparameter indem eine Zahl drin steht. Also die ID eines Newseintrages.

      Und was heißt
      Zitat:
      Dies scheint so aber offensichtlich nicht zu funktionieren.
      ?
      Naja, wenn es so funktionieren würde, hätte ich ja nicht gefragt...

      Comment


      • #4
        Achso, folgende Serverdaten:

        PHP Version: 5.2.10-0.dotdeb.1
        System: Linux weizenbaum 2.6.26-2-amd64 #1 SMP Thu May 28 21:28:49 UTC 2009 x86_64

        wenn ich
        PHP Code:
        $id="33"
        ausschreibe, funktioniert es.

        jetzt kommt Sie so in spiel:
        PHP Code:
        function news_content($id)
        {
           ...
           
        $userconfig = array(...);
           ...

        Comment


        • #5
          Na, dann kommt die ID wohl falsch an. Mal debuggen. Und das error_reporting hochdrehen. Und mal definieren, was statt der korrekten ID ankommt, beschreibe doch wenigstens mal das aktuelle Phänomen. Es ist auf jeden Fall ein Fehler in deinem Code und um den zu finden sind etwas mehr Informationen nötig.

          Comment


          • #6
            Originally posted by Montephp View Post
            PHP Code:
            function news_content($id)
            {
               ...
               
            $userconfig = array(...);
               ...

            PHP Code:
            function news_content($id)
            { global 
            $userconfig;
               ...
               
            $userconfig = array(...);
               ...

            Comment


            • #7
              Was soll der global-Pfusch?

              Comment


              • #8
                Es hat wohl was damit zu tun, dass $id kein string ist.
                Der Typ der Variablen $id ist doch vollkommen egal. Wenn sie mit "." verknüpft wird, konvertiert PHP sie automatisch nach String und fertig. Im schlimmsten Fall würde dann dein zusammengebauter Pfad nicht passen.

                Wenn ich in den array direkt z.b.
                PHP Code:
                'dir_cache' => dirname(__FILE__).'/../img/news/33/cache' 
                schreibe, funktioniert alles.
                Definiere doch mal bitte "funktioniert alles" und "funktioniert nicht" genauer.
                Und lass dir $id (innerhalb deiner Funktion) und $userconfig['dir_cache'] für beide Fälle von var_dump() anzeigen.
                Dann sehen wir weiter (oder klarer ).
                Klingon function calls do not have “parameters”‒they have “arguments”‒and they always win them!

                Comment


                • #9
                  Originally posted by h3ll View Post
                  Was soll der global-Pfusch?
                  Hä ?

                  PHP: Variable scope - Manual

                  Comment


                  • #10
                    Originally posted by piratos View Post
                    Nur weil etwas geht, heißt es noch lange nicht, dass man es so machen soll.

                    Auf global sollte man großteils verzichten. Das ist sehr sehr schlechter Programmierstil.

                    Comment


                    • #11
                      Da scheinst du ja eine festgefahrene Meinung zu haben.

                      Völliger Unsinn wenn man weiss was man macht.

                      Schau dir mal z.B. Phpmyadmin an wie die auf globals setzen.

                      Ansonsten ist die Frage des Fragestelllers beantwortet.
                      Last edited by ; 17-07-2009, 12:33. Reason: Ergänzung

                      Comment


                      • #12
                        Originally posted by piratos View Post
                        Da scheinst du ja eine festgefahrene Meinung zu haben.

                        Völliger Unsinn wenn man weiss was man macht.
                        Völlig unnötig, wenn man sauber und objektorientiert programmiert. Es gibt ganz wenige Sonderfälle, wo ein global sinnvoll ist.

                        Originally posted by piratos View Post
                        Schau dir mal z.B. Phpmyadmin an wie die auf globals setzen.
                        Nur weils andere scheiße machen, muss man es ja selber nicht genauso machen, oder? Oder ist für dich der Source-Code von phpMyAdmin die Referenz? Dann hast du wohl noch nie in deinem Leben guten Source-Code gesehen.

                        Originally posted by piratos View Post
                        Ansonsten ist die Frage des Fragestelllers beantwortet.
                        Es gibt viele Wege nach Rom. Du hast ihm den schlechtesten gezeigt. Bravo.

                        Comment


                        • #13
                          Völliger Unsinn wenn man weiss was man macht.
                          Völliger Unsinn, wenn man weiß wie es besser geht!

                          Schau dir mal z.B. Phpmyadmin an wie die auf globals setzen.
                          Bevor du dir an dem Code von PMA ein Beispiel nimmst, schau dir doch mal die Codestruktur besser designter Systeme wie zum Beispiel das Zend FW oder Doctrine an.

                          Es gibt viele Wege nach Rom. Du hast ihm den schlechtesten gezeigt. Bravo.
                          Falls dass denn überhaupt eine Lösung war. Aber ohne einen weiteren klärenden Beitrag vom TO wird das nicht wirklich beantwortbar sein.

                          Comment


                          • #14
                            Völlig unnötig, wenn man sauber und objektorientiert programmiert
                            Man kann aus jeder Furzfunktion ein OOP Klasse machen, aber klug ist das nicht.

                            Nur weils andere scheiße machen, muss man es ja selber nicht genauso machen, oder? Oder ist für dich der Source-Code von phpMyAdmin die Referenz? Dann hast du wohl noch nie in deinem Leben guten Source-Code gesehen.
                            Ich schreibe laufend guten Code, aber das kannst du dir wohl nicht vorstellen.
                            Schlechte Progger sind immer die, welche mit einer vorgefassten Meinung ran gehen, denn damit hast du Recht.
                            Es gibt viele Wege nach Rom.
                            Und solche Dinge
                            Du hast ihm den schlechtesten gezeigt. Bravo.
                            wirken nicht gerade qualifiziernd.

                            Comment


                            • #15
                              Und solche Dinge ........ wirken nicht gerade qualifiziernd.
                              Deine Aussagen sollen "besser" sein?
                              Unsinn!
                              Du scheinst zu verbohrt zu sein, sonst würde ich dir evtl eine Begründung liefern.
                              Last edited by combie; 17-07-2009, 13:02.
                              Wir werden alle sterben

                              Comment

                              Working...
                              X