1HTML::Mason(3) User Contributed Perl Documentation HTML::Mason(3)
2
3
4
6 HTML::Mason - High-performance, dynamic web site authoring system
7
9 version 1.59
10
12 PerlModule HTML::Mason::ApacheHandler
13
14 <Location />
15 SetHandler perl-script
16 PerlHandler HTML::Mason::ApacheHandler
17 </Location>
18
20 Mason is a tool for building, serving and managing large web sites. Its
21 features make it an ideal backend for high load sites serving dynamic
22 content, such as online newspapers or database driven e-commerce sites.
23
24 Actually, Mason can be used to generate any sort of text, whether for a
25 web site or not. But it was originally built for web sites and since
26 that's why most people are interested in it, that is the focus of this
27 documentation.
28
29 Mason's various pieces revolve around the notion of "components''. A
30 component is a mix of HTML, Perl, and special Mason commands, one
31 component per file. So-called "top-level" components represent entire
32 web-pages, while smaller components typically return HTML snippets for
33 embedding in top-level components. This object-like architecture
34 greatly simplifies site maintenance: change a shared component, and you
35 instantly changed all dependent pages that refer to it across a site
36 (or across many virtual sites).
37
38 Mason's component syntax lets designers separate a web page into
39 programmatic and design elements. This means the esoteric Perl bits can
40 be hidden near the bottom of a component, preloading simple variables
41 for use above in the HTML. In our own experience, this frees content
42 managers (i.e., non-programmers) to work on the layout without getting
43 mired in programming details. Techies, however, still enjoy the full
44 power of Perl.
45
46 Mason works by intercepting innocent-looking requests (say,
47 http://www.yoursite.com/index.html) and mapping them to requests for
48 Mason components. Mason then compiles the component, runs it, and
49 feeds the output back to the client.
50
51 Consider this simple Mason component:
52
53 % my $noun = 'World';
54 Hello <% $noun %>!
55 How are ya?
56
57 The output of this component is:
58
59 Hello World!
60 How are ya?
61
62 In this component you see a mix of standard HTML and Mason elements.
63 The bare '%' prefixing the first line tells Mason that this is a line
64 of Perl code. One line below, the embedded <% ... %> tag gets replaced
65 with the return value of its contents, evaluated as a Perl expression.
66
67 Beyond this trivial example, components can also embed serious chunks
68 of Perl code (say, to pull records from a database). They can also call
69 other components, cache results for later reuse, and perform all the
70 tricks you expect from a regular Perl program.
71
73 I (Dave Rolsky) am no longer using HTML::Mason and I would love to find
74 some co-maintainers to help. Specifically, I'd like people to review
75 issues and PRs, create new PRs, and ultimately take on the task of
76 uploading new releases to CPAN. If you're interested the best way to
77 start is to fix one or more of the issues in the issue tracker
78 <https://github.com/houseabsolute/HTML-
79 Mason/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc>.
80
82 Version 1 of Mason (this distribution) -- has been around since 1998,
83 is in wide use, and is very stable. However it has not changed much in
84 years and is no longer actively developed.
85
86 Version 2 of Mason -- Mason -- was released in February of 2011. It
87 offers a new syntax as well as a number of other features. See
88 <https://metacpan.org/pod/distribution/Mason/lib/Mason/Manual/UpgradingFromMason1.pod>
89 for details of the differences between the two.
90
92 Mason has been tested under Linux, FreeBSD, Solaris, HPUX, and Win32.
93 As an all-Perl solution, it should work on any machine that has working
94 versions of Perl 5.00503+, mod_perl, and the required CPAN modules.
95
96 Mason has a standard MakeMaker-driven installation. See the README file
97 for details.
98
100 This section assumes that you are able to install and configure a
101 mod_perl server. Relevant documentation is available at
102 http://www.apache.org (Apache) and http://perl.apache.org (mod_perl).
103 The mod_perl mailing list, archive, and guide are also great resources.
104
105 The simplest configuration of Mason requires a few lines in your
106 httpd.conf:
107
108 PerlModule HTML::Mason::ApacheHandler
109
110 <Location />
111 SetHandler perl-script
112 PerlHandler HTML::Mason::ApacheHandler
113 </Location>
114
115 The PerlModule directive simply ensures that the Mason code is loaded
116 in the parent process before forking, which can save some memory when
117 running mod_perl.
118
119 The <Location> section routes all requests to the Mason handler, which
120 is a simple way to try out Mason. A more refined setup is discussed in
121 the Controlling Access via Filename Extension section of the
122 administrator's manual.
123
124 Once you have added the configuration directives, restart the server.
125 First, go to a standard URL on your site to make sure you haven't
126 broken anything. If all goes well you should see the same page as
127 before. If not, recheck your Apache config files and also tail your
128 server's error log.
129
130 If you are getting "404 Not Found" errors even when the files clearly
131 exist, Mason may be having trouble with your document root. One
132 situation that will unfortunately confuse Mason is if your document
133 root goes through a symbolic link. Try expressing your document root in
134 terms of the true filesystem path.
135
136 Next, try adding the tag <% 2+2 %> at the top of some HTML file. If you
137 reload this page and see a "4", Mason is working!
138
140 Once Mason is on its feet, the next step is to write a component or
141 two. The Mason Developer's Manual is a complete tutorial for writing,
142 using, and debugging components. A reference companion to the
143 Developer's Manual is the Request API documentation,
144 HTML::Mason::Request.
145
146 Whoever is responsible for setting up and tuning Mason should read the
147 Administrator's Manual, though developers will also benefit from
148 reading it as well. This document covers more advanced configuration
149 scenarios and performance optimization. The reference companion to the
150 Administrator's manual is the Parameters Reference, which describes all
151 the parameters you can use to configure Mason.
152
153 Most of this documentation assumes that you're running Mason on top of
154 mod_perl, since that is the most common configuration. If you would
155 like to run Mason via a CGI script, refer to the
156 HTML::Mason::CGIHandler documentation. If you are using Mason from a
157 standalone program, refer to the Using Mason from a Standalone Script
158 section of the administrator's manual.
159
160 There is also a book about Mason, Embedding Perl in HTML with Mason, by
161 Dave Rolsky and Ken Williams, published by O'Reilly and Associates.
162 The book's website is at http://www.masonbook.com/. This book goes
163 into detail on a number of topics, and includes a chapter of recipes as
164 well as a sample Mason-based website.
165
167 Questions and feedback are welcome, and should be directed to the Mason
168 mailing list. You must be subscribed to post.
169
170 https://lists.sourceforge.net/lists/listinfo/mason-users
171
172 You can also visit us at "#mason" on <irc://irc.perl.org/#mason>.
173
174 Bugs and feature requests will be tracked at RT:
175
176 http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-Mason
177 bug-html-mason@rt.cpan.org
178
180 Bugs may be submitted at
181 <https://github.com/houseabsolute/HTML-Mason/issues>.
182
183 I am also usually active on IRC as 'autarch' on "irc://irc.perl.org".
184
186 The source code repository for HTML-Mason can be found at
187 <https://github.com/houseabsolute/HTML-Mason>.
188
190 • Jonathan Swartz <swartz@pobox.com>
191
192 • Dave Rolsky <autarch@urth.org>
193
194 • Ken Williams <ken@mathforum.org>
195
197 • Ævar Arnfjörð Bjarmason <avarab@gmail.com>
198
199 • Alex Balhatchet <kaoru@slackwise.net>
200
201 • Alex Vandiver <alex@chmrr.net>
202
203 • Florian Schlichting <fsfs@debian.org>
204
205 • John Williams <jwilliams@cpan.org>
206
207 • Kent Fredric <kentnl@gentoo.org>
208
209 • Kevin Falcone <falcone@bestpractical.com>
210
211 • Patrick Kane <modus-cpan@pr.es.to>
212
213 • Ricardo Signes <rjbs@cpan.org>
214
215 • Shlomi Fish <shlomif@shlomifish.org>
216
218 This software is copyright (c) 1998 - 2020 by Jonathan Swartz.
219
220 This is free software; you can redistribute it and/or modify it under
221 the same terms as the Perl 5 programming language system itself.
222
223 The full text of the license can be found in the LICENSE file included
224 with this distribution.
225
226
227
228perl v5.36.0 2022-07-22 HTML::Mason(3)