Heim  >  Artikel  >  Backend-Entwicklung  >  Zusammenfassung der PHP-Berechtigungskontrollmodifikatoren: Ein Überblick über die Verwendung und Unterschiede verschiedener Berechtigungsmodifikatoren

Zusammenfassung der PHP-Berechtigungskontrollmodifikatoren: Ein Überblick über die Verwendung und Unterschiede verschiedener Berechtigungsmodifikatoren

WBOY
WBOYOriginal
2024-01-19 10:28:051241Durchsuche

Zusammenfassung der PHP-Berechtigungskontrollmodifikatoren: Ein Überblick über die Verwendung und Unterschiede verschiedener Berechtigungsmodifikatoren

Als Programmiersprache, die häufig für die Webentwicklung verwendet wird, stellt PHP auch strenge Anforderungen an die Berechtigungsverwaltung. Um die Sicherheit des Programms zu gewährleisten, müssen Entwickler Berechtigungen für verschiedene Teile des Programms durch Berechtigungskontrollmodifikatoren steuern. In diesem Artikel werden die Berechtigungskontrollmodifikatoren in PHP ausführlich vorgestellt, den Lesern geholfen, ihre Funktionen und Unterschiede besser zu verstehen, und entsprechende Codebeispiele bereitgestellt.

  1. öffentlicher Modifikator

Der öffentliche Modifikator ist der am häufigsten verwendete Berechtigungskontrollmodifikator in PHP und wird zur Beschreibung öffentlicher Mitgliedsvariablen und Mitgliedsmethoden verwendet. Wenn Sie eine Mitgliedsvariable oder -methode als öffentlich definieren, kann jedes Objekt auf die Variable oder Methode zugreifen.

Zum Beispiel definiert das folgende Codebeispiel eine Klasse namens Person und definiert darin eine öffentliche Mitgliedsvariable $name und eine öffentliche Mitgliedsmethode sayHello(). Unabhängig davon, ob für den Zugriff auf diese Mitglieder innerhalb oder außerhalb der Klasse keine Einschränkungen erforderlich sind:

class Person {
    public $name;
    
    public function sayHello() {
        echo 'Hello, my name is '.$this->name;
    }
}

$person = new Person();
$person->name = 'Tom';
$person->sayHello();
  1. geschützter Modifikator

Der geschützte Modifikator wird zur Beschreibung geschützter Mitgliedsvariablen und Mitgliedsmethoden verwendet. Das Definieren einer Mitgliedsvariablen oder -methode als geschützt bedeutet, dass nur Unterklassen und übergeordnete Klassen auf diese Mitglieder zugreifen können.

Zum Beispiel definiert das folgende Codebeispiel eine Klasse namens Animal und definiert darin eine geschützte Mitgliedsvariable $name und eine geschützte Mitgliedsmethode getName(). Nur Unterklassen und übergeordnete Klassen der Animal-Klasse können auf diese Mitglieder zugreifen:

class Animal {
    protected $name;
    
    protected function getName() {
        return $this->name;
    }
}

class Cat extends Animal {
    public function setName($name) {
        $this->name = $name;
    }
    
    public function sayHello() {
        echo 'Hello, I am '.$this->getName();
    }
}

$cat = new Cat();
$cat->setName('Tom');
$cat->sayHello();
  1. privater Modifikator

privater Modifikator wird zur Beschreibung privater Mitgliedsvariablen und Mitgliedsmethoden verwendet. Das Definieren einer Mitgliedsvariablen oder -methode als privat bedeutet, dass nur diejenigen innerhalb der Klasse auf diese Mitglieder zugreifen können.

Zum Beispiel definiert das folgende Codebeispiel eine Klasse namens Person und definiert darin eine private Mitgliedsvariable $name und eine private Mitgliedsmethode getName(). Auf diese Mitglieder kann außerhalb der Klasse nicht direkt zugegriffen werden:

class Person {
    private $name;
    
    private function getName() {
        return $this->name;
    }
    
    public function sayHello() {
        echo 'Hello, my name is '.$this->getName();
    }
}

$person = new Person();
$person->name = 'Tom';  // 这里会报错
$person->sayHello();
  1. final-Modifikator

Der final-Modifikator wird verwendet, um das Überschreiben von Klassen und Methoden einzuschränken. Wenn Sie eine Klasse oder Methode als final definieren, bedeutet dies, dass sie in Unterklassen nicht überschrieben werden kann.

Zum Beispiel definiert das folgende Codebeispiel eine Klasse namens Animal und darin eine finale Methode eat(). Da die Methode als final definiert ist, kann sie in einer Unterklasse von Animal nicht überschrieben werden:

class Animal {
    final public function eat() {
        echo 'I am eating';
    }
}

class Cat extends Animal {
    public function eat() {  // 这里会报错
        echo 'I am not eating';
    }
}

$cat = new Cat();
$cat->eat();
  1. abstrakter Modifikator

abstrakter Modifikator wird zum Definieren abstrakter Klassen und abstrakter Methoden verwendet. Abstrakte Klassen können nicht instanziiert werden und können nur von anderen Klassen geerbt werden. Abstrakte Methoden haben nur Definitionen, keine spezifische Implementierung und müssen in Unterklassen überschrieben werden.

Zum Beispiel definiert das folgende Codebeispiel eine abstrakte Klasse namens Animal und darin eine abstrakte Methode eat(). Da die eat()-Methode abstrakt ist, muss diese Methode in der Animal-Unterklasse Cat implementiert werden:

abstract class Animal {
    abstract public function eat();
}

class Cat extends Animal {
    public function eat() {
        echo 'I am eating fish';
    }
}

$cat = new Cat();
$cat->eat();

Durch die obige Einführung können wir die Verwendung und Unterschiede verschiedener Berechtigungskontrollmodifikatoren in PHP klar verstehen. Wenn wir Projekte entwickeln, müssen wir geeignete Methoden zur Berechtigungskontrolle auf der Grundlage spezifischer Anforderungen auswählen und die einschlägigen Vorschriften strikt einhalten, um die Sicherheit und Stabilität des Programmbetriebs zu gewährleisten.

Das obige ist der detaillierte Inhalt vonZusammenfassung der PHP-Berechtigungskontrollmodifikatoren: Ein Überblick über die Verwendung und Unterschiede verschiedener Berechtigungsmodifikatoren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn