Problems generating word documents on server side for security reasons


Posted on 16th Feb 2014 07:03 pm by admin

I have a problem with word documentation generation when generating a word document (docx) with PHP. I am doing this for security reasons, as I do not want people to be able to directly access a file with urls, so I store the files above the web root and they are generated on the server side on demand. Here is my code for manually testing file generation of a .docx file ( a Word 2007 file ):

$path = "../../uploads_productionization/file_for_category_1_tab_2/adsfdafds.docx

// We'll be outputting a docx
header( 'Content-type: application/vnd.openxmlformats & -officedocument.wordprocessingml.document.main+xml');

// It will be called downloaded.docx
header('Content-Disposition: attachment; filename="downloaded.docx"');

// The word source is in adsfdafds.docx
readfile($path);


When I execute this code, ie when I manually generate a docx file, I get two error messages:

"The Open Office XML document cannot be opened because there are problems with the contents"
Details: "File is corrupt and cannot be opened"

Next message:
"Word found unreadable content in downloaded.docx. Do you want to recover the contents of this document? If so, please click Yes"

When I click Yes on the second message, the document opens. Sometimes the file is okay, sometimes it isn't when there are pictures and formatting and so on and so forth.

Anyone have a solution for this problem? Been trying to get around this for at least a week...

P.S. All other files, PDFs, text files, work fine.. I think it's just office documents.

No comments posted yet

Your Answer:

Login to answer
214 Like 22 Dislike
Previous forums Next forums
Other forums

include
Hi I have this way of licensing my PHP application, and I want to know if you guys can answer some q

PHP and XML image gallery variable issue
I'm trying to display the large image on the same page as the thumbnails, to do that I'm passing a v

MSSQL/PHP
I am tryint to setup a webapplication developed in PHP, Apache2.0 and SQLServer2000 as backend which

Take info from one coloum and move to another
Hi all,

I have this:
Code: [Select]$array = "SELECT stock_id FROM stocks WHERE stock_

convert static html data into dynamic
hi all

i need to convert a website which has static above 2000 articles into dynamic and add

Multiple includes losing variables
Hey all,

just starting out w php and ran into a problem pretty quickly. I'm
including seve

Batch update record with Pagination
Hoping someone can help me with this issue I'm having, im trying to batch update records from a resu

Cant display mysql data
Hey all,

I am learning php and my first goal is to create a simple CMS. At the moment I am st

Can we convert non uni code system into unicode
Hi All,

Presently i am using non-unicode system and the sap version is 4.7.
Can i c

Pro-rata Billing in Periodic Billing for Rental
Hi guys,

We have a situation, where a rental contract starts at the mid of the month say

Sign up to write
Sign up now if you have flare of writing..
Login   |   Register
Follow Us
Indyaspeak @ Facebook Indyaspeak @ Twitter Indyaspeak @ Pinterest RSS



Play Free Quiz and Win Cash