Having spam is something we as developers, must deal with daily, avoiding spam is a must that we should keep in mind in all our projects. The usual method of hiding an e-mail is to wrap it up with words like at and dot, this is a trend but when it comes to usability versus spam-fighting, users could get confused. Using the e-mail generation method of eZ Publish combined with jQuery leads us to a safer html code that will avoid further more e-mail-spam-grabbers and will bring up usability in our projects. Developers will gain protection for e-mails and users will rely on well written e-mail sequences.
To understand this tutorial you will need a basic knowledge of jQuery (www.jquery.com) and knowledge on how to configure .ini files in an eZ Publish installation.
Recently I wanted to make e-mail addresses "uncatchable" at a site to avoid crawlers that collect them, a solution was to configure sitesettings/your-site/template.ini.append.php and add under [WashSettings] the following:
# Replacements strings for the . and @ in an email # Used to display emails in a way that SPAM engines # cannot fetch automatically EmailDotText= [punto] EmailAtText= [@]
Adding such definitions e-mail addresses become something like "myname [@] domain [punto] com", you can also change it to the conventional "at" and "dot".
Hint: You can leave spaces before and after each definition “ [punto] ” or “ [@] ” to achieve spaces within the e-mail sequence
The code generated as html by eZ Publish looks something like this:
<a href="mailto:myname@domain.com">myname [@] domain [punto] com</a>
This kind of sequence for an e-mail addresses is not always a straight-forward solution. Avoiding the mailto also keeps crawlers away, so with some jQuery code we can obtain a more interesting approach. You can still let the eZ Publish kernel handle the e-mail address generation but this time surrounded by the <div> that jQuery code will then handle later on when the page has loaded.
An example of template code :
{$owner_map.user_account.content.email|wash('email')}
Will generate something like this:
myname [@] domain [punto] com
Wrapped around the div and adding an id, this will become:
<div id="mail">myname [@] domain [punto] com</div>
Enabling jQuery at an eZPublish project can be done by activating the eZ JS Core certified extension as you would with any extension in eZ Publish. For more information, see http://doc.ez.no/Extensions/eZ-JS-Core/. You could also add the jQuery JS code in your pagelayout (visit www.jquery.com).
The jQuery code that deals with the <div> is:
<script type="text/javascript"> $(function(){ //scrambles mails with [@] and [punto] var spt = $('div#mail'); var at = " [@] "; var dot =" [punto] "; var addr = $(spt).text().replace(at,"@").replace(dot,"."); $(spt).after( '<a href="mailto:' + addr + '" title="Send an email">' + addr + '</a>' ).hover( function() { window.status = "Send a letter!"; }, function() { window.status=""; } ); $(spt).remove(); }); </script>
You can also add within the js code some eZ code that fetches from the template.ini the values of EmailDotText and EmailAtText so whenever you change the definition at the .ini the jQuery works as well.
Once the jQuery runs you get a nicer and understandable e-mail "myname@domain.com" at the frontend site with its own “mailto” once you hover over the link, but this time crawlers will not see it at all as the code is not understandable for them, as for users they will get the well-known e-mail addresses sequence as it should always be.
Developers make projects for users, but not all of them have the knowledge enough to understand scrambled e-mail address sequences that should be interpreted as simple e-mails sequences and thus trust and click them. Usability is a must in the development of a project. In this tutorial we have learned how to achieve better code to protect our users from spam and an understandable e-mail address sequence for our users. Happy developer, happy user!
This tutorial is available for offline reading :
Jorge Estevez - Encapsulating e-mails for usability and spam protection - PDF Version
Jorge Estévez Rams is using eZ Publish since eZ Systems was founded; he leads a web development group in Havana, Cuba (www.elfosdesign.com).
This work is licensed under the Creative Commons – Share Alike license ( http://creativecommons.org/licenses/by-sa/3.0 ).
Timing: | Jan 17 2025 20:50:00 |
Script start | |
Timing: | Jan 17 2025 20:50:00 |
Module start 'layout' | |
Timing: | Jan 17 2025 20:50:00 |
Module start 'content' | |
Timing: | Jan 17 2025 20:50:00 |
Module end 'content' | |
Timing: | Jan 17 2025 20:50:00 |
Script end |
Total runtime | 0.0912 sec |
Peak memory usage | 4,096.0000 KB |
Database Queries | 39 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0043 | 597.6094 | 152.1563 |
Module start 'layout' | 0.0043 | 0.0024 | 749.7656 | 39.5391 |
Module start 'content' | 0.0067 | 0.0833 | 789.3047 | 762.1484 |
Module end 'content' | 0.0900 | 0.0012 | 1,551.4531 | 14.1797 |
Script end | 0.0912 | 1,565.6328 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0028 | 3.0299 | 16 | 0.0002 |
Check MTime | 0.0012 | 1.3286 | 16 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0007 | 0.7891 | 1 | 0.0007 |
Mysqli_queries | 0.0336 | 36.8293 | 39 | 0.0009 |
Looping result | 0.0003 | 0.2796 | 37 | 0.0000 |
Template Total | 0.0686 | 75.1 | 2 | 0.0343 |
Template load | 0.0020 | 2.2126 | 2 | 0.0010 |
Template processing | 0.0665 | 72.9187 | 2 | 0.0333 |
Template load and register function | 0.0001 | 0.0865 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0021 | 2.3072 | 3 | 0.0007 |
state_identifier_array | 0.0015 | 1.6100 | 4 | 0.0004 |
Override | ||||
Cache load | 0.0023 | 2.4901 | 74 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0015 | 1.6592 | 2 | 0.0008 |
Fetch class attribute can translate value | 0.0000 | 0.0253 | 1 | 0.0000 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0068 | 2 | 0.0000 |
XML | ||||
Image XML parsing | 0.0004 | 0.4601 | 1 | 0.0004 |
General | ||||
dbfile | 0.0007 | 0.7632 | 13 | 0.0001 |
String conversion | 0.0000 | 0.0063 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | full/article.tpl | extension/sevenx/design/simple/override/templates/full/article.tpl | ||
1 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
8 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
2 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
18 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
7 | content/datatype/view/ezxmltags/separator.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltags/separator.tpl | ||
6 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
3 | content/datatype/view/ezxmltags/newpage.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tpl | ||
6 | content/datatype/view/ezxmltags/literal.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tpl | ||
2 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
1 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
1 | content/datatype/view/ezxmltags/line.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/line.tpl | ||
1 | content/datatype/view/ezxmltags/embed-inline.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed-inline.tpl | ||
1 | content/view/embed-inline.tpl | <No override> | design/standard/templates/content/view/embed-inline.tpl | ||
1 | content/datatype/view/ezxmltags/embed.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed.tpl | ||
1 | content/view/embed.tpl | embed/image.tpl | extension/sevenx/design/simple/override/templates/embed/image.tpl | ||
1 | content/datatype/view/ezimage.tpl | <No override> | extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 62 Number of unique templates used: 18 |
Time used to render debug report: 0.0001 secs