php - 忽略 PHP Web 服务中的 fatal error 和数据库异常

标签 php web-services error-handling

我有一个用 PHP 编写的 Web 服务,它返回 JSON 结果。它运行良好,并且已经过彻底测试。

我需要将日志记录添加到服务调用(谁调用以及何时调用)。我使用 SQLite 数据库(对于非常少量的数据)和 PDO 实现了这一点。日志记录的一个条件是它不应该损害 Web 服务本身。我正在记录他的调用这一事实对用户来说并不重要,记录过程中的任何错误也不应该阻止任何服务调用。

我实现了一个 Log 类和一个需要 SQL 字符串的“执行”函数:

    function __construct() {
        $this->dbConn = 'sqlite:' . realpath("myLog.sqlite");
        try {
            $this->db = new PDO($this->dbConn);
        }
        catch (PDOException $e) {
            //I don't care
        }
    }

    private function execute($sql) {
        try {
            $query = $this->db->prepare($sql);
            $query->execute();  
        }
        catch(Exception $e) {
            //I don't care
        }
    }

然后我在每个服务函数的末尾添加了一个类似于这样的调用:
$sql = "INSERT INTO $table(id, Time) VALUES('$id', datetime('now','localtime'))";
$this->execute($sql);

$jsonResult = doSomething($id);
return $jsonReuslt;

问题是:有时,我在客户端上收到一个包含 fatal error 字符串的字符串(指向此行 $query->execute() ),说它不是对象。

到目前为止,在所有情况下,我都将其追溯到错误的 SQL 查询。但是我需要一种方法来确保返回原始 JSON,即使日志记录函数中存在错误。

当我调用 $this->execute($sql) 时,如何确保无论发生什么? - $jsonResult 将返回实际的 JSON 结果?

TIA,
盖伊

最佳答案

在执行之前测试准备查询的结果 - 如果无法成功准备语句,server will return false (或抛出异常)。

$query = $this->db->prepare($sql);
if ($query)
    $query->execute();

关于php - 忽略 PHP Web 服务中的 fatal error 和数据库异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3964616/

相关文章:

c# - 如何使用 Web 服务正确抛出和处理异常

c++ - 从 Webservice 访问 C++ COM dll

perl - 如何从Moose构造函数报告错误?

ruby-on-rails - 救援中的 DRY 代码 => Rails 中各种模型文件中的 e

php - CKeditor 删除多余的空格

javascript - 如何从jquery获取数据字段动态数据

php - 如何在 Laravel 5.2 中获取列类型?

java - 访问 Restful Web 服务时出现 404 错误

Python:抛出异常或返回无?

PHPUnit 段错误