如何解决PHP Slim v3 post 方法 405使用 POSTMAN 测试!
我发不了数据,测试用的是POSTMAN,测试代码:
<?php
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;
require '../vendor/autoload.php';
require '../config/config.php';
$app = new Slim\App(['settings' => $config]);
$container = $app->getContainer();
$container['db'] = function ($c) {
$db = $c['settings']['db'];
$pdo = new PDO('mysql:host=' . $db['host'] . ';dbname=' . $db['dbname'],$db['user'],$db['pass']);
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE,PDO::FETCH_ASSOC);
return $pdo;
};
$app->post('api/menu-list',function (Request $request,Response $response,array $args) {
$db = $this->db;
$insertData = [
'router' => $args['rouster'],'show_name' => $args['show_name'],'is_lv_one_menu' => $args['is_lv_one_menu']
];
$query = "INSERT INTO menu_list (router,show_name,is_lv_one_menu) VALUES (:router,:show_name,:is_lv_one_menu)";
try {
$db->prepare($query)->execute($insertData);
$response->getBody()->write('Data success,the insert id is : ' . $db->lastInsertId());
} catch (Exception $e) {
$response->getBody()->write('Data insert error,take look : ');
$response->getBody()->write($e);
}
});
邮递员截图在这里:
也许问题不是apache,有什么帮助吗?谢谢。
编辑:
我不知道发生了什么,我修复了args,问题消失了,插入成功。
function (Request $request,array $args)
{
$db = $this->db;
$insertData = ['router' => 'testRouter2','show_name' => 'test2','is_lv_one_menu' => 'N'];
$query = "INSERT INTO menu_list (router,take look : ');
$response->getBody()->write($e);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。