문제:
이를 알아내려고 노력 중입니다. 문자열로 전달된 수학 연산을 실행하는 적절하고 안전한 방법입니다. 제 시나리오에서는 이미지 EXIF 데이터에서 가져온 값입니다.
약간의 조사 끝에 두 가지 방법을 찾았습니다.
function calculator1($str){ eval("$str = $str;"); return $str; }
function calculator2($str){ $fn = create_function("", "return ({$str});" ); return $fn(); };
두 예 모두 악성 코드를 방지하려면 문자열 정리가 필요합니다. 실행. 다른 방법이나 더 짧은 방법이 있습니까?
답변:
function calculator3($str){ $m = new EvalMath; return $m->evaluate($str); }
이 방법은 수학 표현식을 안전하게 평가하기 위해 특별히 설계된 EvalMath 클래스를 사용합니다. 신뢰할 수 없는 출처에서. 강력한 오류 검사 기능을 제공하며 제한된 기능 세트만 평가합니다.
사용 방법의 예는 다음과 같습니다.
$str = '2+2'; $result = calculator3($str); echo $result; // Output: 4
위 내용은 PHP에서 문자열로 전달된 수학 공식을 어떻게 안전하게 평가할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!