user1176941
user1176941

Reputation: 141

Running libreoffice from php exec()

I have installed libreoffice headless on a freebsd-server with apache in order to convert documents programmatically (e.g. odt->pdf). It works from the command line! But my goal is to be able to do it from php. This demands that the web-user (www) can run libreoffice. But it cannot.

When running libreoffice as my own user, I get:

%libreoffice --headless -convert-to pdf Litteraturundervisningogit.doc
javaPathHelper: not found #This should not be a problem, says people on the net.
convert /usr/home/bundsgaard.net/www/jeppe/foredrag/Litteraturundervisningogit.doc ->
 /usr/home/bundsgaard.net/www/jeppe/foredrag/Litteraturundervisningogit.pdf using writer_pdf_Export
%

If I try the same command as root, it does not work. The same is the problem with the www-user from php:

sp# libreoffice --headless -convert-to pdf Litteraturundervisningogit.doc
javaPathHelper: not found
sp#

The problem is that I do not get any information from libreoffice, thus I don't know why libreoffice does not want to run as other users than my own.

My question is: How do I give the www-user permission to run libreoffice via exec() in php?

Upvotes: 14

Views: 18096

Answers (8)

Ramesh
Ramesh

Reputation: 1555

It is working for me.

You can convert docx to HTML by using libreoffice, You need to give proper permission output directory

exec("export HOME='/var/www/html/wp/wp-content/uploads/' && /usr/bin/libreoffice --headless   --convert-to html --outdir '/var/www/html/wp/wp-content/uploads/' /var/www/html/wp/wp-content/uploads/demo.docx");

Upvotes: 1

Arief Karfianto
Arief Karfianto

Reputation: 245

This works for me.

Make sure you have installed java RE, for example in ubuntu:

apt-get install default-jre

First, find the location of your libreoffice

$ which libreoffice
/usr/bin/libreoffice

Include the folder location in the PATH, and also set the HOME var by adding these lines:

putenv('PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin');
putenv('HOME=/tmp'); 
system("libreoffice .....

Upvotes: 2

Adonias Vasquez
Adonias Vasquez

Reputation: 1024

I'll recomend put config path first you run exec() or shell_exec();

IE:

// Vars
putenv('PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin');
putenv('HOME=' . $outputdir); 

$outputdir = chmod 777 And the same forlder from libreoffice command "--outdir"

Upvotes: 1

Peter Krauss
Peter Krauss

Reputation: 13930

About Universal Network Objects (UNO), there are some "plug-and-play" final-user tools, see Docvert and JODConverter (jODconverter and pyODconverter). All of then can be called as web-service or exec by PHP.

Upvotes: 0

Question Mark
Question Mark

Reputation: 3606

I managed to fix this issue with a quick export HOME=/tmp before running the convert command, this gives libreoffice somewhere writable to work it's magic.

Upvotes: 17

nickyspag
nickyspag

Reputation: 115

I was having the same problem and yes (thanks Wrikken) after prepending /usr/local/sbin to the PATH environment variable I was able to run libreoffice as www-data under apache.

Upvotes: 1

Mark Baker
Mark Baker

Reputation: 212442

Not strictly an answer, but rather than using PHP's exec, you might consider using PUNO, a PHP5 module that provides access to the OpenOffice.org UNO Programming API.

Upvotes: 3

Related Questions