这是我的 Index.php 文件:
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;
require '../vendor/autoload.php';
require '../src/config/db.php';
$app = new \Slim\App;
//User Routes
require '../src/routes/users.php'; // This not working
require '../src/routes/org.php'; // Only This working
$app->run();
.htaccess 文件
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^ index.php [QSA,L]
当只有一个需要的文件时,它工作正常,但是当添加两个或多个文件时,只有最后一个文件工作,其他文件给出页面未找到错误。我是 slim 和 PHP 的新手,所以我不知道出了什么问题。
users.php
<?php
/**
* User: y34h1a
* Date: 2/10/17
* Time: 3:47 AM
*/
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;
$app = new \Slim\App;
//Get All Customers
$app->get('/api/users', function (Request $request, Response $response){
$sql = "Select * from users";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->query($sql);
$users['users'] = $stmt->fetchAll(PDO::FETCH_OBJ);
$db = null;
echo json_encode($users);
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//GET SINGLE USER
$app->get('/api/user/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$sql = "Select * from users WHERE id = $id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->query($sql);
$user['user'] = $stmt->fetchAll(PDO::FETCH_OBJ);
$db = null;
echo json_encode($user);
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//ADD USER
$app->post('/api/user/add', function (Request $request, Response $response){
$name = $request->getParam('name');
$email = $request->getParam('email');
$password = $request->getParam('password');
$sql = "Insert into users(name,email, password) values (:name, :email, :password)";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->bindParam(':name', $name);
$stmt->bindParam(':email', $email);
$stmt->bindParam(':password', $password);
$stmt->execute();
echo '{"notice": {"text": "Customer Added"}}';
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//UPDATE USER
$app->put('/api/user/update/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$name = $request->getParam('name');
$email = $request->getParam('email');
$password = $request->getParam('password');
$sql = "UPDATE users SET
name = :name,
email = :email,
password = :password
WHERE id = $id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->bindParam(':name', $name);
$stmt->bindParam(':email', $email);
$stmt->bindParam(':password', $password);
$stmt->execute();
echo '{"notice": {"text": "Customr UPDATED"}}';
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//DELETE USER
$app->get('/api/user/delete/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$sql = "DELETE FROM users WHERE id = $id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->execute();
$db = null;
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
org.php
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;
$app = new \Slim\App;
//Get All Orgs
$app->get('/api/orgs', function (Request $request, Response $response){
$sql = "Select * from org";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->query($sql);
$users['orgs'] = $stmt->fetchAll(PDO::FETCH_OBJ);
$db = null;
echo json_encode($users);
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//GET SINGLE ORG
$app->get('/api/org/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$sql = "Select * from org WHERE id = $id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->query($sql);
$user['org'] = $stmt->fetchAll(PDO::FETCH_OBJ);
$db = null;
echo json_encode($user);
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//ADD ORG
$app->post('/api/org/add', function (Request $request, Response $response){
$user_id = $request->getParam('user_id');
$name = $request->getParam('name');
$address = $request->getParam('address');
$sql = "Insert into org(user_id, name, address) values (:user_id, :name, :address)";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->bindParam(':user_id', $user_id);
$stmt->bindParam(':name', $name);
$stmt->bindParam(':address', $address);
$stmt->execute();
echo '{"notice": {"text": "Organization Added"}}';
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//UPDATE ORG
$app->put('/api/org/update/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$name = $request->getParam('name');
$address = $request->getParam('address');
$sql = "UPDATE org SET
name = :name,
address = :address
WHERE id = $id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->bindParam(':name', $name);
$stmt->bindParam(':address', $address);
$stmt->execute();
echo '{"notice": {"text": "Organization Deleted"}}';
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
//DELETE ORG
$app->delete('/api/org/delete/{id}', function (Request $request, Response $response){
$id = $request->getAttribute('id');
$user_id = $request->getParam('user_id');
$org_id = $request->getParam('org_id');
$sql = "DELETE FROM org WHERE id = $id AND user_id = $user_id";
try{
//Get DB Object
$db = new db();
//Connect
$db = $db->connect();
$stmt = $db->prepare($sql);
$stmt->execute();
$db = null;
echo '{"notice": {"text": "Sheet Deleted"}}';
}catch(PDOException $e){
echo '{"error":{"text":'.$e->getMessage().'}';
}
});
最佳答案
好的,您的问题是您基本上创建了三个应用程序实例:一个在 index.php
中,一个在 users.php
中,一个在 org 中。 php
.
应用实例由
创建$app = new \Slim\App;
该应用程序由 $app->run
启动。
在 index.php
中你有 $app
,它被 users.php
中的 $app
覆盖, 然后被 org.php
中的 $app
覆盖。
这就是为什么 require '../src/routes/users.php';
似乎被忽略的原因 - 它声明 $app
,添加路由并在覆盖 $app
并添加路由的下一个文件。
要解决这个问题,只需删除
$app = new \Slim\App;
除了 index.php
之外的任何地方。
关于php - 将路由组织成单独的文件,在 Slim 中无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42174121/