1

我正在构建一个 API,但是在使用 JWT 创建令牌时出现未捕获错误,当我运行 post man 调用时,我进入错误日志堆栈跟踪:

#0 [internal function]: Api->generateToken()
#1 /home/osconliz/public_html/Osconlizapicall/rest.php(42): ReflectionMethod->invoke(Object(Api))
#2 /home/osconliz/public_html/Osconlizapicall/index.php(4): Rest->processApi()
#3 {main}
thrown in /home/osconliz/public_html/Osconlizapicall/api.php on line 36
[19-May-2018 02:04:47 UTC] PHP Fatal error:  Uncaught Error: Class 'JWT' not found in /home/osconliz/public_html/Osconlizapicall/api.php:36
Stack trace:
#0 [internal function]: Api->generateToken()
#1 /home/osconliz/public_html/Osconlizapicall/rest.php(42): ReflectionMethod->invoke(Object(Api))
#2 /home/osconliz/public_html/Osconlizapicall/index.php(4): Rest->processApi()
#3 {main}

但是当我在我的 PHP 服务器上检查我的 jwt 文件时,它里面有 JWT 类。

**jwt.php**带有类 jwt 屏幕截图的页面

然后我用来创建令牌的页面是**api.php**

//SECRETE_KEY 是用于为 JWT 创建通行证的常量

   <?php 
  class Api extends Rest {
    public $dbConn;  

     public function __construct(){
        parent::__construct();  
        $db = new DbConnect;
        $this->dbConn = $db->connect();

    }

    public function generateToken(){
        $client_id_key = $this->validateParameter('client_id_key', $this->param['client_id_key'], STRING);
        //$client_secret_key = $this->validateParameter('client_secret_key', $this->param['client_secret_key'], STRING);
        //client_secret_key should be commented out it is not used for validation for security purposes, only id key

        $stmt = $this->dbConn->prepare("SELECT * FROM `api_clients_properties` WHERE client_id = :client_id_key");
        $stmt->bindParam(":client_id_key", $client_id_key);
        $stmt->execute();
        $user = $stmt->fetch(PDO::FETCH_ASSOC);
        if (!is_array($user)){
            $this->returnResponse(API_NAME_REQUIRED, "Invalid Client Id Key");
        }

        if ($user['property_status'] == "not verified"){
           $this->returnResponse(API_NAME_REQUIRED, "Property not verified, please contact admin, to verify it");   
        }

        $payload = [
           'iat' => time(),
           'iss' => 'localhost',
           'exp' => time() + (60),
           'userId' => $user['id']
        ];
        $token = JWT::encode($payload, SECRETE_KEY);
        echo $token;
    }

  }

?>
4

2 回答 2

2

该类JWT位于 namespaceFirebase\JWT中,因此您将需要use它:

use \Firebase\Jwt\Jwt;
Jwt::encode(...);

或者在调用时使用它的完整命名空间:

\Firebase\Jwt\Jwt::encode();
于 2018-05-19T03:02:51.120 回答
1

如果您从 GitHub 复制文件而不是使用 composer 安装它,则需要注释掉文件顶部的命名空间行。因此,从我在屏幕截图第一行顶部的jwt.php快照中,您将注释掉//namespace Firebase\JWT;,您将不会再次收到 500 内部服务器错误。

于 2018-05-19T15:52:59.343 回答