A place for users and developers of the Xataface to discuss and receive support.
by ADobkin » Mon Oct 29, 2007 11:16 am
I followed the instructions in the "How to handle file uploads" doc, and I created LONGBLOB fields for my files, mainly PDF and TIFF in this case. As soon as I tried to upload a "large" file (only 1 MB), there was a bunch of binary data dumped to the client browser, and the following error appeared in the web server logs:
PHP Fatal error: Failed to update due to sql error: Got a packet bigger than 'max_allowed_packet' bytesOn line 577 of file /var/www/html/dataface-0.7.1/Dataface/IO.php in function print
According to the MySQL manual: The server's default max_allowed_packet value is 1MB. You can increase this if the server needs to handle big queries (for example, if you are working with big BLOB columns).
http://dev.mysql.com/doc/refman/5.0/en/ ... large.html
Could this value be set somewhere in Dataface, such as conf.ini or index.php, rather than changing it for the whole MySQL server? Either way, this information should probably be added to the "How to handle file uploads" doc for future reference....
Thanks,
Alan
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by shannah » Mon Oct 29, 2007 11:36 am
Another note. When I first created dataface I decided it was important to incorporate the ability to work with BLOB fields nicely. However most people advocate using the Container method for storing files. (i.e. you store the path of the file in the DB, but the actual file is stored on the file system).
Using blob fields currently has some security benefits, but the container method has performance benefits.
Just a note.
-Steve
-
shannah
-
- Posts: 4457
- Joined: Wed Dec 31, 1969 5:00 pm
by ADobkin » Mon Oct 29, 2007 12:10 pm
Perfect, thanks.
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by ADobkin » Mon Oct 29, 2007 12:23 pm
Thanks for the note. The fact that things work so nicely with BLOB fields (and probably containers too) in Dataface is one of the things that really amazes me about it. I uploaded a TIFF, and it automatically displayed the preview image in both the edit and the details views. (BTW, this didn't work some other browsers however, probably due to lack of a TIFF viewer or MIME type problem, I'm not sure.) Anyway, these automatic functions are really a pleasure to work with.
I did give some thought to BLOB vs. container, especially because the statement you made in your how to document was exactly how I felt:
One thing that may scare you about storing files in the database is that they may seem less accessible than if they were on the file system.
However, I thought it would be easier to have everything in one place, rather than have to maintain a separate file system with accurate pointers in the database, and hope that nothing gets moved or deleted. (I assume deleting a record requires you to manually delete the file to avoid leaving an "orphan" and vice-versa.) Performance may be an issue though, so I may change my mind down the road, and hopefully it won't be too difficult to migrate if necessary.
Thanks,
Alan
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by ADobkin » Mon Oct 29, 2007 4:05 pm
FYI, this didn't work for me. I have the following in my conf/ApplicationDelegate.php file:
- Code: Select all
function getPreferences(){ mysql_query("SET SESSION max_allowed_packet=16777216", df_db()); }
It generates the following error on top of my pages and leaves out most of the page navigation widgets: - Code: Select all
Warning: array_merge() [function.array-merge]: Argument #2 is not an array in /var/www/html/dataface-0.7.1/Dataface/Application.php on line 712
Alan
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by shannah » Mon Oct 29, 2007 4:18 pm
Sorry, didn't realize that you weren't already using a getPreferences() method.
The getPreferences() method must return an array.
so just add
- Code: Select all
return array();
to the end of it.
-
shannah
-
- Posts: 4457
- Joined: Wed Dec 31, 1969 5:00 pm
by ADobkin » Mon Oct 29, 2007 5:44 pm
My bad, I should have realized that. Thanks, it works now.
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by ADobkin » Tue Nov 13, 2007 5:33 am
I understand the performance benefits with the container method, but I initially didn't realize what you meant about the security benefits with blob fields in this statement:
[quote="shannah"]Using blob fields currently has some security benefits, but the container method has performance benefits.
I've since done some experimenting with both methods, and I've noticed that the container method basically requires that all of the files have public access. In other words, if we use the container method, there is essentially no security. As long as users know (or can guess) the filename, they can access it directly through the web server, and any application security built-in to Dataface is bypassed. Is this correct? If so, you may want to point this out in the "How to handle file uploads" document, since this could be a big issue for some people.
That being the case, I think I will suffer any performance implications of the blob fields and keep everything in the database for now.
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by ADobkin » Tue Nov 13, 2007 5:42 am
The "How to handle file uploads" document specifies that BLOB fields be defined with the LONGBLOB data type. This type allows for files to be stored in the database with a maximum size of 4GB! I have smaller requirements and want to increase performance as much as possible. Will Dataface recognize and function the same way with regular BLOB (up to 64K) or MEDIUMBLOB (up to 16M) data types also?
-
ADobkin
-
- Posts: 195
- Joined: Mon Oct 22, 2007 7:31 pm
- Location: Atlanta, GA, USA
by shannah » Tue Nov 13, 2007 9:04 am
Yes. It will recognize any blob field type.
-Steve
-
shannah
-
- Posts: 4457
- Joined: Wed Dec 31, 1969 5:00 pm
Return to Xataface Users
Who is online
Users browsing this forum: No registered users and 26 guests
|