添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

Static websites aren’t suitable for every situation, but they have several advantages over dynamic apps; they’re more efficient, more secure and simpler to deploy. That said, developing and maintaining a static site is a pain, there’s just too much repetitive boilerplate code. Enter Wallflower , it generates static websites from PSGI compatible Perl web applications. You get the best of both worlds: develop the routes, templates and unit tests in your favourite web framework but deploy it as a static website with Wallflower.

Requirements

The CPAN Testers results for the latest version (v1.004) of App::Wallflower show it runs on just about any Perl and operating system, including Windows. You can install it from CPAN by going to the command line and typing:

$ cpan App::Wallflower

Wallflower in action

Let’s create a simple application using Dancer2 :

$ dancer2 -a MyApp

This will create a skeleton application for us. Now change into the root application directory and create a new directory to hold the static files, we’ll call it “static”:

$ cd MyApp
$ mkdir static

That’s all we need to generate the static site with wallflower:

$ wallflower --a bin/app.pl --d static

Wallflower will request the application root page (‘/’) and spider all links it finds from there, copying the files to the static folder. This includes files referenced in your html and css, such as JavaScript files. If your app has links to all of its pages, this is all you need.

Test the static site with nginx

Let’s deploy the site with nginx locally (you’ll need nginx installed for this). First create the virtual host file:

server {
    listen 80;
    server_name localhost;
    root /var/www/MyApp/static;
    location / {
        index index.html;
        rewrite ^/$ /index.html break;

Assuming a unix-like platform, save the virtual host file to “/etc/nginx/sites-available/localhost”. Next enter these commands:

$ sudo mkdir /var/www/MyApp
$ sudo cp static /var/www/MyApp
$ cd /etc/nginx/sites-enabled
$ sudo ln -s ../sites-available/localhost

Now we need to start nginx. On RHEL/Fedora/CentOS you can start nginx with:

$ sudo nginx

On Ubuntu:

sudo service nginx start

Now check out the site at http://localhost:

Looks pretty good to me!

Wallflower Tips

A few things I’ve found whilst using Wallflower:

  • Use absolute urls over relative ones. So if you host your font files in your css directory, use: “/css/MyFont.ttf” instead of “MyFont.ttf” in your css files.
  • Think about files you use but aren’t directly linked to in your app’s HTML pages, the sitemap.xml file for example. Feed urls for these files to Wallflower with the -F option.
  • Watch out for urls in commented code as Wallflower will copy these too!
  • The Wallflower docs recommend using extensions in your urls to ensure the correct content-type is set. I found this wasn’t required when I deployed the files with nginx.
  • Conclusion

    Whether you prefer developing applications with Catalyst, Dancer or Mojolicious, Wallflower is a useful tool that can be incorporated into your development and deployment process. For further examples of Wallflower in action, check out the tutorial and advent calendar entry by Wallflower creator Philippe Bruhat (BooK).

    Cover image © Ruth Hartnup

    This article was originally posted on PerlTricks.com.

    David Farrell

    David is a professional programmer who regularly tweets and blogs about code and the art of programming.

    Browse their articles
    Legal

    Perl.com and the authors make no representations with respect to the accuracy or completeness of the contents of all work on this website and specifically disclaim all warranties, including without limitation warranties of fitness for a particular purpose. The information published on this website may not be suitable for every situation. All work on this website is provided with the understanding that Perl.com and the authors are not engaged in rendering professional services. Neither Perl.com nor the authors shall be liable for damages arising herefrom.