-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PDF files not uploading with PHP 7 and Joomla 3.7.2 #16238
Comments
Can't confirm, test using PHP 7.0.15 and 7.1.1. System information3.7.3-dev MAMP 4.1.1
|
I cannot replicate this at all.
|
Cannot replicate:
|
I also couldn't replicate this issue, pdf uploaded without errors. |
PHP 7.0.18 we're having this issue - "fileinfo.so" php extension was disabled in server. maybe a more informative error message would help debuging issue adding something like "Could not detect the file mime type. Please check with your host if you have fileinfo PHP extension enabled.". anyway with php fileinfo extension enabled cannot replicate the issue. |
My fileinfo extension is enabled. |
Confirmed issue on Rochen server: PHP Built On Linux impress51.directrouter.com 3.10.0-427.36.1.lve1.4.43.el7.x86_64 #1 SMP Wed Mar 29 16:13:25 EDT 2017 x86_64 |
@zero-24 Since |
Update from Rochen -- After telling me that fileinfo and mime_content_type were enabled, they were able to get the PDF upload working under PHP 5.6. (In the control panel, go to PHP version and switch it.) However, a second support person has come back to me after that change was made. He switched PHP 5.6 back to PHP 7.0. The PDF upload now works. He says "I suppose it's possible that a needed PHP extension (like fileinfo) hadn't been selected previously, but the new defaults in the selector resolved the problem." So, suggestion for other Rochen people with this issue: a. log into cPanel If it IS checked, and you can't upload PDFs, then try: My guess is that "fileinfo" is showing as checked when it's not really set. |
Quy -- yes, that was my expectation for turning off the MIME type check. However, it had no effect on my ability/inability to upload a PDF. Fix (???) is listed in the post before this one. |
@jen4web My expectation too. The code has to be reworked to first check that |
@jen4web what error do you get when mime checking is disabled? As this should never be a option you should set. If you try to upload a file on a server where we can not check or detect the mime type we don't allow uploading it. The |
My issue is resolved at this point. However, when it was broken, I tried uploading the PDF with mime checking enabled and disabled. Error message was the same: Error |
Sure we can improve that message. But this means "We can not detect any mime type for that file so we don't allow uploading it" |
Here is the description for
getMimeType() should only be executed if |
The problem is that you do not get "invalid mime type error" (i have already sayed that the message needs to be inproved) you get the "mime type detection is not working on your system" error. Which IMO should be fixed on server side and not just ignored by the CMS. As this is a server / configuration error and not a CMS error ;). We maybe need a suggestion for a better error message in that case. |
Please take a look here: #16246 for a extended message. |
I am sorry but I cannot replicate this on our servers (PHP 7.1.14). Neither in default media manager nor in /TinyMCEJCE. I can upload pdf's either from frontend or admin without problems and if pdf's disabled (in media options) I do get the proper message (extension not supported) However: The pdf's show in the file system with FTP (after upload in the media manager but they do not show after upload in the media manager itself in the administrator (they are uploaded as stated since they show in the file manager with ftp) That only happens when uploaded in this case with Tiny/JCE but they show when uploaded with/in the admin panel in the media manager itself (!) so by using the media manager upload they show but when upload with any editor they don't show in the media manager in admin backend despite being listed in the file system (FTP) |
Sure the most of us can't as it looks like a server / hosting issue.
Please double check that. For the frontend |
For reference I have notified Rochen of this issue and they are investigating |
In general, things are working fine as long as the server is correctly configured. The issue we are running into it seems is that there are hosting environments (such as Rochen's) which are disabling features that are by default enabled in the baseline PHP distribution. So, we need to improve our handling a bit; though |
Any suggestions? |
@zero-24 I do disagree with you on upload pdf. Please read what I wrote. I can upload with JCE for instance and it is successful. However the pdf won't show in the media manager but is in the file system.... See images |
That modal is hardcoded to only display images, even if the upload was successful it will never display PDF files. |
and that is NOT a new thing - it has always been that way |
I get you but why not? If mime-types are supported they should show? |
@dstncz based on all our tests it does sound like they are correct |
I'm having a hard time tracking this down. In addition to our site at SG we are also experiencing this issue with 3 additional sites on a separate container hosted at PowerVPS. One of which has barely any extra extensions (3.7.1 with Akeeba Backup, Brute Force Stop, JCE & Rokcandy). I've tried disabling all the mentioned extensions and still get the mime error. Related: I've confirmed that fileinfo is enabled on this container as well with the host. Thought it might possibly be something with CXS, so fully disabled that. Still getting the error. Any ideas? |
I was able to resolve the issue on both our containers. For the sites running 3.7.1 upgrading to 3.7.2 fixed it. For the SG site, we restored to a backup of 3.7.1 then re-upgraded to 3.7.2. |
Joomla 3.7.2 with PHP 7.1.1 |
Joomla 3.8.0 with PHP 7.0.22 - same for PHP 7.1.7: Seems like upgrading from Joomla! 3.7.2 to 3.8.0 has reintroduced the Invalid mime type problem. This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/16238. |
BTW: This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/16238. |
Hi, i have similar problem. I have mime, fileinfo, etc... After trying to upload a PDF in media manager, even with check mime types OFF and PDF in excluded extension, even with application/octet-stream i receive this error: 0 - Invalid controller: name='file', format='html' I can't upload with Docman too... systeminfo-2017-11-30T14_47_16+00_00.txt EDIT: with K2 Media Manager i can upload without any problem! EDIT 2: If i try to upload with JCE File Browser i receive "The server returned an invalid JSON response." |
I think the problem could be alleviated by changing some of the code in the Media Helper canUpload() method, around lines 270 to 283 in libraries/src/Helper/MediaHelper.php in joomla 3.8. Change:
to
This means that if for some reason the MIME type can't be ascertained, the code checks if the user has Media "core.manage" access before it disallows the upload. So users with sufficient privilege can still do their job, without having to relax the Restrict Uploads setting. (It would also fix this problem). To my mind, this also fixes another inconsistency when the Restrict Uploads is set. When a user who doesn't have "core.manage" access tries to upload a non-image file – even though the file has a legal MIME type, the upload is still rejected because the user doesn't have "core.manage" privilege. Which doesn't in my opinion fit with the description of the Restrict Uploads setting "Restrict uploads for lower than manager users to just images if Fileinfo or MIME magic isn't installed.", in that it restricts it even if the system can determine the MIME type, and the file passes the legal MIME types check. |
Oddly enough, I've looked in many places and could not find answers that worked for me. Found this one below and it worked like a charm. Not sure why though...
Try uploading a pdf, that is what fixed it for me. This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/16238. |
@zero-24 Can this be closed? |
The work-around works, because it is negatively ignored as a media type. Since PDFs play an important role in SoHo site creations, e.g. for ideal communities, PDF as a mime type should be allowed per default. My recommendation would be for the Joomla core team to incorporate a fix into the next Joomla release to allow for PDFs. |
Thanks for your recomendation. PDF has been enabend per default for serveral releases. But for obius reasons we don't overwrite your settings using update ;-) This is more a issue with your server not beeing able to detect the file extension. To me it is the expected behavior that if a extension cant bee detected the upload fails (this is the reason i wrote the code this way) but I'm happy to get another opinions. Technical this is a broken server config and well we can implement workarrounds but they will all compromise Security.. |
In any case the setting "Check MIME Types" is not taken into account, so at least we should provide a fix for that, right? |
If the upload is always disallowed if the MIME type can't be determined, then in that case what does the config parameter Restrict Uploads mean? Its tooltip is "Restrict uploads for lower than manager users to just images if Fileinfo or MIME magic isn't installed". I think there's an inconsistency between the tooltip description of this config parameter and the actual coded functionality, and it would be helpful to fix this. |
@zero-24 I don't see |
Yes
On Thu, Mar 15, 2018 at 3:32 PM Quy ***@***.***> wrote:
@zero-24 <https://github.com/zero-24> Can this be closed?
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#16238 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ADwCKYnuL3y03QhLJ8NZl6F65BFnrSglks5tes-2gaJpZM4Nk8b9>
.
--
Best Regards,
Everett Alexander
------------------------------
*Moxy Mediaworks*
*http://www.moxymediaworks.com* <http://moxymediaworks.com>
|
Yes because anything that is not allowed is illegal ;) |
Then why have
According to the above description, this setting can be used to disable the invalid mime type errors, but that is not possible since it is performed after Shouldn't it be something like this?
|
Perhaps it's best to consider what the options should be, and ensure that the code then matches that. The fact that Fileinfo is now an inherent part of PHP has changed things a bit. I've documented below what the options tooltips are, and what I believe the functionality is in the code, as a starting point. Worth checking I've got it right! Restrict Uploads Check MIME Types Legal Image Extensions (File Types) Ignored Extensions Legal MIME Types Illegal MIME Types In addition there is the question of what should happen if the system can't determine the MIME type. At the moment, this results in an error if Restrict Uploads is set to Yes, regardless of whether Check MIME types option is set to Yes or No. |
It should include this condition Fileinfo or MIME Magic isn't installed. Please test PR #20156 to show/hide settings relating to restrict uploads. |
I'm not sure how relevant that condition Fileinfo or MIME Magic isn't installed is any longer. So I think that this is one reason why these tooltip descriptions would benefit from being updated. |
Several people in this thread have mentioned that they are using "mime magic".
Can we agree with this and not implement workarounds? Which tooltip to rephrase and to what? |
Here are some suggestions as a starter. Personally I would change some of the field names as well as the tooltips. I find it confusing having one field called Legal Extensions and another called Legal Image Extensions. I think that showing the latter only if Restrict Uploads is Yes will help to some extent. Suggestions for field name changes: Legal Image Extensions (File Types) - change to Unrestricted Extensions (File Types) Suggestions for tooltip descriptions: Restrict Uploads – If set to Yes, then users who have not got manager access are restricted to only a subset of the Legal Extensions which can be uploaded. They may only upload a file if its extension is in the specified Unrestricted Extensions or (if Check MIME Types is set to Yes) if its MIME type is in the specified Unrestricted MIME Types. Unrestricted Extensions – If Restrict Uploads is Yes, then this is the list of file extensions which any user may upload. Unrestricted MIME Types – If Restrict Uploads is Yes, then this is the list of MIME Types which any user may upload. |
Set to "closed" on behalf of @Quy by The JTracker Application at issues.joomla.org/joomla-cms/16238 |
Please test PR #25351 This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/16238. |
Steps to reproduce the issue
Go to: Content / Media
Click green Upload button, upload PDF file
Expected result
PDF file uploads without issue
Actual result
Error
Invalid mime type detected.
System information (as much as possible)
Site hosted at Rochen
Database Version 10.1.23-MariaDB
PHP Version 7.0.19
Web Server LiteSpeed
WebServer to PHP Interface litespeed
Joomla! Version Joomla! 3.7.2 Stable [ Amani ] 22-May-2017 09:46 GMT
Joomla! Platform Version Joomla Platform 13.1.0 Stable [ Curiosity ] 24-Apr-2013 00:00 GMT
I have disabled "check mime types" in the Media Options (click Options button from Media screen).
Legal MIME types: image/jpeg,image/gif,image/png,image/bmp,application/x-shockwave-flash,application/msword,application/excel,application/pdf,application/powerpoint,text/plain,application/x-zip
Legal extensions: bmp,csv,doc,gif,ico,jpg,jpeg,odg,odp,ods,odt,pdf,png,ppt,swf,txt,xcf,xls,BMP,CSV,DOC,GIF,ICO,JPG,JPEG,ODG,ODP,ODS,ODT,PDF,PNG,PPT,SWF,TXT,XCF,XLS
Additional comments
I have been uploading files through the Media Manager. JPG and PNG work, while PDF does not.
I reported this to Rochen, who confirmed that finfo_open and mime_content_type were installed, available, and working correctly.
Their response was this: "Well there seems to be compatibility issue with mime_content_type on Joomla version and PHP v7.0, If I switch the PHP version to v5.6 it is working fine.
It appears the patch provided isn't working on 3.7.1 and 3.7.2, due to mime_content_type. Thanks!"
Previously I was running PHP 7.0.19.
The text was updated successfully, but these errors were encountered: