Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann ich in PHP als Strings übergebene mathematische Formeln sicher auswerten?

Wie kann ich in PHP als Strings übergebene mathematische Formeln sicher auswerten?

DDD
Freigeben: 2024-12-08 16:36:11
Original
516 Leute haben es durchsucht

How Can I Safely Evaluate Mathematical Formulas Passed as Strings in PHP?

Wie werte ich eine Formel aus, die als String in PHP übergeben wird?

Problem:

Ich versuche herauszufinden, was Richtige und sicherere Möglichkeit, eine als Zeichenfolge übergebene mathematische Operation auszuführen. In meinem Szenario handelt es sich um Werte, die aus Bild-EXIF-Daten abgerufen werden.

Nach kurzer Recherche habe ich zwei Möglichkeiten gefunden, dies zu tun.

function calculator1($str){
    eval("$str = $str;");
    return $str;
}
Nach dem Login kopieren
function calculator2($str){
    $fn = create_function("", "return ({$str});" );
    return $fn();
};
Nach dem Login kopieren

Beide Beispiele erfordern eine String-Bereinigung, um bösartigen Code zu vermeiden Ausführung. Gibt es eine andere oder kürzere Möglichkeit, dies zu tun?

Antwort:

function calculator3($str){
    $m = new EvalMath;
    return $m->evaluate($str);
}
Nach dem Login kopieren

Diese Methode verwendet die EvalMath-Klasse, die speziell für die sichere Auswertung mathematischer Ausdrücke entwickelt wurde aus nicht vertrauenswürdigen Quellen. Es bietet eine robuste Fehlerprüfung und wertet nur eine begrenzte Anzahl von Funktionen aus.

Hier ist ein Beispiel für die Verwendung:

$str = '2+2';
$result = calculator3($str);
echo $result; // Output: 4
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich in PHP als Strings übergebene mathematische Formeln sicher auswerten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage