所以我遇到了一些障碍。我正在处理一个将图像文件上传到ftp的表单,并创建一个mysql条目,其中包含指向图像的链接以及用于组织和排序图像的列。
我收到以下错误:
您的SQL语法有错误;检查手册 对应于您的MySQL服务器版本,以便使用正确的语法 靠近'order)VALUES('','../tattoo / 1.jpg','6')'在第1行
我试过放置''围绕值而不是我仍然得到相同的消息。我确定解决方案很简单,我只是累了,并且一直盯着它看。这是代码
<?php
// Configuration - Your Options
$allowed_filetypes = array('.jpg','.gif','.bmp','.png'); // These will be the types of file that will pass the validation.
$max_filesize = 524288; // Maximum filesize in BYTES (currently 0.5MB).
$upload_path = '../tattoo/'; // The place the files will be uploaded to.
$filename = $_FILES['userfile']['name']; // Get the name of the file (including file extension).
$ext = substr($filename, strpos($filename,'.'), strlen($filename)-1); // Get the extension from the filename.
// Check if the filetype is allowed, if not DIE and inform the user.
if(!in_array($ext,$allowed_filetypes))
die('The file you attempted to upload is not the proper format, please submit a .jpg, .gif, .bmp, or .png');
// Now check the filesize, if it is too large then DIE and inform the user.
if(filesize($_FILES['userfile']['tmp_name']) > $max_filesize)
die('The file you attempted to upload is too large. Max file size is 0.5MB');
// Check if we can upload to the specified path, if not DIE and inform the user.
if(!is_writable($upload_path))
die('You cannot upload to the specified directory, please CHMOD it to 777.');
// Upload the file to your specified path.
if(move_uploaded_file($_FILES['userfile']['tmp_name'],$upload_path . $filename))
echo 'Your file upload was successful, view the file <a href="' . $upload_path . $filename . '" title="Your File">here</a><p>'; // It worked.
else
echo 'There was an error during the file upload. Please try again.'; // It failed :(.
// Add picture listing to mysql
//Include database connection details
include('config.php');
//Connect to mysql server
$mysql = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_DATABASE);
if(!$mysql) {
die('Failed to connect to server: ' . mysql_error());
}
mysql_select_db("sonyaopal", $mysql) or die( "Unable to select database" . mysql_error());
$result = mysql_query ( "SELECT count(*) from tattoos" );
$location = '' . $upload_path . $filename . '';
$order = $result+1;
$insListing_sql = "INSERT INTO tattoos (id, location, order) VALUES('',
'".mysql_real_escape_string("$location")."',
'".mysql_real_escape_string("$order")."')";
$insListing_res = mysql_query($insListing_sql, $mysql)
or die(mysql_error($mysql));
?>
答案 0 :(得分:0)
您可以编辑以下代码并尝试:
<?php
//getting the filename of the image file.
$filename = $_FILES["image"]["name"];
//directory name to be stored.
$path = "data/mydata";
//uploading the image file with the image file name into the directory.
if(move_uploaded_file($_FILES["image"]["tmp_name"],$path."/".$filename) {
//if the image is stored success into the directory then we are going to store into database.
//the real path with the filename.
$mysql_path = $path."/".$filename;
//sql query to be executed.
$sql = "INSERT INTO `tablename`(`filename`,`path`) VALUES ('$filename','$mysql_path')";
//executing the query.
if(mysql_query($sql)) {
echo 'path inserted into database';
}
else {
echo 'path not inserted into database';
}
}
else {
echo 'file not uploaded';
}
?>
错误发生在您的INSERT QUERY中您是否手动运行查询并检查..