如何在php slimframwork中插入包含非英文字母的数据
我正在使用PHP slim框架开发API。我可以获取和删除,但随着插入(POST)和更新(PUT),我面临着问题如何在php slimframwork中插入包含非英文字母的数据,php,mysql,slim,Php,Mysql,Slim,我正在使用PHP slim框架开发API。我可以获取和删除,但随着插入(POST)和更新(PUT),我面临着问题 class db { //Propertise private $dbhost = 'localhost'; private $dbuser = 'root'; private $dbpass = ''; private $dbname = 'bralivnara-api'; //
class db {
//Propertise
private $dbhost = 'localhost';
private $dbuser = 'root';
private $dbpass = '';
private $dbname = 'bralivnara-api';
//Connect
public function connect(){
try {
$options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8', 'CHARSET utf8');
$dbConnection = new PDO("mysql:host=$this->dbhost;dbname=$this->dbname;", $this->dbuser, $this->dbpass, $options);
// set the PDO error mode to exception
$dbConnection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
//echo "Connected successfully";
}
catch(PDOException $e)
{
echo "Connection failed: " . $e->getMessage();
}
return $dbConnection;
}
}
当我使用rest easy时,我收到500错误
Response Status: 500 (Internal Server Error)
当我在浏览器中传递URL并按enter键时,它会显示错误
Connection failed: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'add' at line 1
在我对瑞典语字母也有异议之前,它并没有正确地显示在浏览器中。如果任何人有相同的问题,您可以使用该标题修复此问题。它适用于所有非英语字母
return $response->withStatus(200)
->withHeader('Content-Type', 'application/json;charset=utf-8;')
->write(json_encode($tranasVcDatainsamling, JSON_UNESCAPED_UNICODE));
如果您想查看完整的get代码,可以加入我们的讨论
现在剩下的最后一个问题是插入数据库。下面是插入数据库的代码
$app->post('/api/tranas-vc/add', function (Request $request, Response $response){
$besöksdatum = $request->getParam('besöksdatum');
$kön = $request->getParam('kön');
$ålder_år = $request->getParam('ålder_år');
$sökorsak = $request->getParam('sökorsak');
$vp_objektiv_prio = $request->getParam('vp_objektiv_prio');
$vp_objektiv_variabel_med_högst_prio = $request->getParam('vp_objektiv_variabel_med_högst_prio');
$vp_mätning_prio = $request->getParam('vp_mätning_prio');
$vp_mätning_variabel_med_högst_prio = $request->getParam('vp_mätning_variabel_med_högst_prio');
$ess_val = $request->getParam('ess_val');
$prio_ess = $request->getParam('prio_ess ');
$prio_total = $request->getParam('prio-total');
$utskrivning_hänvisning_återbesök = $request->getParam('utskrivning_hänvisning_återbesök');
$åtgärd_remiss = $request->getParam('åtgärd_remiss');
$om_lab_vilka_prover = $request->getParam('om-lab-vilka-prover');
$sql = "INSERT INTO
`tranasvcdatainsamling`
(
`besöksdatum`,
`kön`,
`ålder_år`,
`sökorsak`,
`vp_objektiv_prio`,
`vp_objektiv_variabel_med_högst_prio`,
`vp_mätning_prio`,
`vp_mätning_variabel_med_högst_prio`,
`ess_val`,
`prio_ess`,
`prio_total`,
`utskrivning_hänvisning_återbesök`,
`åtgärd_remiss`,
`om_lab_vilka_prover`
)
VALUES
(
:`besöksdatum`,
:`kön`,
:`ålder_år`,
:`sökorsak`,
:`vp_objektiv_prio`,
:`vp_objektiv_variabel_med_högst_prio`,
:`vp_mätning_prio`,
:`vp_mätning_variabel_med_högst_prio`,
:`ess_val`,
:`prio_ess`,
:`prio_total`,
:`utskrivning_hänvisning_återbesök`,
:`åtgärd_remiss`,
:`om_lab_vilka_prover`
)";
try {
// Get DB Objects
$db = new db();
// Connect
$db = $db->connect();
// Execute Query
$stmt = $db->prepare($sql);
$stmt->bindParam(':besöksdatum', $besöksdatum);
$stmt->bindParam(':kön', $kön);
$stmt->bindParam(':ålder_år', $ålder_år);
$stmt->bindParam(':sökorsak', $sökorsak);
$stmt->bindParam(':vp_objektiv_prio', $vp_objektiv_prio);
$stmt->bindParam(':vp_objektiv_variabel_med_högst_prio', $vp_objektiv_variabel_med_högst_prio);
$stmt->bindParam(':vp_mätning_prio', $vp_mätning_prio);
$stmt->bindParam(':vp_mätning_variabel_med_högst_prio', $vp_mätning_variabel_med_högst_prio);
$stmt->bindParam(':ess_val', $ess_val);
$stmt->bindParam(':prio_ess', $prio_ess);
$stmt->bindParam(':prio_total', $prio_total);
$stmt->bindParam(':utskrivning_hänvisning_återbesök', $utskrivning_hänvisning_återbesök);
$stmt->bindParam(':åtgärd_remiss', $åtgärd_remiss);
$stmt->bindParam(':om_lab_vilka_prover', $om_lab_vilka_prover);
$stmt->execute();
echo '{"notice": {"text": "Tranås VC Entry Added"}';
} catch(PDOEception $e) {
echo '{"error": {"text": '.$e->getMessage().'}';
}
});
我们对该代码做了所有可能的实验,您可以在注释中看到这些建议,但在POST和PUT中仍然存在问题
我对$stmt->execute()进行了注释;为了停止查询和检查的执行,我在RESTEasy中成功了200次,但没有插入数据。我认为错误是一样的。这表明问题正在执行中。我检查了英文字母上的代码和数据,它正常工作了
我很确定我有这个问题是因为瑞典语字母,它不是英语
我把那些包含瑞典语字母的列作为数据库
kön varchar(125) latin1_swedish_ci
sökorsak varchar(125) latin1_swedish_ci
这是拉丁文,我想让你也考虑一下。
我将感谢您的帮助,并请加入本次讨论。如果我们解决这个问题,这将是一个非常好的研究非英语字母的问题。我几乎搜索了一整天,但没有找到解决方案。您已经使用了
设置名称
,这是正确的方法,但您需要将utf8
括在一个引号内
SET name'charset\u name'[COLLATE'collation\u name']
不知道php/mysql是如何处理这样的字符的,我们可以看看您收到的错误吗?@ziaullahzia使用一个编码为UTF8 general ci的数据库,您可以添加所有语言。使用utf8\u编码utf8\u解码。当做您应该避免在任何非ascii的文件中使用POST参数。表中的字段也是如此。您可以插入非ascii的数据,但是构造应该遵循更严格的模式。您的
错误\u log
说是什么导致了500?如@delboy1978uk所说的任何日志错误,任何来自MYSQL PHP Apaches或Ngix的错误。。。
$options = array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8'", 'CHARSET utf8');
^ ^