Difference between revisions of "WebsiteCodingPractices"

From Warwick Student Cinema
Jump to: navigation, search
(Example php page)
 
(74 intermediate revisions by 70 users not shown)
Line 1: Line 1:
  +
{{Update}}
jVQHCo gIcbEw9n3n6JdaL72z0Fu
 
   
  +
==Common standards on how to write php pages for the website==
this post is fantastic <a href=" http://in905.com/accessible/testsite/forum//viewtopic.php?f=8&t=17987 ">boyversum</a> pkckak <a href=" http://www.sabukudo.com/forum//viewtopic.php?f=20&t=16962 ">momsteachingteens</a> ailt <a href=" http://ridecanadawest.com/forum//viewtopic.php?f=2&t=51860 ">heliosnatura</a> =-[[[ <a href=" http://rmargate.com/wp/theforums//viewtopic.php?f=2&t=1671 ">illegal verry young virgin youngest girl sex</a> 38366 <a href=" http://www.soaljawabagama.com//viewtopic.php?f=2&t=5536 ">parent directory pthc</a> vqjnyw <a href=" http://www.torresycarrera.com/foro//viewtopic.php?f=2&t=3680 ">xoyunx</a> zhahm <a href=" http://www.iwannabet.net/forum//viewtopic.php?f=2&t=17542 ">shemela</a> ccqzg <a href=" http://dorbol.ru/forum//viewtopic.php?f=2&t=1494 ">hardcore illegal sex</a> %-[[[ <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4498 ">bangkok child porn</a> %-DDD <a href=" http://ogreview.net/forum//viewtopic.php?f=2&t=5243 ">zeps guide to bbs</a> edbif <a href=" http://www.torresycarrera.com/foro//viewtopic.php?f=2&t=3696 ">CHAT TUVI</a> vmhcww <a href=" http://heinavesi.tv/foorum//viewtopic.php?f=4&t=1219 ">housewifeporn</a> vaq <a href=" http://rmargate.com/wp/theforums//viewtopic.php?f=2&t=1652 ">nude children and art</a> 5141 <a href=" http://forums.closertohim.co.uk//viewtopic.php?f=9&t=5482 ">naked kids pool</a> uknkn <a href=" http://heinavesi.tv/foorum//viewtopic.php?f=4&t=1197 ">illegal black porn</a> >:-(( <a href=" http://mithrae.net/syrnia/forum//viewtopic.php?f=5&t=4920 ">megatits lacting</a> >:(( <a href=" http://www.gazetapf.com/forum//viewtopic.php?f=5&t=273 ">reshma fucking</a> %) <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4501 ">preteen porn anime</a> 8-(( <a href=" http://www.torresycarrera.com/foro//viewtopic.php?f=2&t=3697 ">child pedo</a> =-[[ <a href=" http://ridecanadawest.com/forum//viewtopic.php?f=2&t=51853 ">teagan presley gallery</a> 8[ <a href=" http://mithrae.net/syrnia/forum//viewtopic.php?f=5&t=4924 ">preteen underage models</a> xjjws <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4497 ">hikayeler</a> 933737 <a href=" http://www.iwannabet.net/forum//viewtopic.php?f=2&t=17536 ">bbs preteen nude</a> =))) <a href=" http://www.jea-soluzioni.com/phpBB3//viewtopic.php?f=2&t=1022 ">naked kids outdoors</a> pcjwl <a href=" http://stehelp.net//viewtopic.php?f=2&t=3096 ">gambling online illegal</a> 92370 <a href=" http://www.thecheapcostume.com/includes/forums//viewtopic.php?f=6&t=9033 ">nude married with children</a> uqamqc <a href=" http://www.mastersofmovies.com/forums//viewtopic.php?f=25&t=86902 ">kid watching sex</a> 058340 <a href=" http://dorbol.ru/forum//viewtopic.php?f=2&t=1496 ">dorki preteen girl bbs</a> tgmbtv <a href=" http://www.mastersofmovies.com/forums//viewtopic.php?f=25&t=86879 ">sexy naked verry young little virgin</a> 673089 <a href=" http://heinavesi.tv/foorum//viewtopic.php?f=4&t=1208 ">japanese nymphets</a> >:(( <a href=" http://ogreview.net/forum//viewtopic.php?f=2&t=5222 ">pedo xxx</a> mocv <a href=" http://guardiansofavalon.org//viewtopic.php?f=2&t=22743 ">halloween party games for preteens</a> =-( <a href=" http://www.sabukudo.com/forum//viewtopic.php?f=20&t=16978 ">hot kid sex</a> ulxlml <a href=" http://www.iwannabet.net/forum//viewtopic.php?f=2&t=17511 ">preteen artistic</a> xjing <a href=" http://dorbol.ru/forum//viewtopic.php?f=2&t=1491 ">illegal children porn</a> hfhei <a href=" http://mithrae.net/syrnia/forum//viewtopic.php?f=5&t=4928 ">anime kid sex</a> 460590 <a href=" http://www.logosculture.com/forum//viewtopic.php?f=11&t=11626 ">teen asian model pre</a> :-PPP <a href=" http://rmargate.com/wp/theforums//viewtopic.php?f=2&t=1654 ">doctruyen</a> 231 <a href=" http://sorcerorcomic.com/forum//viewtopic.php?f=2&t=106973 ">kids playing nude</a> xrpli <a href=" http://www.gazetapf.com/forum//viewtopic.php?f=5&t=301 ">info on child pornography</a> =[ <a href=" http://ogreview.net/forum//viewtopic.php?f=2&t=5258 ">illegal pre teen models
 
</a> %((( <a href=" http://rmargate.com/wp/theforums//viewtopic.php?f=2&t=1684 ">very young nude children</a> 003072 <a href=" http://ridecanadawest.com/forum//viewtopic.php?f=2&t=51843 ">elweb bbs</a> %( <a href=" http://funnytosee.com//viewtopic.php?f=5&t=39031 ">preteen nude model art site</a> 8-PP <a href=" http://ogreview.net/forum//viewtopic.php?f=2&t=5245 ">bikini pre teen models</a> 8((( <a href=" http://ase-clan.com/phpBB3//viewtopic.php?f=2&t=823 ">iranxiran</a> dkv <a href=" http://mithrae.net/syrnia/forum//viewtopic.php?f=5&t=4931 ">illegal very young virgin sex galleries</a> sokvdq <a href=" http://ogreview.net/forum//viewtopic.php?f=2&t=5224 ">cute preteens</a> 0473 <a href=" http://guardiansofavalon.org//viewtopic.php?f=2&t=22758 ">bbs japanese preteen illegal very young japanese virgin illegal very young</a> 185 <a href=" http://www.logosculture.com/forum//viewtopic.php?f=11&t=11628 ">3arab sex</a> =-P
 
   
  +
This is up for discussion. If anyone would find it useful to see a particular standard implemented to make it easier for anyone to edit any page, please suggest it.
Excellent work, Nice Design <a href=" http://www.lirtiyatrosu.org/forum//viewtopic.php?f=22&t=28433 ">incest stories, pics</a> vplmt <a href=" http://funnytosee.com//viewtopic.php?f=5&t=39132 ">young incest stories</a> dpdvdl <a href=" http://www.pickypatient.com/forum//viewtopic.php?f=2&t=5824 ">real incest sex</a> 8[[ <a href=" http://www.cleanandgreenscene.com/forum//viewtopic.php?f=3&t=5725 ">free incest stories</a> fabek <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4469 ">incest taboo stories</a> gdvayv <a href=" http://funnytosee.com//viewtopic.php?f=5&t=39141 ">Mother fuck</a> rrd <a href=" http://listbuildingactionplan.com/forum//viewtopic.php?f=5&t=22023 ">incest sex movies</a> zox <a href=" http://www.rachelrayrocks.com/phpBB3//viewtopic.php?f=5&t=22651 ">cartoon incest tube</a> 930 <a href=" http://www.freervparkdirectory.com/campers-forum//viewtopic.php?f=4&t=29035 ">ukraine incest teen lolita porn</a> maxbf <a href=" http://guardiansofavalon.org//viewtopic.php?f=2&t=22665 ">. incest brother sex pics</a> :]] <a href=" http://in905.com/accessible/testsite/forum//viewtopic.php?f=8&t=17889 ">family incest with loli</a> 69385 <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4472 ">free incest pics</a> coef <a href=" http://tempest-war.net/forums//viewtopic.php?f=7&t=4471 ">incest sex stories</a> %-D <a href=" http://www.polkcountydownhillderby.com/forum//viewtopic.php?f=3&t=6918 ">incest thumbs forums</a> 6587 <a href=" http://www.generacion21.es/foro//viewtopic.php?f=2&t=2180 ">ptsc pthc kinderficker</a> 8-D <a href=" http://aevorum.com/forum//viewtopic.php?f=1&t=2098 ">erotic cartoons incest</a> =-]]] <a href=" http://www.edinoros-ural.ru/forum//viewtopic.php?f=2&t=61463 ">Back to top</a> =[[[ <a href=" http://dorbol.ru/forum//viewtopic.php?f=2&t=1527 ">best real incest web sites</a> =D <a href=" http://senseless.messwithyou.com//viewtopic.php?f=2&t=22589 ">Incest son mother</a> tdjrl <a href=" http://www.webforsale.lv/forum//viewtopic.php?f=10&t=5095 ">pic of asian girls seeking marriage animer</a> =DD <a href=" http://www.freervparkdirectory.com/campers-forum//viewtopic.php?f=4&t=29041 ">dad daughter incest stories</a> :D <a href=" http://www.rachelrayrocks.com/phpBB3//viewtopic.php?f=5&t=22642 ">taboo family incest videos</a> :(( <a href=" http://forums.closertohim.co.uk//viewtopic.php?f=9&t=5440 ">seduced amanda cartoons</a> 52770 <a href=" http://www.freervparkdirectory.com/campers-forum//viewtopic.php?f=4&t=29030 ">family incest forums</a> ndcev <a href=" http://www.coopmusic.com/forum//viewtopic.php?f=2&t=43119 ">incest pictures and art</a> 238 <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1865 ">Mother daughter sex</a> %( <a href=" http://www.busamapromotions.com/phpBB//viewtopic.php?f=7&t=76322 ">lesbian incest sex</a> nftc <a href=" http://www.polkcountydownhillderby.com/forum//viewtopic.php?f=3&t=6912 ">incest photos of teen brother and sister</a> 4231 <a href=" http://www.freervparkdirectory.com/campers-forum//viewtopic.php?f=4&t=29044 ">taboo family incest videos</a> szvc <a href=" http://www.buci-th.com/process//viewtopic.php?f=2&t=2933 ">free incest porn comics</a> 44337 <a href=" http://www.buci-th.com/process//viewtopic.php?f=2&t=2923 ">incest taboo fetish</a> hppfm <a href=" http://www.baselinejumper.com/forum//viewtopic.php?f=2&t=11541 ">free incest lesbians stories</a> 925197 <a href=" http://guardiansofavalon.org//viewtopic.php?f=2&t=22664 ">mother son incest story sister</a> >:P <a href=" http://www.baselinejumper.com/forum//viewtopic.php?f=2&t=11544 ">underage incest porn</a> 059 <a href=" http://www.polkcountydownhillderby.com/forum//viewtopic.php?f=3&t=6898 ">incest sex chat</a> 4323 <a href=" http://www.webforsale.lv/forum//viewtopic.php?f=10&t=5096 ">lesbian incest tgp</a> 59560 <a href=" http://aevorum.com/forum//viewtopic.php?f=1&t=2094 ">father daughter incest pictures</a> yxe <a href=" http://www.rachelrayrocks.com/phpBB3//viewtopic.php?f=5&t=22645 ">father son incest galleries</a> typo <a href=" http://www.generacion21.es/foro//viewtopic.php?f=2&t=2161 ">hussyfan keywords pthc p2p top searches</a> mhynrw <a href=" http://www.jea-soluzioni.com/phpBB3//viewtopic.php?f=2&t=975 ">incest tube movies</a> ltlfwy <a href=" http://www.polkcountydownhillderby.com/forum//viewtopic.php?f=3&t=6917 ">cartoon incest bdsm xxx</a> vhtz <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1869 ">asian mother perform oral sex son</a> omlkvi <a href=" http://www.edinoros-ural.ru/forum//viewtopic.php?f=2&t=61449 ">british incest porn</a> rbpo <a href=" http://www.cleanandgreenscene.com/forum//viewtopic.php?f=3&t=5715 ">incest comics forum</a> 23454 <a href=" http://senseless.messwithyou.com//viewtopic.php?f=2&t=22594 ">incest cartoons drawings</a> 910 <a href=" http://articlesforsalecanada.forumsecure.com//viewtopic.php?f=3&t=3112 ">father daughter incest pics</a> 85482 <a href=" http://www.ango.nl/forum//viewtopic.php?f=9&t=4240 ">adult english incest hentai</a> 224 <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=5932 ">incest pic sites</a> lvzru <a href=" http://forums.closertohim.co.uk//viewtopic.php?f=9&t=5435 ">young incest galleries</a> vnjye <a href=" http://www.jea-soluzioni.com/phpBB3//viewtopic.php?f=2&t=973 ">3d gay incest</a> 1591
 
   
  +
If anyone things that any of the standards suggested do not help, please comment.
Very interesting tale <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=6094 ">underage kids cp</a> ghrh <a href=" http://www.buci-th.com/process//viewtopic.php?f=2&t=2823 ">loli pussy</a> 3559 <a href=" http://www.lippymag.co.uk/forum//viewtopic.php?f=2&t=9842 ">boy lolita sex</a> nptyrh <a href=" http://stehelp.net//viewtopic.php?f=2&t=3032 ">nude art of lolita preteen girls</a> :[[[ <a href=" http://www.uniedu.it/forum//viewtopic.php?f=3&t=2856 ">loli index</a> 8050 <a href=" http://ridecanadawest.com/forum//viewtopic.php?f=2&t=51077 ">young lolita preteen underage</a> 64874 <a href=" http://www.buci-th.com/process//viewtopic.php?f=2&t=2840 ">lolita nude models</a> gydiwy <a href=" http://www.prevencioname.com/foro//viewtopic.php?f=2&t=1999 ">spanking naked sex little girls children</a> prvdn <a href=" http://www.cleanandgreenscene.com/forum//viewtopic.php?f=3&t=5623 ">little girl lolita pussy</a> =-((( <a href=" http://stehelp.net//viewtopic.php?f=2&t=3009 ">incest preteen lolita, lolita incest</a> fmh <a href=" http://forum.space-pirates.ch//viewtopic.php?f=3&t=2245 ">lolita preteen thumbs</a> :-( <a href=" http://www.freervparkdirectory.com/campers-forum//viewtopic.php?f=4&t=28889 ">underage bbs japanese preteen japanese lolita pedo lolis sex gallery</a> uqx <a href=" http://www.lippymag.co.uk/forum//viewtopic.php?f=2&t=9828 ">discourage underage bbs japanese preteen japanese lolita pedo lolis sex</a> jxxem <a href=" http://www.pickypatient.com/forum//viewtopic.php?f=2&t=6141 ">hiddenjane free</a> wmnn <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=6070 ">topheavyamateurs2</a> sitivh <a href=" http://audio-vintage.ru/forum//viewtopic.php?f=2&t=5615 ">loli models</a> >:PPP <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=6084 ">CrazyXXX3dWorld pictures</a> >:[[ <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1954 ">sex22</a> 97533 <a href=" http://gothiccountry.com/talk//viewtopic.php?f=6&t=41146 ">art girl model preteen</a> >:-OOO <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1946 ">mr moo nudemanila</a> 2712 <a href=" http://www.baselinejumper.com/forum//viewtopic.php?f=2&t=11698 ">naked kids photos</a> uqyviw <a href=" http://www.baselinejumper.com/forum//viewtopic.php?f=2&t=11508 ">free little lolita porn</a> hyyx <a href=" http://misterdoog.nl/forum//viewtopic.php?f=2&t=2413 ">vicky r(at)ygold loli pthc cp hussyfan</a> 8042 <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=6068 ">pre teen bikini modeling</a> =-(( <a href=" http://www.generacion21.es/foro//viewtopic.php?f=2&t=2186 ">lolita home</a> =[[ <a href=" http://www.prevencioname.com/foro//viewtopic.php?f=2&t=1907 ">sexy little lolitas</a> fvpo <a href=" http://forum.space-pirates.ch//viewtopic.php?f=3&t=2257 ">lolita bbs list</a> %) <a href=" http://bazo.sk/forum//viewtopic.php?f=11&t=3424 ">helping my child fight pornography</a> 617001 <a href=" http://senseless.messwithyou.com//viewtopic.php?f=2&t=22335 ">lolita underage preteen sweet young</a> 9898 <a href=" http://www.aflacum.ro//viewtopic.php?f=2&t=5833 ">lolita preteen</a> ahkkbe <a href=" http://misterdoog.nl/forum//viewtopic.php?f=2&t=2406 ">lolicon free</a> lyhl <a href=" http://www.rachelrayrocks.com/phpBB3//viewtopic.php?f=5&t=22567 ">young preteens lolitas nudes</a> gafk <a href=" http://bazo.sk/forum//viewtopic.php?f=11&t=3409 ">little kid porn</a> fmwzd <a href=" http://www.uniedu.it/forum//viewtopic.php?f=3&t=2858 ">lolitas pics</a> :-PPP <a href=" http://www.pickypatient.com/forum//viewtopic.php?f=2&t=6159 ">housewifeporn</a> qjpbf <a href=" http://www.cleanandgreenscene.com/forum//viewtopic.php?f=3&t=5765 ">megatits lacting</a> %]] <a href=" http://senseless.messwithyou.com//viewtopic.php?f=2&t=22330 ">lolita angels</a> qfgu <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1936 ">underage teen russian schoolgirl</a> sog <a href=" http://forum.space-pirates.ch//viewtopic.php?f=3&t=2247 ">cute loli</a> 320 <a href=" http://www.iwannabet.net/forum//viewtopic.php?f=2&t=16685 ">young sexy lolita nymphets</a> vodbw <a href=" http://www.rachelrayrocks.com/phpBB3//viewtopic.php?f=5&t=22557 ">lolita</a> ukocfw <a href=" http://www.pickypatient.com/forum//viewtopic.php?f=2&t=6145 ">wsotg</a> =[[ <a href=" http://foro.modamadridencrisis.es//viewtopic.php?f=2&t=1935 ">anemel</a> wmrn <a href=" http://ase-clan.com/phpBB3//viewtopic.php?f=2&t=722 ">preteen lolita list</a> 54805 <a href=" http://www.generacion21.es/foro//viewtopic.php?f=2&t=2190 ">pedo ftp russia loli 12yo bbs sex samples</a> 6774 <a href=" http://senseless.messwithyou.com//viewtopic.php?f=2&t=22341 ">preteen preteen lolitas</a> bqnph <a href=" http://www.iwannabet.net/forum//viewtopic.php?f=2&t=16678 ">crazy preteen lolitas</a> >:[ <a href=" http://www.generacion21.es/foro//viewtopic.php?f=2&t=2193 ">lolita pre teen art models</a> 8D <a href=" http://forum.trafficonacid.com//viewtopic.php?f=1&t=19130 ">karisweets</a> yovc <a href=" http://www.lippymag.co.uk/forum//viewtopic.php?f=2&t=9823 ">girl nymphets lolita</a> 07571
 
  +
  +
==Purpose==
  +
* Make it easier for other people to edit your code
  +
* Ensure that pages are written securely
  +
* Encourage compatibility with future changes
  +
* Derived from pear coding standard http://pear.php.net/manual/en/standards.php
  +
  +
==Standard==
  +
'''Header'''
  +
* Optional $page_title
  +
  +
* All pages that require authentication start with<br>
  +
wscauth_requirepriv(PRIV); or <br>
  +
if(!wscauth_haspriv(PRIV)){return;}
  +
  +
* Optional includes
  +
**Use include_once or require_once
  +
**Any includes that are not used on every page should be included at the start of the page using them
  +
  +
*All pages that are passed variables should declare the variables after the authentication
  +
**Newer versions of php disable register_globals, which means that this is required<br>
  +
eg.<br>
  +
$var=$_REQUEST['var']; for url, post and cookie or<br>
  +
$var=$_GET['var']; for URL only<br>
  +
$var=$_POST['var']; for POST only<br>
  +
$var=$_COOKIE['var']; for cookie only
  +
  +
* Optional check vars passed to the page for expected string format
  +
eg.
  +
$pid=preg_match(/^[0-9]+/, $_GET['pid'],$match) ? $match[0] : false;<br>
  +
This will assign $pid to the value of pid in the url if it is a number.
  +
  +
'''Block statments'''
  +
  +
*Use tabs to indent block code
  +
  +
* Avoid nested or long if statements
  +
eg.
  +
instead of if(COND){Do lots of code}<br>
  +
use if(!COND){return;}Do lots of code
  +
  +
'''Functions'''
  +
  +
* Use functions to make the structure of a page clear
  +
** If the page performs lots of actions use a switch statment to call functions that perform the actions. Do not use lots of if statments throughout the page
  +
** If functions are used on more than one page, put them in an include
  +
** Where possible use existing functions even if it is slightly less efficient. This will make the website more reliable and have a negligable impact on performance.
  +
  +
'''Database'''
  +
  +
* All database queries are to be performed in functions specifically for that task
  +
  +
* Database queries should use PEAR or string formatting functions
  +
eg.
  +
$query=sprintf("SELECT * FROM table WHERE id='%d' AND string='%s'",<br>
  +
mysql_real_escape_string($id),<br>
  +
mysql_real_escape_string($string))<br>
  +
  +
'''Syntax'''
  +
  +
*Use <?php and ?> not <? and ?> which is not standards compliant
  +
  +
'''Comments'''
  +
  +
*All functions should be preceded with a comment block so that docmentation can be automatically built
  +
  +
The comment block should have to following format
  +
/**
  +
* A description of the function
  +
* @param string $param A description of the parameter
  +
*
  +
*/
  +
function example ($param) { ...
  +
  +
*Comments used within the code should have a dimilar format
  +
  +
*Documentation on comment syntax is available at http://www.phpdoc.org
  +
  +
==Example php page==
  +
<?php<br>
  +
$page_title="Example php page";<br>
  +
wscauth_requrepriv(PRIV_VIEW_EXAMPLE);<br>
  +
include_once("include/members.inc");<br>
  +
include_once("include/strings.inc");<br>
  +
<br>
  +
$pid=preg_match(/^[0-9]+/, $_REQUEST['pid'],$match) ? $match[0] : false;<br>
  +
<br>
  +
//This if statement may not actually be required as person_by_id does a similar thing.<br>
  +
//Consider what the effect of not passing $pid would be and only use a statment like this if the page would break.<br>
  +
if(!$pid){<br>
  +
&nbsp;print "Person not found";<br>
  +
&nbsp;include_once("another_page.php");<br>
  +
&nbsp;return;<br>
  +
}<br>
  +
$person=person_by_id($pid);<br>
  +
print "Name ".$person['fullname'];<br>
  +
<br>
  +
//Only put a function in this page, if it cannot be used in other pages.<br>
  +
function exampleFunction($var1, $var2, $var3="default"){<br>
  +
&nbsp;//Only do database queries in this page, if this will be the only page where the database table is used.<br>
  +
&nbsp;$query=sprintf("SELECT * FROM example_table WHERE<br>
  +
&nbsp;&nbsp;&nbsp;pid='%d' AND expired="<br>
  +
&nbsp;&nbsp;&nbsp;.stringNull($date).<br>
  +
&nbsp;&nbsp;&nbsp;")",<br>
  +
&nbsp;&nbsp;mysql_real_escape_string($pid));<br>
  +
<br>
  +
&nbsp;return wscdb_fetchresults($query,0,0);<br>
  +
}<br>
  +
?>
  +
  +
[[Category:Website]]

Latest revision as of 23:25, 9 February 2019

Common standards on how to write php pages for the website

This is up for discussion. If anyone would find it useful to see a particular standard implemented to make it easier for anyone to edit any page, please suggest it.

If anyone things that any of the standards suggested do not help, please comment.

Purpose

Standard

Header

  • Optional $page_title
  • All pages that require authentication start with

wscauth_requirepriv(PRIV); or
if(!wscauth_haspriv(PRIV)){return;}

  • Optional includes
    • Use include_once or require_once
    • Any includes that are not used on every page should be included at the start of the page using them
  • All pages that are passed variables should declare the variables after the authentication
    • Newer versions of php disable register_globals, which means that this is required

eg.
$var=$_REQUEST['var']; for url, post and cookie or
$var=$_GET['var']; for URL only
$var=$_POST['var']; for POST only
$var=$_COOKIE['var']; for cookie only

  • Optional check vars passed to the page for expected string format

eg. $pid=preg_match(/^[0-9]+/, $_GET['pid'],$match) ? $match[0] : false;
This will assign $pid to the value of pid in the url if it is a number.

Block statments

  • Use tabs to indent block code
  • Avoid nested or long if statements

eg. instead of if(COND){Do lots of code}
use if(!COND){return;}Do lots of code

Functions

  • Use functions to make the structure of a page clear
    • If the page performs lots of actions use a switch statment to call functions that perform the actions. Do not use lots of if statments throughout the page
    • If functions are used on more than one page, put them in an include
    • Where possible use existing functions even if it is slightly less efficient. This will make the website more reliable and have a negligable impact on performance.

Database

  • All database queries are to be performed in functions specifically for that task
  • Database queries should use PEAR or string formatting functions

eg. $query=sprintf("SELECT * FROM table WHERE id='%d' AND string='%s'",
mysql_real_escape_string($id),
mysql_real_escape_string($string))

Syntax

  • Use <?php and ?> not <? and ?> which is not standards compliant

Comments

  • All functions should be preceded with a comment block so that docmentation can be automatically built

The comment block should have to following format

/**
 * A description of the function
 * @param string $param A description of the parameter
 *
 */
function example ($param) { ...
  • Comments used within the code should have a dimilar format

Example php page

<?php
$page_title="Example php page";
wscauth_requrepriv(PRIV_VIEW_EXAMPLE);
include_once("include/members.inc");
include_once("include/strings.inc");

$pid=preg_match(/^[0-9]+/, $_REQUEST['pid'],$match) ? $match[0] : false;

//This if statement may not actually be required as person_by_id does a similar thing.
//Consider what the effect of not passing $pid would be and only use a statment like this if the page would break.
if(!$pid){
 print "Person not found";
 include_once("another_page.php");
 return;
}
$person=person_by_id($pid);
print "Name ".$person['fullname'];

//Only put a function in this page, if it cannot be used in other pages.
function exampleFunction($var1, $var2, $var3="default"){
 //Only do database queries in this page, if this will be the only page where the database table is used.
 $query=sprintf("SELECT * FROM example_table WHERE
   pid='%d' AND expired="
   .stringNull($date).
   ")",
  mysql_real_escape_string($pid));

 return wscdb_fetchresults($query,0,0);
}
?>