Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
486 views
in Technique[技术] by (71.8m points)

php - Installing PhantomJS on server

I'm using PhantomJS on windows and accessing the files through command line. Now I want to install it on the server I'm working on local host so I want it to be installed on Apache, so that I may integrate Phantom with my html and PHP to be used within a web page. I'm using Windows 8.1 and Apache Server for localhost.

Can I actually do that? How to use it in web services now? How i will use it if I have to make my web online? should I have t ask my hosting provider to place this thing on server for me?

I'm using phantomJS to develop a web service which takes a url as input and returns an image file of the screen shot of the website.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

The "installation" of PhantomJS is just adding its path to the PATH environment variable.

Running through php

Since you're using php, you would invoke PhantomJS from your php script like it is shown here where you need to provide the full path to the PhantomJS executable. You can also use putenv to extend the PATH directly from php as seen here.
You can return something from the PhantomJS script in the $output variable of exec and then parse it.

Running through the webserver module

PhantomJS provides the web server module. You can write a script that listens for requests, creates the page on request and returns the image. You would somehow run the script at startup or together with apache. It's also possible to write a wrapper so that you can run it as windows service. It may be possible to pass the requests through Apache so that the PhantomJS is not completely open to the outside.
Although this option is a little treacherous, because PhantomJS may fail and then you would need some kind of reviving mechanism. Your script may also run into a memory leak.

Returning the image

Both of the above options are agnostic to how you return the image. There are several possiblities.

  1. On request, create a random and unique filename and render the page into the file. You can then send the name of the file to the client which might request it afterwards. This needs two requests.
  2. On request, render the page through renderBase64 to receive the plain image data. Now you can send this image data directly in the response and the client may put it into the DOM via data:-URI.

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...