Jump to content

problem with $this using multiple classes? *SOLVED*


Recommended Posts

I have two classes, site and security, both defined in seperate files. I have a function in the security class that has to call the site class. The problem is that when I try to use the $this variable in the site function that I called, it thinks that this is an object of the security class, not of the site class.


Can anyone tell me why this is happening?
You have to create an instance of the site class before calling it within the security class. Unless the method that you're calling within the site class doesn't use $this, then you can call it from within the security class like so:

site::method_name();


hth.

[!--quoteo(post=373882:date=May 14 2006, 10:26 PM:name=toplay)--][div class=\'quotetop\']QUOTE(toplay @ May 14 2006, 10:26 PM) [snapback]373882[/snapback][/div][div class=\'quotemain\'][!--quotec--]
You have to create an instance of the site class before calling it within the security class. Unless the method that you're calling within the site class doesn't use $this, then you can call it from within the security class like so:

site::method_name();
hth.
[/quote]

I don't think you understood my problem, here it is in a diluted form:

securityclass.php:
[code]
class securityclass {

       function getuser() {
             global $site;
             $site->query({sql statement});
       }

}
$security = new securityclass;
[/code]
siteclass.php
[code]
class siteclass {
          function otherfunction() {
          }
      function query($sqltext) {
               $this->otherfunction();
      }

}
[/code]

That $this right here ^ doesn't work because it thinks it refers to the security class, not the site class. It says function not defined because otherfunction is in the site class, not the security class.
[!--quoteo--][div class=\'quotetop\']QUOTE[/div][div class=\'quotemain\'][!--quotec--]That $this right here ^ doesn't work because it thinks it refers to the security class[/quote]
How does it? There is no sign of inheritence and you dont define securityclass() within site class at all.

Im afraid, with the code you have posted, these classes are not related AT ALL. Well, not properly anyway. Global vars are bad, especially within classes.

What exactly are you trying to have happen? Can we see the client code your using to get this error?
Here's full text of securityclass.php:
[code]
class securityclass {
    
    function setuser($username) {
        $this->username = $username;
        $this->setcodes();
    }
    
    function getuserid() {
        global $tbl_users,$site;
        $obj_userid = $site->query("SELECT id FROM ".$tbl_users." WHERE username='".$this->username."'",__FILE__,__LINE__);
        $obj_userid = $site->fetch($obj_userid,'object');
        return $obj_userid->id;
        
    }
    
    function getcodeids($int_userid) {
        global $tbl_usersecuritycodes,$site;
        $obj_codeids = $site->query("SELECT codeid FROM ".$tbl_usersecuritycodes." WHERE userid='".$int_userid."'",__FILE__,__LINE__);
        $arr_codeids = $site->extractids($obj_codeids);
        return $arr_codeids;
    }
    
    function getcodes($arr_codeids) {
        global $tbl_securitycodes,$site;
        $obj_codes = $site->query("SELECT code FROM ".$tbl_securitycodes." WHERE codeIN IN (".explode(",",$arr_codeids).")");
        $arr_codes = $site->extractids($obj_codes);
        return $arr_codes;
    }
    
    
    function setcodes() {
        $userid = $this->getuserid();
        $codeids = $this->getcodeids($userid);
        $codes = $this->getcodes($userid);
        foreach ($codes AS $value) {
            $this->security[$value] = TRUE;
        }
    }
    
    function checkcode($code) {
        if (isset($this->security['SYSTEMADMIN'])) {
            if ($this->security['SYSTEMADMIN']) {
                return TRUE;
            } else {
                return FALSE;
            }
        } elseif (isset($this->security[$code])) {
            if ($this->security[$code]) {
                return TRUE;
            } else {
                return FALSE;
            }
        } else {
            return FALSE;
        }
    }
}

$security = new securityclass;
?>[/code]

Here's part of siteclass.php (only the functions called)
[code]
<?php

class siteclass {
var $lastsql = "";
var $insertid = 0;
var $testmode = TRUE;

    
    function query($sqltext,$file=0,$line=0) {
        print_r(get_class_methods($this));
        echo($sqltext);
        if ($file==0 && $line==0) {
            $this->reporterror('STANDARDS',Array($sqltext));
        }        
        if ($obj = mysql_query($sqltext)) {
            $this->lastsql = $sqltext;
            if (substr($sqltext,0,6)=="INSERT") {
                $this->insertid = mysql_insert_id();
            }
            return $obj;
        } else {
            $this->reporterror('MYSQL',Array($sqltext,'site->query')); // DIES RIGHT HERE
            return FALSE;
        }
    }
    
        
    function reporterror($type,$data) {
        switch ($type) {
            case 'MYSQL' :
            case 'TECHNICAL' :
            case 'STANDARDS' :
            default :
                if ($this->testmode) {
                    echo $type."<BR>";
                    foreach ($data AS $value) {
                        print_r($value);
                    }
                }
            break;
        }        
    }

}
$site = new siteclass();
?>[/code]


I have no problem calling the class using siteclass::function() coding, I switched it thinking it would work better, and it didn't. Either way, site still thinks that $this is calling a securityclass object, not a siteclass object.
[!--quoteo(post=373910:date=May 15 2006, 12:35 AM:name=emehrkay)--][div class=\'quotetop\']QUOTE(emehrkay @ May 15 2006, 12:35 AM) [snapback]373910[/snapback][/div][div class=\'quotemain\'][!--quotec--]
your second class would have to extend the first in order to use $this->method_from_first_class
[/quote]

What's up with that? I'm in the site class and I can't call a function of the site class using $this? So, I have to call all my class methods using siteclass::method(), even though I'm calling within the same class? That is really fouled up logic.
in one file, you can include both classes, giving them references:
[code]
require_once('securityclass.php');
require_once('siteclass.php');

$sec = new securityclass;
$site = new siteclass;

$sec->GetCodeIds($userID);
$site->function($site->global_siteclass_variable);
[/code]

HTH

Also. One suggestion. I always use ExampleFunction() or ExampleClass{} and $exampleVariable formatting in my scripts. It's not a requirement by any means, but it certainly makes reading scripts a bit easier. Personal preference, though [img src=\"style_emoticons/[#EMO_DIR#]/smile.gif\" style=\"vertical-align:middle\" emoid=\":smile:\" border=\"0\" alt=\"smile.gif\" /]
Why didn't that work?

[!--quoteo(post=374037:date=May 15 2006, 03:52 PM:name=mb81)--][div class=\'quotetop\']QUOTE(mb81 @ May 15 2006, 03:52 PM) [snapback]374037[/snapback][/div][div class=\'quotemain\'][!--quotec--]
OK, I still don't have a good solution to my problem.

Anybody else want to ring in?
[/quote]
To be honest I still dont understand what your problem is exactly. Once again I ask you... can we see the client code that proves your error? Also, I still dont see any sign of inheritence in these classes.

Again I would suggest droping the global declarations and either instatiating the site class within the security class, or use inheritence.
[!--quoteo(post=374057:date=May 15 2006, 12:36 PM:name=thorpe)--][div class=\'quotetop\']QUOTE(thorpe @ May 15 2006, 12:36 PM) [snapback]374057[/snapback][/div][div class=\'quotemain\'][!--quotec--]
Again I would suggest droping the global declarations and either instatiating the site class within the security class, or use inheritence.
[/quote]

As far as proving the inheritance, I did a print_r() on the $this object and it display the variables that were currently assigned to the security class. I also displayed the methods and it was the same, it showed the methods of the security class, not the site class.

I like your idea of declaring the site class inside the security class, but will that also have the same variable values as the global $site class or are they consider two seperate objects? (for example, if I call $site->lastid in the security class, will it be the same value as the $site->id I call from the regular page?) If so, how do I do declare that?




[!--quoteo(post=374046:date=May 15 2006, 12:15 PM:name=macdumbpling)--][div class=\'quotetop\']QUOTE(macdumbpling @ May 15 2006, 12:15 PM) [snapback]374046[/snapback][/div][div class=\'quotemain\'][!--quotec--]
Why didn't that work?
[/quote]

It didn't work because you weren't calling the site class from inside the security class.
mb81, I believe that you're not understanding us. I gave you one solution in the first post here and so have others.

Please read up some more on PHP OOP so you can implement a design that works for you. Only you really know what you want and need. Don't rush into creating a design that's not going to be effective or won't work. Look into design patterns and it may help you pick an approach.

instance / instantiate / new object:
[a href=\"http://us2.php.net/manual/en/language.oop.php\" target=\"_blank\"]http://us2.php.net/manual/en/language.oop.php[/a]

extend / inheritance:
[a href=\"http://us2.php.net/manual/en/keyword.extends.php\" target=\"_blank\"]http://us2.php.net/manual/en/keyword.extends.php[/a]
[a href=\"http://us2.php.net/manual/en/keyword.parent.php\" target=\"_blank\"]http://us2.php.net/manual/en/keyword.parent.php[/a]

Scope Resolution Operator:
[a href=\"http://us2.php.net/manual/en/keyword.paamayim-nekudotayim.php\" target=\"_blank\"]http://us2.php.net/manual/en/keyword.paama...nekudotayim.php[/a]

Patterns (PHP5+ page):
[a href=\"http://us2.php.net/manual/sv/language.oop5.patterns.php\" target=\"_blank\"]http://us2.php.net/manual/sv/language.oop5.patterns.php[/a]

[a href=\"http://www.zend.com/php/design/patterns1.php\" target=\"_blank\"]http://www.zend.com/php/design/patterns1.php[/a]
[a href=\"http://www.devshed.com/c/a/PHP/Design-Patterns-in-PHP-Factory-Method-and-Abstract-Factory/\" target=\"_blank\"]http://www.devshed.com/c/a/PHP/Design-Patt...stract-Factory/[/a]
[a href=\"http://www.devarticles.com/c/a/PHP/Introduction-to-Design-Patterns-Using-PHP/\" target=\"_blank\"]http://www.devarticles.com/c/a/PHP/Introdu...erns-Using-PHP/[/a]
Book: [a href=\"http://www.phparch.com/shop_product.php?itemid=96\" target=\"_blank\"]http://www.phparch.com/shop_product.php?itemid=96[/a]
[code]class securityclass {

       function getuser() {
             global $site;
             $site->query({sql statement});
       }

}[/code]
Are you sure the "global" here picks up anything outside of the class scope?
[!--quoteo(post=374118:date=May 15 2006, 04:08 PM:name=toplay)--][div class=\'quotetop\']QUOTE(toplay @ May 15 2006, 04:08 PM) [snapback]374118[/snapback][/div][div class=\'quotemain\'][!--quotec--]

Patterns (PHP5+ page):
[a href=\"http://us2.php.net/manual/sv/language.oop5.patterns.php\" target=\"_blank\"]http://us2.php.net/manual/sv/language.oop5.patterns.php[/a]

[/quote]

This page answered my question. I have read a couple of other things, and here is what I have found:

toplay, actually your first post did not solve the problem because the ($this) reserved word is based on the last instantiate class, so if you use a scope resolution operator (::) to call the function, then the last instantiated class is the one you are calling from, not the one you are in. I still don't understand why declaring the global didn't work, but I don't really care at this point.

Then, there was a post to say not to use the global instance of the class, but didn't explain anything about the singleton method as described in the above link to be able to access the same instance of the class.

Then, the other post was calling the class from outside of the other class, which didn't help me either, because I was calling it from inside the other class.

Thanks for the help.

[!--quoteo(post=374119:date=May 15 2006, 04:10 PM:name=ryanlwh)--][div class=\'quotetop\']QUOTE(ryanlwh @ May 15 2006, 04:10 PM) [snapback]374119[/snapback][/div][div class=\'quotemain\'][!--quotec--]
[code]class securityclass {

       function getuser() {
             global $site;
             $site->query({sql statement});
       }

}[/code]
Are you sure the "global" here picks up anything outside of the class scope?
[/quote]

Yes it does, it is the way I have done other sites without a problem.
[!--quoteo--][div class=\'quotetop\']QUOTE[/div][div class=\'quotemain\'][!--quotec--]Yes it does, it is the way I have done other sites without a problem. [/quote]

But have you actually INSTANTIANTED a site class for $site??

[code]$site = new SiteClass; //do you have this??

class securityclass {

       function getuser() {
             global $site;
             $site->query({sql statement});
       }

}[/code]

If you do not instantiate the site class in the global scope, then $site is NULL, so it doesn't have the member function "query"
[!--quoteo(post=374129:date=May 15 2006, 04:48 PM:name=ryanlwh)--][div class=\'quotetop\']QUOTE(ryanlwh @ May 15 2006, 04:48 PM) [snapback]374129[/snapback][/div][div class=\'quotemain\'][!--quotec--]
But have you actually INSTANTIANTED a site class for $site??

[code]$site = new SiteClass; //do you have this??

class securityclass {

       function getuser() {
             global $site;
             $site->query({sql statement});
       }

}[/code]

If you do not instantiate the site class in the global scope, then $site is NULL, so it doesn't have the member function "query"
[/quote]

Yes I have that. That wasn't the problem. I could get to the siteclass and until I fixed it, I just couldn't get the site class to recognize itself.
There wasn't client code, there was a fatal error due to a function not being defined.

I posted my server code...
I spoke in complete English sentences and actually used appropriate terms when I asked my question....
And I found in the PHP documentation that it behaved exactly the way it was supposed to.......

By the way, it's not "solved" per se, but I just extended one of the classes, even though it makes absolutely no sense to do it that way, it got rid of my issues.





[!--quoteo--][div class=\'quotetop\']QUOTE[/div][div class=\'quotemain\'][!--quotec--]There wasn't client code[/quote]
So... you didn't actually use these classes anywhere?
[!--quoteo--][div class=\'quotetop\']QUOTE[/div][div class=\'quotemain\'][!--quotec--]even though it makes absolutely no sense to do it that way, it got rid of my issues[/quote]
Probably because your missing some OOP concepts. These can be quite hard to grasp at first and can seem a little alien. This site might be good for you though...

[a href=\"http://www.phppatterns.com\" target=\"_blank\"]phppatterns[/a]().

Its ugly, but well worth a visit.
Guest askjames01
I khow this was solved but i would like to thank [b][!--coloro:#CC6600--][span style=\"color:#CC6600\"][!--/coloro--]TOPLAY[!--colorc--][/span][!--/colorc--][/b]
for the good links about PATTERNS...

thanks toplay... [img src=\"style_emoticons/[#EMO_DIR#]/laugh.gif\" style=\"vertical-align:middle\" emoid=\":laugh:\" border=\"0\" alt=\"laugh.gif\" /]

cheers!
This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.