PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了PHP-将路线整理到单独的文件中,这些文件在Slim中无法正常工作大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

这是我的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]

当只有一个需求文件时,它工作正常,但是当添加两个或多个文件时,只有最后一个工作,而其他文件却找不到页面错误.我是苗条和PHP的新手,所以@R_99_6618@了.

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覆盖.

这就是为什么需要’../src/routes/users.PHP’的原因;似乎被忽略了-它在声明$app,添加路由,在下一个文件中,您覆盖$app并添加路由.

解决此问题,只需删除

$app = new \Slim\App;

除index.PHP外,其他任何地方都可以.

大佬总结

以上是大佬教程为你收集整理的PHP-将路线整理到单独的文件中,这些文件在Slim中无法正常工作全部内容,希望文章能够帮你解决PHP-将路线整理到单独的文件中,这些文件在Slim中无法正常工作所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: