rewriterule probleem

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

C# Ontwikkelaar

Functieomschrijving Voor een software ontwikkelaar in de omgeving van Vught zijn we op zoek naar een gemotiveerde C# ontwikkelaar. Deel jij hun passie voor development en dan vooral in C#.NET? Dan kan dit wel eens jouw droombaan zijn! Jouw werkzaamheden zullen er ongeveer als volgt uit gaan zien Door de wensen van de klant goed te begrijpen ga jij aan de slag dit om te zetten naar passende oplossingen en werk je deze uit tot een sterk eindproduct. Je gaat je bezighouden met de ontwikkeling van webapplicaties en websites, dit doe je door middel van ASP.NET, MVC Frameworks en C#.

Bekijk vacature »

.NET Developer

Functieomschrijving Ben jij klaar voor de volgende stap in jouw carrière? Kom werken bij dit kleine softwarebureau en werk aan de gaafste maatwerk projecten. Je komt te werken in een klein development team en werk nauw samen met elkaar, om maatwerk software te leveren en bij te dragen aan bedrijfsautomatiseringen. Je gaat werken met de Microsoft stack en technieken als .NET, C#, Entity, MVC, SQL server. In de functie krijg je veel vrijheid om zelf beslissingen te nemen en je hebt impact op de bedrijfsprocessen. Bedrijfsprofiel Dit familiebedrijf bestaat al ruim 20 jaar. Zij hebben een vast netwerk van klanten,

Bekijk vacature »

Medior/senior Front-end developer (Vue.js)

Functie Als Front-end developer ben je uiteindelijk overkoepelend aan de slag voor de 3 ontwikkelteams die ieder aan een specifiek product werken. In samenwerking met de UX-designer en de huidige Front-end developer zorg je voor gebruiksvriendelijke software. Lijkt het jou interessant om complexe problemen op te lossen en feautures naar een hoger niveau te tillen? En vind je het niet erg om oudere delen van de applicaties te refactoren i.c.m. het toevoegen van nieuwe functionaliteiten? Dan komen wij graag met je in contact. Eisen • HBO werk- en denkniveau (ze kijken niet naar papieren, maar naar denkniveau, motivatie en zelfredzaamheid)

Bekijk vacature »

Medior/senior Front-end developer

Functie Je maakt deel uit van een DevOps Scrum team en werkt samen met back-end developers, test-engineers, interaction designers en een projectmanager. Er zijn verschillende groepen Scrum teams. Een roadmap team is jouw ‘’thuisbasis’’, daar wordt gewerkt aan doorontwikkeling van bestaande omgevingen voor een aantal klanten. Hiernaast zijn er projectteams waar nieuwe omgevingen worden gebouwd, of grote complexe wijzigingen worden doorgevoerd op bestaande omgevingen. Je kunt (afhankelijk van jouw wensen en doelen) dus afwisselend werken in beide teams. Hiernaast participeer je in het Chapter Front-end development waar gezamenlijk kennis en ervaring wordt gedeeld. Als Front-end developer is het jouw doel

Bekijk vacature »

Digitale Tovenaar Gezocht: Junior Low-code/No-code

Bedrijfsomschrijving Duik mee in een wereld vol innovatieve avonturen waar gegevens en technologie een magische symbiose aangaan! Al meer dan twee decennia lang zijn we de tovenaars achter de schermen die oplossingen creëren voor de meest complexe klantcontactvraagstukken en datagedreven software-uitdagingen. Bij ons draait het om de kracht van samenwerking en groei. We zijn een hechte vriendengroep die samen bergen verzet om elkaar én onze klanten te laten schitteren. Jouw succes is ons succes en we streven ernaar om elkaar naar nieuwe hoogten te tillen, niet voor even, maar voor altijd. We willen dat jij je helemaal thuis voelt in

Bekijk vacature »

Laravel / PHP developer gezocht!

Functie omschrijving Wij zijn op zoek naar een Laravel PHP Developer voor een leuk bedrijf in de omgeving van Amsterdam! Je zult je bezig houden met de volgende werkzaamheden: Je gaat aan de hand van de wensen van klanten software ontwikkelen; Je bent bij het gehele proces betrokken; van A tot Z; Je hebt na de oplevering contact met de klant wanneer zij problemen ervaren; Je denkt mee over het verbeteren van de werkprocessen; Je denkt mee over softwareoplossingen; Je speelt in op de behoefte van de klant; Je houdt je bezig met het verbeteren, aanpassen en vernieuwen van de

Bekijk vacature »

Back end developer

Functie Jij als full stack ontwikkelaar komt te werken in een team bestaande uit 4 back end programmeurs, 2 vormgevers/ Front end developers en een online marketeer. Qua persoonlijkheden is het team erg gevarieerd van sportfanaten tot gameliefhebbers en Golfers. Een ding heeft iedereen hier gemeen; Passie voor goede code. In jouw rol zul je voor 90% van je tijd je bezig houden met het ontwikkelen van grote maatwerk applicaties. Daarnaast hebben wij op aanvraag ook wel eens een website of onderhoudsklusje, die opgepakt moet worden en hier ben jij ook niet vies van. De technische uitdaging momenteel is dat

Bekijk vacature »

Front end developer

Functie Het team bestaat uit User Experience designers, Data Scientists en Software Engineers met passie voor hun vak. De consultants en ontwikkelaars werken volgens de Design Thinking methode waarbij de eerste stappen van ontwerp en ontwikkeling zullen samenkomen in een proof of concept. Nadat is vastgesteld dat de oplossing voldoet aan de belangrijkste behoeftes worden producten of services gevalideerd door middel van korte iteraties. Hiermee zorgen ze ervoor dat het werk voldoet aan de technische vereisten en gebruikersbehoefte. Door het inzetten van de nieuwste technologieën die toekomstbestendig zijn weten ze klanten omver te blazen. Ook geven en organiseren ze veel

Bekijk vacature »

Junior .NET developer

Functie Als junior .NET ontwikkelaar start jij in ons development team met twee andere .NET developers. Als team werken jullie in scrum en is er iedere ochtend om 11.00 een standup. Jij krijgt als junior .NET ontwikkelaar een inwerk traject dat echt specifiek wordt ingericht op basis van wat jij nodig hebt. Een van de grootste pluspunten bij ons is dat wij binnen ons bedrijf veel (technische) vrijheid geven en juist eigen initiatieven erg stimuleren. Jouw werkzaamheden gaan er bij ons als volgt uit zien: – Het ontwikkelen van nieuwe software samen met interne en eventueel externe ontwikkelaars; – Het

Bekijk vacature »

Traineeship Java Developer

Functie Wat ga je doen als Java Developer? Jij start via ons bij deze opdrachtgever als Trainee Java ontwikkelaar, tijdens het traineeship ga je in 1 jaar van de basis naar professioneel Java ontwikkelaar. Je start samen met een groep trainees, volgt de aangeboden cursussen en gaat aan de slag bij één van onze opdrachtgevers. Na een aantal maanden volgt de volgende opdracht. Door de groei in jouw rol kom je op steeds complexere opdrachten terecht. Veel afwisseling dus. Collega’s met ervaring helpen je bij deze groei en samen met jouw coach ga je een persoonlijke leerplan opzetten om jou

Bekijk vacature »

Junior Front end developer

Functie Als Front end developer binnen onze organisatie ga jij je bezig houden met het bouwen van de user experience van de webapplicaties. Je bent verantwoordelijk voor het vertalen van concepten, briefings en designs naar werkende functionaliteit. Hierbij zorg je ervoor dat applicaties betrouwbaar, veilig en toekomstbestendig zijn en een goede architectuur hebben en behouden. Verder denk je actief na- en mee over nieuwe ontwikkelingen en functionaliteiten om zo elke dag de klantervaring weer te verbeteren. Dit doe je natuurlijk niet alleen maar in een development team. Het team bedraagt momenteel 4 man bestaande uit 2 devops engineers en 2

Bekijk vacature »

.NET developer

Wat ga je doen als Full stack .NET developer Microsoft 365? Je stelt je op als sparringpartner voor het team en PO over toekomstige functionaliteiten, architectuur en mogelijke nieuwe producten. Je bent mede-verantwoordelijk voor het vertalen en omzetten van een user story in een passend technisch design. Je implementeert functionaliteiten op basis van een technisch design en user story. Je bent mede-verantwoordelijk voor het beheer van Azure DevOps, waaronder het beheer van GIT, Build Pipelines, Release Pipelines en geautomatiseerde testen. Hier herken jij jezelf in Hbo werk- en denkniveau of hoger aangevuld met relevante certificeringen en/of cursussen; Minimaal 3 jaar

Bekijk vacature »

Java Developer

Dit ga je doen Het ontwikkelen van nieuwe software; Het ombouwen van de bestaande software; Zowel back- als front-end software ontwikkelen; Het testen; Het implementeren van de volledig geteste software; Het verzorgen van nazorg en het oplossen van bugs; Het opstellen en bijhouden van procesdocumentatie; Je draagt bij aan het agile/scrum processen van het team. Hier ga je werken Ongetwijfeld heb je een of meerdere producten van deze organisatie in huis. Het proces erachter, daar ben je ongetwijfeld minder bekend mee. Deze opdracht geeft je de kans meer over dit proces te weten te komen en een mooie bijdrage te

Bekijk vacature »

Junior .NET developer

Functie Ons programma is voor afgestudeerde enthousiastelingen die het als een uitdaging zien om met een klein dynamisch team bij de grootste bedrijven van Nederland aan de slag te gaan. Tijdens jouw dienstverband word jij begeleid door een talent manager. Het ontwikkelen van jouw talent staat hierbij centraal. Het programma doorloop je met een team van circa 8 Mede- trainees. De eerste maand start je met een fulltime inhouse opleiding. Deze staat geheel in het teken van de werkzaamheden die jij verder in het programma zult uitvoeren. Na deze opleidingsmaand ga je aan de slag in een dynamische omgeving bij

Bekijk vacature »

Software Programmeur

Functie omschrijving Ben jij op zoek naar een organisatie waar je samen met een team werkt aan iets moois en waar je naast hard werken ook hard kunt lachen? Dan ben je hier aan het juiste adres! Voor een informeel IT-bedrijf in omgeving Wassenaar zijn wij op zoek naar versterking. Ben jij op zoek naar een nieuwe uitdaging als Software Programmeur lees dan snel verder! Werkzaamheden Programmeur Je bent bezig met het ontwikkelen van software en webapplicaties. Je kunt technische klussen uitvoeren op locatie. Je onderhoudt contact met de projectleider om er zeker van te zijn dat een project goed

Bekijk vacature »
Tortuga web

tortuga web

10/04/2015 09:18:31
Quote Anchor link
Ik heb een website met in de root een index-file die de diverse pagina´s aanroept:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<!DOCTYPE html>
<html lang="nl">
<head>
    <meta charset="utf-8" />
    <link rel="stylesheet" href="css/menu.css" />
    <title>Testsite</title>
    <link rel="shortcut icon" type="image/x-icon" href="favicon.ico" />
</head>

<body>
<div align="center">
    <div class="head">
        <?php
            session_start();
            include("content/head.php");
            include("content/menu.php");
        ?>

        <div class="basis">
            <?php
                if (!isset($_GET['page'])) {
                    //url-variabele bestaat niet, geef beginpagina
                    include('content/home.php');
                }

                else {
                    //url-variabele bestaat wel, definieer bestand
                    $page = 'content/'.$_GET['page'].'.php';
                    if (file_exists($page)) {
                        //pagina bestaat, laat zien
                        include($page);
                    }

                    else {
                        //pagina bestaat niet
                        echo '<p id="index">Deze pagina bestaat (nog) niet. Kijkt u later nog eens.</p>';
                    }
                }

            ?>

        </div>
    </div>
</div>
</body>
</html>

De pagina´s met de inhoud staan in de submap /content, met enkel de body-inhoud.
Ook het bestand menu.php staat in de submap /content en is als volgt:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
<ul id="nav">
    <li><a href="index.php?page=home">Home</a></li>
    <li><a href="index.php?page=links">Links</a></li>
</ul>

Dit levert in de adresregel in de browser links met de structuur http://127.0.0.1:8080/test/index.php?page=home.
Dat wil ik graag omzetten naar http://127.0.0.1:8080/test/home, dus heb ik in de root (bij de index.php) een .htaccess bestand toegevoegd:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
RewriteEngine On
RewriteBase /

RewriteCond %{REQUEST_FILENAME} -f [NC,OR]
RewriteCond %{REQUEST_FILENAME} -d [NC]

RewriteRule ^(.*?)$ $1 [L]
RewriteRule ^(.*?)$ index.php?page=$1 [L,QSA]

Ik heb dit getest met de Wamp-server én gecontroleerd dat rewrite-module aan staat en ja, die staat aan.

Waarom werkt dit niet?
 
PHP hulp

PHP hulp

22/07/2024 19:29:25
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 09:27:28
Quote Anchor link
Je RewriteBase zal in ieder geval /test/ moeten zijn denk ik.

Verder snap ik niet dat iedereen altijd een volledig pad in een querystring wil opslaan... Hiermee reserveer (lees: verspil) je effectief een querystring-variabele voor dit doel. Wat nu als je $_GET['page'] later wilt gebruiken voor een pagina-navigatie, dit kan dan niet meer.

Ik zal eens een voorbeeldje maken, maar mogelijk is het na de aanpassing van je RewriteBase al opgelost.
 
Tortuga web

tortuga web

10/04/2015 09:30:18
Quote Anchor link
Ook met RewriteBase /test/ blijft het onveranderd. Ik ben benieuwd naar je voorbeeldje.
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 10:27:57
Quote Anchor link
Het duurde ff, maar dan heb je ook wat :).

Mijn opzet: code staat in http://localhost/test/rewriterules.

.htaccess in deze map:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
RewriteEngine on

# het relatieve pad ten opzichte van de document root van je (virtual) host
RewriteBase /test/rewriterules/

# rechtstreekse aanroep van bestaande directories en bestanden blijft werken
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f

# rest van alle aanroepen wordt doorgestuurd naar index.php
# plak hierbij de querystring aan index.php vast
RewriteRule . index.php [L,QSA]


index.php in deze map:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?php
// Zet bij het ontwikkelingen foutmeldingen aan.
error_reporting(E_ALL);
ini_set('display_errors', 'stdout');

// Sessies starten doe je voor aanvang van je document.
session_start();

// In plaats van eem metatag zou je ook kunnen overwegen om gewoon een PHP-header te gebruiken:
header('Content-Type: text/html; charset=UTF-8');
?>

<!DOCTYPE html>
<html lang="nl">
<head>
    <meta charset="UTF-8" />
    <!-- omdat je in CSS en JavaScript vaak relatieve verwijzingen gebruikt en je URLs vaak niet uit -->
    <!-- echte folders bestaan is het zaak dat je altijd hetzelfde uitgangspunt hanteert voor relatieve -->
    <!-- verwijzingen naar deze documenten, dit doe je met de base tag -->
    <base href="http://localhost/test/rewriterules/">
    <link rel="stylesheet" href="css/menu.css" />
    <title>Testsite</title>
    <link rel="shortcut icon" type="image/x-icon" href="favicon.ico" />
</head>

<body>
<div align="center">
    <div class="head"><?php
        // Ik zou hier "includes/onderdeel.php" van maken ofzo, om dit te onderscheiden van je content-includes.
        // Ook zou ik hier "require" van maken - het is de bedoeling dat deze bestanden bestaan!

        require './content/head.php';
        require './content/menu.php';
        ?>
<div class="basis"><?php
            // Hier ga je bepalen welke pagina werd aangeroepen. Dit doe je aan de hand van $_SERVER['REQUEST_URI'].
            ?>
<p>Oorspronkelijke aanroep: <?php echo $_SERVER['REQUEST_URI'] ?></p><?php
            // Inspecteer of deze hout snijdt.
            $path = '';
            $uriData = @parse_url($_SERVER['REQUEST_URI']);
            if ($uriData === false) {
                // REQUEST_URI klopte niet, doe hier iets of geef $path een waarde.
            } else {
                ?>
<p>Absoluut pad: <?php echo $uriData['path'] ?></p><?php
                // We zijn alleen maar geinteresseerd in het relatieve pad vanaf de relatieve root
                // oftewel we willen /test/rewriterules/ van $uriData['path'] strippen

                $path = substr($uriData['path'], strlen(dirname($_SERVER['SCRIPT_NAME'])) + 1);
                ?>
<p>Relatief pad: <?php echo $path ?></p><?php
                // Bonus: al je $_GET variabelen kun je vrij gebruiken:
                ?>
<p><pre>$_GET: <?php echo print_r($_GET, true) ?></pre></p><?php
                // Vervolgens kun je $path (mogelijk in combinatie met waarden uit $_GET) gebruiken om
                // wat voor content dan ook te laden...

            }
        ?>
</div>
    </div>
</div>
</body>
</html>


Een aanroep van http://localhost/test/rewriterules/pagina/lalal/hoi?test=1&hoi=2 levert dit op:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
Oorspronkelijke aanroep: /test/rewriterules/pagina/lalal/hoi?test=1&hoi=2

Absoluut pad: /test/rewriterules/pagina/lalal/hoi

Relatief pad: pagina/lalal/hoi

$_GET: Array
(
    [test] => 1
    [hoi] => 2
)


EDIT: waar je ook voor moet zorgen is dat je .htaccess bestanden MAG declareren in je webdirectories, dit doe je door in je httpd.conf in de <Directory> tag van je web directory de instelling AllowOverride de waarde All te geven. Als deze op None stond en/of je deze waarde hebt aangepast moet je Apache even herstarten uiteraard.

EDIT:
Als alternatief voor de regel
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
$path
= substr($uriData['path'], strlen(dirname($_SERVER['SCRIPT_NAME'])) + 1);
?>


Zou je ook deze kunnen gebruiken
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
$path
= trim(substr($uriData['path'], strlen(dirname($_SERVER['SCRIPT_NAME']))), '/');
?>

Dit zorgt ervoor dat het niet uitmaakt of je een pagina aanroept met /whatever of /whatever/. Het uiteindelijke relatieve pad wordt dan in beide gevallen "whatever" (zonder trailing of leading slashes).
Gewijzigd op 10/04/2015 11:08:08 door Thomas van den Heuvel
 
Tortuga web

tortuga web

10/04/2015 11:34:24
Quote Anchor link
Ben heel driftig aan het uitproberen geslagen, en het werkt goed om de pagina´s zo aan te roepen, maar in de adresregel verandert er niets.
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 11:42:09
Quote Anchor link
Wat bedoel je met "in de adresregel verandert er niets"?

Als je hiermee bedoelt dat als er in je code staat:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
<a href="index.php?page=home">home</a>

Dat dit op een of andere magische wijze wordt omgezet in:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
<a href="test/home">home</a>

Dan klopt dit (dat dit niet gebeurt).

Dit is een ander probleem dat je op een andere manier -en op een andere plaats- moet oplossen. Dit heb ik hier al min of meer toegelicht.

Of ik begrijp niet goed wat je bedoelt.
 
Tortuga web

tortuga web

10/04/2015 11:55:44
Quote Anchor link
Dat klopt, daar was ik al achter, maar het moet toch kunnen dat ik m´n pagina´s aanroep via de index.php, zoals met jouw script, en dat de output in de adresregel verschijnt met localhost/test/home.
Als ik de pagina aanroep met: index.php?page=home, dan wordt de pagina inderdaad aangeroepen, en zie ik dit dus in de adresregel. Als ik de pagina aanroep met /home.php of home of whatever ik heb kunnen bedenken, dan wordt die niet geladen.
Dus neem ik aan dat ik iets fout doe met de wijze van aanroepen, maar ik weet niet wat.

NB. Ja, de allowoverride staat op on
Gewijzigd op 10/04/2015 11:58:20 door tortuga web
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 11:59:41
Quote Anchor link
Had je deze edit nog gezien:
Quote:
EDIT: waar je ook voor moet zorgen is dat je .htaccess bestanden MAG declareren in je webdirectories, dit doe je door in je httpd.conf in de <Directory> tag van je web directory de instelling AllowOverride de waarde All te geven. Als deze op None stond en/of je deze waarde hebt aangepast moet je Apache even herstarten uiteraard.

Oftewel: als AllowOverride in je httpd.conf op None staat, dan doen je .htaccess bestanden (en daarmee je RewriteRules) niets.

EDIT: heb je Apache/XAMPP opnieuw gestart na deze wijziging?
Gewijzigd op 10/04/2015 12:01:45 door Thomas van den Heuvel
 
Tortuga web

tortuga web

10/04/2015 12:00:44
Quote Anchor link
Ja, die heb ik dus gecontroleerd en staat All
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 12:04:15
Quote Anchor link
Uhhh...

Hoe ziet je code er op dit moment uit?
Welke URL roep je precies aan?
Wat verwacht je dat er zou moeten gebeuren?
Wat gebeurt er daadwerkelijk?
 
Tortuga web

tortuga web

10/04/2015 17:42:00
Quote Anchor link
Oké, ik zie door de bomen het bos niet meer.
Wat zet ik in de menu-file om de diverse pagina´s aan te roepen?
<a href=""index.php?page=home">Home</a> is dus niet goed? Wat dan wel???
 
Bart V B

Bart V B

10/04/2015 18:40:49
Quote Anchor link
Je urls moet je zelf aanpassen.
Dat gebeurt niet automatisch.
Dus in jou geval een hyperlink ala http://domain.tld/test/home
Heel dat index.php moet aangepast worden.
 
Thomas van den Heuvel

Thomas van den Heuvel

10/04/2015 21:11:11
Quote Anchor link
Voor de duidelijkheid: de index.php die ik hierboven plaatste is niet volledig. Uiteindelijk houd je een schoongemaakt relatief pad over op grond waarvan je moet bepalen welke pagina geladen moet worden...

Dit doe je bijvoorbeeld met een if-elseif-...-else-statement waarbij je $path inspecteert, of je slaat deze unieke slugs op in je database en haal je deze hieruit op.

En in je hyperlinks kun je gewoon je clean URLs gebruiken, zoals je ze wilt aanroepen. Maar als je deze hier hard incodeert, dan veranderen ze dus ook niet mee als je de "slug" aanpast. Hierbij zou een database-oplossing beter zijn, in die zin dat je dingen generieker kunt opzetten. Je houdt de pagina's bijvoorbeeld bij in een "nodes" tabel, en gebruikt voor je interne URL's een functie die met behulp van het node-id de juiste slug (pagina URL) ophaalt. Zo heb je dus een indirecte en centrale manier voor het aanspreken van je pagina's.

Hey, nobody said it would be easy.
 
Tortuga web

tortuga web

10/04/2015 21:27:36
Quote Anchor link
Thomas van den Heuvel op 10/04/2015 21:11:11:
Hey, nobody said it would be easy.


Een waarheid als een koe!!!

Ik ga er weer verder mee stoeien, wellicht kom ik er ooit uit.
Ik snap in ieder geval iets beter wat jullie bedoelen, nou nog zien of ik het ook verwerkt krijg. In ieder geval alvast bedankt voor de hulp.
 
Thomas van den Heuvel

Thomas van den Heuvel

11/04/2015 11:59:15
Quote Anchor link
Ik bedacht me net een variant die ook wel makkelijk werkt: eentje met arrays en wat hulpfuncties. Als je wilt kan ik daar een voorbeeldje van uitwerken van wat het idee is en hoe je deze vervolgens gebruikt.
 
Tortuga web

tortuga web

11/04/2015 12:03:30
Quote Anchor link
Nou, dat zou wel welkom zijn. Als je dat zou willen doen, dan al bij voorbaat veel dank daarvoor.
 
Thomas van den Heuvel

Thomas van den Heuvel

11/04/2015 13:32:14
Quote Anchor link
Okay, allereerst, in zijn algemeenheid kom je bij "clean URLs" voor drie uitdagingen te staan:

1. hoe maak ik deze en krijg ik deze aan de praat
Dit is hierboven wel ongeveer behandeld. In een ander topic refereerde Frank aan een script die slugs kan maken uit titels enzo, die zou ik zeker eens bekijken. Dit is dus de "genereer" kant.

Vervolgens:
2. hoe zorg ik ervoor dat ik deze weer uit kan lezen
Hier waren we nu ongeveer beland, we hebben de REQUEST_URI al helemaal uitgekleed tot het moment dat we de oorspronkelijke "slug" overhielden. Maar hier moet nog iets mee gebeuren anders gebeurt er nog steeds niets :). Hier gaan we zodadelijk mee verder.

En last but certainly not least,
3. hoe houd ik de referenties naar mijn pagina's (de slugs) consistent
Want je wijst nu niet meer direct naar een bron (een fysiek bestand) maar naar een soort van niet-bestaande alias. Wat nu als ik een rubriek op mijn site heb genaamd /news (de slash is even om te verduidelijken dat ik het over een pad heb) en ik heb een aantal plaatsen waar ik hier naar verwijs. Stel nu dat /blog toch toepasselijker was geweest? Dit kan ik verder prima aanpassen, maar hoe zorg ik ervoor dat alle verwijzingen naar /news automatisch meeveranderen naar /blog (nog even los van alle SEO implicaties van zo'n operatie :)). Als je allerlei verwijzingen in je navigatielinks hard-code dan zul je dus een soort van site-wide search-and-replace moeten doen, en daar wil je echt niet aan beginnen (tenzij je Moodle heet (een opensource electronisch leersysteem, DON'T ASK :P)). Maar goed dit probleem moeten we dus ff in ons achterhoofd houden. Eerst naar punt 2.

Het idee
De eerste stap van dit proces is het organiseren van onze data. Wat we willen is een soort van "mapping" van een unieke slug naar een stuk code dat wordt uitgevoerd. Maar hierbij kunnen we er niet vanuit gaan dat de slug niet verandert. Het beste wat we kunnen doen is deze paren nummeren. We krijgen dan bijvoorbeeld de volgende structuur:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<?php
$nodes
= array(
    1 => array(
        'slug'  => '',
        'title' => 'Home',
        'code'  => '/path/to/code/home.php',
    ),

    2 => array(
        'slug'  => 'links',
        'title' => 'Links',
        'code'  => '/path/to/code/links.php',
    ),

    3 => array(
        'slug'  => 'contact',
        'title' => 'Contact',
        'code'  => '/path/to/code/contact.php',
    ),

    // et cetera
);
?>

Dat is fijn, maar we hebben de slug nodig om te bepalen welke code we moeten includen :p.
Dus maken we een reverse-lookup array. Je hebt nu met $nodes een id => slug mapping, en je wilt het omgekeerde: slug => id. Daarom is het ook belangrijk dat slugs uniek zijn en blijven, dit is iets wat je op een of andere manier moet afdwingen. Bij het opstellen van het reverse-lookup array houden we alleen de meest relevante informatie bij (enkel slugs in de keys en id's in de values). Het $nodes array blijft onze enige echte bron van de structuur-data, we gaan niet alles lopen sleuren en pleuren door onze code.

Zorg ook dat slugs geschikt zijn als array-key uiteraard :).
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
// build slugs array - MAKE SURE SLUGS REMAIN UNIQUE
$slugs = array();
foreach ($nodes as $id => $data) {
    $slugs[$data['slug']] = $id;
}

?>

Als we hiermee voortborduren op de eerdere code van index.php, dan kunnen we vrij eenvoudig bepalen welke code we moeten includen, voeg de $nodes en $slugs code toe aan je index.php na regel 50 ($path heeft nu een waarde die we moeten inspecteren) en voeg de volgende code toe om te testen of de juiste pagina geladen zou worden:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?php
// if the path contains an existing slug, we have found an existing "alias"
if (isset($slugs[$path])) {
    // shorthand for node id for readibility
    $nodeId = $slugs[$path];
    // the next bit is merely a check to see what code we would include
    // it still does nothing!
    // to actually do this you would need to include it yourself obviously

    ?>
<h2>Page Found!</h2>
    <p>code: <?php echo $nodes[$nodeId]['code'] ?></p><?php
} else {
    // in this case you would revert to a default node id, which would be 1 in our case
    // you could also choose to load a special error page (404, 500 etc.) and set the
    // appropriate HTTP headers to indicate what is wrong

    $nodeId = 1;
    ?>
<h2>Page not found! Loading default!</h2>
    <p>code: <?php echo $nodes[$nodeId]['code'] ?></p><?php
}
?>

That's it, je kunt nu de juiste code requiren. Het wordt natuurlijk nog spannender als:
- je deze code gaat verplaatsen naar klasses (niet meer inline uitschrijven enzo)
- je je sitestructuur in een database stopt in een soort van boomstructuur
- je index.php een soort van "maintemplate" wordt en de code een soort van "paginatypes" waarbij het paginatype kan communiceren met het maintemplate, bijvoorbeeld vanuit je paginatype stel je een titel in voor het HTML-document in je maintemplate

Dan nog een ILLUSTRATIEVE manier van hoe je links zou moeten maken in je pagina's. Het is heel simpel: je gebruikt hiervoor een functie die aan het node-id refereert. Vervolgens kun je je slug dus vrij aanpassen (zolang deze uniek blijft). Let wel: dit is een VOORBEELD, je kunt de link functie beter ook opnemen in een klasse bij de rest van je "SITE ROUTING", maar goed het volgende werkt ook:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<?php
function nodeLink($id) {
    global $nodes; // this is ugly, i know alright!
    if (isset($nodes[$id])) {
        $slug  = $nodes[$id]['slug'];
    }
else {
        $slug = ''; // or "deadlink" or something
    }
    // @todo add HTTPS
    // @todo make relative path configurable
    // @todo add args parameter etc.

    return 'http://'.$_SERVER['HTTP_HOST'].'/test/rewriterules/'.$slug;
}

?>

Vervolgens, als je dus een link naar /contact wil maken doe je dus:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
<a href="<?php echo nodeLink(3) ?>">test</a>

En als je de slug van deze pagina vervolgens verandert naar "whatever" dan verandert de link automatisch mee! Tadaa~
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.