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
DDDOriginal
2024-12-08 16:36:11493Durchsuche

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;
}
function calculator2($str){
    $fn = create_function("", "return ({$str});" );
    return $fn();
};

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);
}

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

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!

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