我正在尝试将图像文件上传到我的 MySql 数据库。我已经在网上搜索了,我终于开始使用以下脚本:
if(is_uploaded_file($_FILES['filename']['tmp_name'])){
$maxsize=$_POST['MAX_FILE_SIZE'];
$size=$_FILES['filename']['size'];
// getting the image info..
$imgdetails = getimagesize($_FILES['filename']['tmp_name']);
$mime_type = $imgdetails['mime'];
// checking for valid image type
if(($mime_type=='image/jpeg')||($mime_type=='image/gif')||($mime_type=='image/png')){
// checking for size again
if($size<$maxsize){
$filename=$_FILES['filename']['name'];
$imgData =addslashes (file_get_contents($_FILES['filename']['tmp_name']));
if(is_uploaded_file($_FILES['filename']['tmp_name'])){
debug('subida ok');
}else{
debug('fallo subida');
}
//echo $imgData;
$imgDetail=addslashes($imgdetails[3]);
$db = new mysqli('127.0.0.1','user','pass', 'db');
if($db->connect_error){
debug('Error en la conexion : '.$db->connect_errno.
'-'.$db->connect_error);
}
$stmt = $db->stmt_init();
$stmt->prepare("INSERT INTO `image` (`name`, `image`, `type`, `size`) VALUES (?, ?, ?, ?)");
if($stmt===false){ debug('Error en prepare');}
$rc=$stmt->bind_param('sbss', $filename, $imgData, $mime_type,$imgDetail);
if($rc===false){ debug('Error en bind');}
if($stmt->execute()==false){ debug('error ' . $stmt->error); };
$stmt->close();
}else{
debug("<font class='error'>Image to be uploaded is too large..Error uploading the image!!</font>");
}
}else{
debug("<font class='error'>Not a valid image file! Please upload jpeg or gif image.</font>");
}
}else{
switch($_FILES['filename']['error']){
case 0: //no error; possible file attack!
debug("<font class='error'>There was a problem with your upload.</font>");
break;
case 1: //uploaded file exceeds the upload_max_filesize directive in php.ini
debug( "<font class='error'>The file you are trying to upload is too big.</font>");
break;
case 2: //uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the html form
debug( "<font class='error'>The file you are trying to upload is too big.</font>");
break;
case 3: //uploaded file was only partially uploaded
debug( "<font class='error'>The file you are trying upload was only partially uploaded.</font>");
break;
case 4: //no file was uploaded
debug( "<font class='error'>You must select an image for upload.</font>");
break;
default: //a default error, just in case!
debug( "<font class='error'>There was a problem with your upload.</font>");
break;
}
}
上传的图像似乎是 find 照顾脚本输出,但查看数据库大小是 0 字节... 有人知道这是为什么吗?
最佳答案
mysqli SEND_LONG_DATA()!!!
http://php.net/manual/en/mysqli-stmt.send-long-data.php
对于某些 php/mysql(特别是 mysqli 库)服务器设置,Blob 似乎特别令人沮丧。该解决方案似乎在配置设置无法解决问题的情况下始终有效。如果重新实现很头疼,我建议使用 PDO。
关于php - mysqli 图像 blob 插入不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19863370/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我有带有Logo图像的公司模型has_attached_file:logo我用他们的Logo创建了许多公司。现在,我需要添加新样式has_attached_file:logo,:styles=>{:small=>"30x15>",:medium=>"155x85>"}我是否应该重新上传所有旧数据以重新生成新样式?我不这么认为……或者有什么rake任务可以重新生成样式吗? 最佳答案 参见Thumbnail-Generation.如果rake任务不适合你,你应该能够在控制台中使用一个片段来调用重新处理!关于相关公司
使用Ruby1.9.2运行IDE提示说需要gemruby-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall
我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的
我正在尝试使用Ruby2.0.0和Rails4.0.0提供的API从imgur中提取图像。我已尝试按照Ruby2.0.0文档中列出的各种方式构建http请求,但均无济于事。代码如下:require'net/http'require'net/https'defimgurheaders={"Authorization"=>"Client-ID"+my_client_id}path="/3/gallery/image/#{img_id}.json"uri=URI("https://api.imgur.com"+path)request,data=Net::HTTP::Get.new(path
2022/8/4更新支持加入水印水印必须包含透明图像,并且水印图像大小要等于原图像的大小pythonconvert_image_to_video.py-f30-mwatermark.pngim_dirout.mkv2022/6/21更新让命令行参数更加易用新的命令行使用方法pythonconvert_image_to_video.py-f30im_dirout.mkvFFMPEG命令行转换一组JPG图像到视频时,是将这组图像视为MJPG流。我需要转换一组PNG图像到视频,FFMPEG就不认了。pyav内置了ffmpeg库,不需要系统带有ffmpeg工具因此我使用ffmpeg的python包装p