Skip to main content

Resolving Absolute Paths of included files from relative paths when using SEO friendly URLs

How to resolve base paths of your included files when using Htaccess mod rewrite rules for generating SEO friendly URL?

Most of the programmers might have encountered a design break issue while using mod rewrite rule in htaccess to override websites dynamic url with SEO friendly URLs

SEO friendly URLs

Search Engine Friendly URLs are purely structural URLs that do not contain a query string and instead contain only the path of the resource.

A dynamic url may look like:

http://www.awebsite.com/index.php?act=search&key=vacancies
this url may not look so pretty

You can rewrite this to a SEO friendly URL like this

http://www.awebsite.com/search/vacancies

Even though the webpage is called as http://www.awebsite.com/search/vacancies in background server is accessing the actual url of the webpage ie, http://www.awebsite.com/index.php?act=search&key=vacancies

This is done by using mod_rewrite rule in htaccess file.

Apaches mod_rewrite rule is a really sophisticated module which provides a powerful way to do URL manipulations. With it you can do nearly all types of URL manipulations you ever dreamed about.

in the .htaccess file add this

RewriteEngine On
RewriteBase /
RewriteRule ^search/([a-z0-9\-_]+)(/)?$ index.php?act=search&key=$1 [L]

ErrorDocument 404 http://www.awebsite.com/index.html



Mod rewrite - design breaks - JS and CSS Includes fails

If you are including JS and CSS file in your web pages using the relative paths like


<head>
<title> PHP techi </title>

<link rel=stylesheet type="text/css" href="include/style.css">
<script language="JavaScript" src="include/scr.js"></script>

</head>


then there is a chance like, you will see you web design break or your JS functions do not work.

this is because when you used the url rewriting the absolute url to the style.css and scr.js files (shown above) becomes :
http://www.awebsite.com/search/includes/style.css
http://www.awebsite.com/search/includes/scr.js

but it is invalid. The valid path for this files are :

http://www.awebsite.com/includes/style.css
http://www.awebsite.com/includes/scr.js

and this is the reason for your design break and JS scrpt failing.

Solution to the problem

Add a BASE tag inside the head tag just before calling all the including files.

The <base> tag specifies the base URL/target for all relative URLs in a document.
The <base> tag goes inside the <head> element.

it looks like the one below:


<head>
<title> PHP techi </title>
<base href="http://www.awebsite.com/" />
<link rel=stylesheet type="text/css" href="include/style.css">
<script language="JavaScript" src="include/scr.js"></script>

</head>


Mod rewrite - Query string checking
Usage of BASE tag
Apache Mod rewrite rule
Apache Mod rewrite Guide

Comments

Post a Comment

Popular posts from this blog

How to delete videos from your Youtube Watch History list?

How to Delete Individual or all videos from your Youtube Watch History list? Youtube keeps a fine record of the videos that you had watched earlier. You can view this by visiting the History section. If you want to remove the video's from the list do the following: Logon to Youtube and click on the "History" tab on the left menu to view Watch History ( Read more ) There will be check boxes corresponding to each video in the list Tick the check boxes of the videos which you want to remove Click on " Remove " button to delete the videos.

How to add "Link to this page" option under blogger posts?

Steps in adding Link to this page to your blogger posts Links to your page can improve your page rank. So it is a good option to add HTML code for linking to your web page. So that reader can copy and paste it on their web page. if another website links to your web page, this is considered an external link to your website. External links to your website are the most important source of ranking power and in SEO terminology it is considered as third party ranking vote for your page.

Intex Aqua 5.5 VR Plus genuine Review - Dont Buy Intex Aqua 5.5 VR Plus - Board complaint and low battery backup issues

Intex Aqua 5.5 VR Plus  Review - Dont Buy Intex Aqua 5.5 VR + - Board complaint and low battery backup issues I bought an Intex Aqua 5.5 VR Plus on April 23, 2018, With in a week it started to show Battery backup issues. Even if it is charged full, it will completely drain out with in 12 or 13 hours. During this time No internet was used, only 2 or 3 calls were done. Some times there was issues with net connection also.


Urgent Openings for PHP trainees, Andriod / IOS developers and PHP developers in Kochi Trivandrum Calicut and Bangalore. Please Send Your updated resumes to recruit.vo@gmail.com   Read more »
Member
Search This Blog