我正在尝试使用Silex创建REST API。它工作得很好,但现在我想使用会话变量来跟踪用户。我曾尝试使用常规的php会话变量和SessionServiceProvider。对于我的生活,会话变量不会持续超过页面请求。查看我的临时会话文件夹,似乎正在为每个请求创建一个新会话。
所以我在index.php文件中包含了许多php文件,其中初始化了$ app?我不确定这是否与它有任何关系,但它可能会理解后面的代码正在做什么。
的index.php
<?php
require_once 'vendor/autoload.php';
$config['displayErrorDetails'] = true;
$app = new Silex\Application();
$app->register(new Silex\Provider\SessionServiceProvider, array('session.storage.save_path' => dirname(__DIR__) . '/tmp'));
$app->before(function() use ($app){
$app['session']->start();
});
require "../apiSource/classes/employees.php";
$app->run();
employees.php
<?php
use Symfony\Component\HttpFoundation\JsonResponse as JsonResponse;
use Symfony\Component\HttpFoundation\Request as Request;
class Employees
{
private $database;
function __construct()
{
$this->database = getDB();
}
function loginEmployee($loginInfo, $app){
//.... check loginInfo with database of employee ....///
if ($isEmployee) {
$app['session']->set('userID', $employee['e_ID']);
return array('success' => 'success', 'e_ID' => $employee['e_ID'], 'session' => $app['session']->get('userID'));
//SUCCESS
} else {
return array('message' => 'Error.');
}
}
function isLoggedIn($app){
$stmt = $this->database->prepare("SELECT e_ID, e_Email FROM Employee WHERE e_ID = ?");
$stmt->execute(array($app['session']->get('userID')));
$employee = $stmt->fetch(PDO::FETCH_ASSOC);
if(empty($employee)){
return array('Error' => $employee, 'Session' => $app['session']->get('userID'));
}
return $employee;
}
function logout($app){
$app['session']->remove('userID');
return array('success' => 'success');
}
}
$app->get('/employees/logout', function() use ($app) {
$employees = new Employees();
$results = $employees->logout($app);
return new JsonResponse($results);
});
$app->get('/employees/status', function() use ($app) {
$employees = new Employees();
$results = $employees->isLoggedIn($app);
return new JsonResponse($results);
});
$app->post('/employees/login', function(Request $request) use ($app) {
$data = json_decode($request->getContent(), true);
$request->request->replace(is_array($data) ? $data : array());
$employee = new Employees();
$results = $employee->loginEmployee($data, $app);
return new JsonResponse($results);
});
当我的Angular应用发布了对&#39; {url} / employees / login&#39;会话变量已设置,它确实返回会话[&#39; userID&#39;]。但是,如果在此之后我打电话给&#39; {url} / employees / status&#39;要查看用户是否已登录,会话变量为空。在保存会话变量的tmp文件夹中,我可以看到为每个请求创建的新文件。
我做错了什么?任何帮助将不胜感激。
谢谢!
修改
我已经尝试过简化这里的事情,看看发生了什么。它必须与我的角度页面发布和展示我的意思。
的index.php
$app->get('/hello', function () use ($app){
session_start();
$num = $_SESSION['idea'] ? $_SESSION['idea'] : 1;
$_SESSION['idea'] = $num+1;
echoResponse(200, $_SESSION['idea']);
});
如果我只是访问该页面并继续点击刷新,我的会话变量正在工作,并且它一直在上升。因此会话变量正在运行。
然而,当我尝试从我的角度应用程序调用此页面时:
$scope.hello = function(){
$http.get('https://viromo.com/cubex/api/hello').then(function(results){
console.log(results);
})
};
结果不断发布相同的数字而不增加。不知道为什么会这样。我更新了标题和标签,以更好地反映我的问题目标。
谢谢!