我发不了数据,测试用的是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, Response $response, array $args)
{
$db = $this->db;
$insertData = ['router' => 'testRouter2', 'show_name' => 'test2', 'is_lv_one_menu' => 'N'];
$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);
}
}