我正在使用MYSQL
数据库从我的iOS
应用中将图片存储到其中。我使用base64encoding
和解码技术来存储图像。
的问题:
它将名称存储在数据库中作为字符串即可。但它不是将图像存储在htdocs文件夹中。我的问题在哪里以及如何解决?
php代码:
<?PHP
$host='localhost';
$name='root';
$pwd='';
$db='i';
$conn=mysql_connect($host,$name,$pwd);
mysql_select_db($db,$conn);
if($conn)
{ $image=$_POST['image_string'];
if($image!='')
{
$img = @imagecreatefromstring(base64_decode($image));
if($img != false)
{
imagejpeg($img, "htdocs/".$image."");}
}
$qur=mysql_query("INSERT INTO `j` (`id`, `name`) VALUES (NULL, '$image')");
if($qur)
{
echo "inserted";
}
else
{
echo mysql_error();
}
}
?>
客户端代码:
NSData *imageData=UIImagePNGRepresentation(_imageView.image);
NSString *string;
if([imageData respondsToSelector:@selector(base64EncodedStringWithOptions:)])
{
NSLog(@"iOS 7+");
string=[imageData base64EncodedStringWithOptions:kNilOptions];
}
else
{
string=[imageData base64Encoding];
}
NSString *post=[[NSString alloc]initWithFormat:@"image_string=%@",string];
post = [post stringByReplacingOccurrencesOfString:@"+" withString:@"%2B"];
NSURL *url=[[NSURL alloc]initWithString:@"http://localhost/lastImage.php"];
NSData *postDAta=[post dataUsingEncoding:NSUTF8StringEncoding];
NSString *postlength=[NSString stringWithFormat:@"%lu",(unsigned long)[postDAta length]];
NSMutableURLRequest *request=[[NSMutableURLRequest alloc]init];
[request setURL:url];
[request setHTTPMethod:@"POST"];
[request setValue:postlength forHTTPHeaderField:@"Content-length"];
[request setValue:@"application/json" forHTTPHeaderField:@"Accept"];
[request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
[request setHTTPBody:postDAta];
NSError *error = [[NSError alloc] init];
NSHTTPURLResponse *response = nil;
NSData *urlData=[NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];
答案 0 :(得分:1)
首先检查您要保存的目录是否具有写入权限。
然后尝试:
imagejpeg($img, $_SERVER['DOCUMENT_ROOT'] . "/image_name.jpg");