Google Crawl Redirect Error Tutorial

Google Crawl Redirect Error Tutorial

Google Crawl Redirect Error Tutorial

We’ve been attending to some Google Crawl errors recently, one of them like the …

  • “Incompatible Plugin Error” of Google Crawl Incompatible Plugin Error Tutorial … and, today …
  • “Redirect Error” caused by our WordPress blog TwentyTen theme’s header.php code not up to a user definable piece of functionality we allowed for with WordPress Temporary User CSS Primer Tutorial (and WordPress Temporary Window Print Primer Tutorial, we discovered) … so that our changes to header.php will, hopefully fix future “user adventures” …
    <?php

    if (isset($_SESSION['ourcss'])) {
    echo "\n" . ' appendtoa("cssextra", "" + user_encodeURIComponent("' . str_replace('"','" + String.fromCharCode(34) + "',str_replace('+',' ',urldecode($_SESSION['ourcss']))) . '")); ' . "\n";
    }
    if (isset($_SESSION['ourprint'])) {
    echo "\n" . ' appendtoa("printextra", "" + user_encodeURIComponent("' . str_replace('"','" + String.fromCharCode(34) + "',str_replace('+',' ',urldecode($_SESSION['ourprint']))) . '")); ' . "\n";
    }

    ?>
    … teamed with new Javascript function …
    <?php echo ”

    function user_encodeURIComponent(insr) {
    var oursr=encodeURIComponent(insr);
    var preeqs=[];
    var oursrs=oursr.split(encodeURIComponent('&'));
    for (var ioursr=1; ioursr<eval('' + oursrs.length); ioursr++) {
    preeqs=oursrs[ioursr].split(encodeURIComponent('='));
    if (eval('' + preeqs.length) > 1) {
    if (decodeURIComponent(preeqs[0]) == preeqs[0]) {
    oursr=oursr.replace(encodeURIComponent('&') + preeqs[0] + encodeURIComponent('='), '&' + preeqs[0] + '=');
    }
    }
    }
    return oursr;
    }


    “; ?>

Fixing today’s Google Crawl “Incompatible Plugin Error” was embarrassingly easier still. Within a Website-Flyer.htm we commented out an Adobe Flash Player reference as below …


<!--object type="application/x-shockwave-flash" width="509" height="75" id="BZDC1DB0A84A024A6D91AB" data="Flyer/bzAnimation.swf?swfId=BZDC1DB0A84A024A6D91AB&xmlPath=Flyer/bz.xml&imgPath=Flyer/img&soundPath=false&urlType=_top&showInfo=1&themeMode=2"><param name="movie" value="Flyer/bzAnimation.swf?swfId=BZDC1DB0A84A024A6D91AB&xmlPath=Flyer/bz.xml&imgPath=Flyer/img&soundPath=false&urlType=_top&showInfo=1&themeMode=2" /><param name="allowScriptAccess" value="always"></param><param name="wmode" value="transparent"></param></object-->

We’ve got thousands upon thousands of RJM Programming webpages. How can this tinkering make a difference (to Search Engine Optimization)? We’re not sure, but we’ve read it might. Just because you’ve got “thousands upon thousands” of webpages does not ensure they are all indexed by Google is one issue, perhaps making your attention proportionately more meaningful.


Previous relevant Google Crawl Incompatible Plugin Error Tutorial is shown below.

Google Crawl Incompatible Plugin Error Tutorial

Google Crawl Incompatible Plugin Error Tutorial

As a webmaster it can be good to get an outside view of the issues on the website you manage. Google provide this with Google Search Console (part of “Google Webmasters”) as a …

  • search engine … helping out webmasters of websites in relation to …
  • the search engine crawling of URLs they discover with regard to your website domain

… with a variety of “Crawl Error” category we last talked about with, regarding “Broken Links” when we presented the previous Google Crawl Errors Primer Tutorial below.

Today, we revisit “Google Crawl Error” territory, this time regarding a “Crawl Error” category “Uses incompatible plugins”. The URL pointed to by the error message link got us to …

This is a troubleshooting issue. As such, we recommend acting in an objective way, and try to find an independent test environment both to …

  • recreate the live environment, enough, to mimic the problem of the “live” URL with a “test” equivalent (so downloaded, via sftp, the “subdomain” (sort of) to our local MAMP Apache/PHP/MySql web server) … where we saw an Adobe Flash Player window warning of the issue and offering to “Download Flash…”, an offer we have decided to skirt around (but read on) …
  • prove/disprove or find out what is wrong on the “test” web server
  • change code of the “test” web server and unit test and rechange and test again until satisfied, on the “test” web server
  • show a working set of changed code on the “test” web server
  • upload, via sftp, changed “test” web server files to the “live” web server

… a tried and many times tested paradigm, that in broad brush terms, suits many types of troubleshooting problems.

Within prove/disprove or find out what is wrong on the “test” web server we …

  1. turned off the need for Adobe Flash Player via the !– and encased …

    <!--object type="application/x-shockwave-flash" width="122" height="110" id="BZ9F1B51BAAA56473FBB39" data="bzAnimation.swf?swfId=BZ9F1B51BAAA56473FBB39&xmlPath=bz.xml&imgPath=img&soundPath=false&urlType=_top&showInfo=1&themeMode=2"><param name="movie" value="bzAnimation.swf?swfId=BZ9F1B51BAAA56473FBB39&xmlPath=bz.xml&imgPath=.//img&soundPath=false&urlType=_top&showInfo=1&themeMode=2" /><param name="allowScriptAccess" value="always"></param><param name="wmode" value="transparent"></param>
    </object-->

    … and lo and behold, Adobe Flash Player plugin no longer required, the good news, but the not so good news is a lack of animation interest … so …
  2. examining the webpage via the web browser web inspector we discovered that there was an HTML5 canvas element left behind for us to work with, and we decided to do our own animation with this canvas via new document.body onload call


    <body style="background: #ffffff url(Welcome_files/PhotoGray_nav_bg.jpg) repeat scroll top left; margin: 0pt; " onload="setTimeout(avoidflash,2000); onPageLoad();" onunload="onPageUnload();">

    … calling on new Javascript …

    <script type="text/javascript">
    var imgs=['img/E2056759-788F-47B2-B890.png','img/4BFD4F98-069C-450F-9B2F.png','img/13925BFD-163A-439F-8CBB.jpg','img/BFA442D7-A0A2-48E0-AE4C.jpg','img/F6351070-2CC4-4914-A785.jpg','img/E9BFF839-D932-49B4-8270.jpg','img/EA588468-4D33-4FD6-9D25.png','img/37FA1992-4889-4F6D-84AD.jpg','img/1781F2A2-50AC-4A89-94E5.jpg','img/4B76B23B-840C-4E0B-B57C.jpg','img/16C4852F-A463-452B-BACA.jpg'];
    var elem=[null];
    var context=[null];
    function chooseanother() {
    var iuy=Math.floor(Math.random() * imgs.length);
    document.getElementById('imgf').src=imgs[iuy] + '?x=' + Math.floor(Math.random() * 19876543);
    }
    function showthis(ithis) {
    for (var ics=1; ics<context.length; ics++) {
    context[ics].drawImage(ithis, 0, 0, ithis.width, ithis.height, 10, 10, eval(-20 + elem[ics].width), eval(-20 + elem[ics].height));
    }
    setTimeout(chooseanother, 2000);
    }
    function avoidflash() {
    var cs=document.getElementsByTagName('canvas');
    if (cs.length > 0) {
    elem[0]=cs[0];
    context[0]=elem[0].getContext('2d');
    for (var ics=1; ics<cs.length; ics++) {
    elem.push(cs[ics]);
    context.push(cs[ics].getContext('2d'));
    }
    document.getElementById('iidiv').innerHTML='<img onload=showthis(this); id=imgf src=' + imgs[0] + '></img>';
    }
    }
    </script>

    … to suit our purposes, not quite as cute as Flash, but serviceable, and animated

  3. back at “Google Crawl Errors” click the “Validate Fix” button to the right of “Done fixing?” wording to see whether your fix also fixes Google’s “Crawl View” of the website affected


Previous relevant Google Crawl Errors Primer Tutorial is shown below.

Google Crawl Errors Primer Tutorial

Google Crawl Errors Primer Tutorial

When you are a webmaster (of a web domain, such as www.rjmprogramming.com.au) registered with Google you can receive (Google) console notifications from unusual events. Thanks for the heads up, Google. This is like a sanity check, independently, for webmasters, registering websites at Google.

Lately, we’ve been noticed a bit, we guess, because of the introduction of index.htm into the picture (that we talked about last with Landing Page Mobile Phone Crontab Curl Tutorial) … you’ll see it middle top of today’s tutorial picture … saying cheese … sorry, the dogs got involved in today’s blog posting … they’re sooooooooooo immature … unlike the humans, of course!?

Anyway, mistakes of the past hand crafting blog posting have come back to bite, and the Google crawl error count for error 404 has gone up, for www.rjmprogramming.com.au, quite a bit lately. Another term for this is “broken links”.

No excuse, but when hand crafting blog posts, care is needed with HTML a links, pretty obviously, regarding …

  • spelling mistakes
  • copying and pasting (absolute) URLs (often from a search engine result set) and forgetting the http:// or https:// bit (which does not always appear with a copied URL from the search engine results, for instance) … which, if left out, as you can imagine, leads the web browser to want to search through your domain for that (what becomes “orphaned”) URL reference … we make this mistake quite a bit with Wikipedia and W3schools … sorry, guys
  • for us, moving between WordPress blog URLs that are non-permalink pointing to the permalink ones and misspelling, or not properly working(/mapping) out the permalink, or forgetting to change the blog posting title into its URL-part-of constituent (see also WordPress Upgrade Links Tutorial), properly, in our heads (Nala??!!)

Of course, all this should be checked with the WordPress (Blog Post) Preview button ahead of it going live, but, there you go. Nala????!!!! We’re fixing them gradually, as an ongoing issue.

We’ve talked about broken links, and a programmable way to detect them, previously, with More Bookmarklet via Javascript Tutorial and WordPress plugins such as Broken Link Checker could help with this issue, as well.

And you’ll be pleased to know No puppy feelings were hurt in the production of this blog posting … it ended up being my fault.


Previous relevant More Bookmarklet via Javascript Tutorial is shown below.

More Bookmarklet via Javascript Tutorial

More Bookmarklet via Javascript Tutorial

Have you heard of Bookmarklets?

Are you a person with a cluttered (thoughtfully placed, of course) desk?

Yes? Read on … even if not, “Go to Jail … Do Not Pass Go” (maybe you were impressed by that idea that the Lord’s Prayer was Once Etched on a Pinhead? … yes? … read on down below … are you here? … oops … c’est la vie … read on) … read on … why?

This tutorial builds on Bookmarklet via Javascript Primer Tutorial below. For our tutorial we write a bookmarklet to check for Broken Links, something that could be very useful to run against the very common Links pages on websites today, so that you can check for those Broken Links that annoy the search engines so much and contribute to a lower SEO “score”.


<script type=”text/javascript”>
function checkBrokenLink() {
var bWin,j,b=”,tl=40,dl=document.links;
for(j=0;j<dl.length;j++){
if(b.indexOf(dl[j].href)<0){
bWin=window.open(dl[j].href,’BW’+j,’top=’+tl+’,left=620,width=400,height=120,
scrollbars=yes,menubar=no,titlebar=no,toolbar=no,status=no’);
tl+=120;
b+='<tr style=”height:120″><td>’+dl[j].href+'</td><td>’;
b+=dl[j].target+'</td><td>’+dl[j].id+'</td><td>’;
b+=dl[j].className+'</td><td>–></td></tr>’;
}
}
if(b===”){
alert(‘No links’);
}else{
bWin=window.open(”,’Links of ‘+document.title,’top=0,left=0,width=600,height=800,scrollbars=yes’);
bWin.title=’Links of ‘+document.title;
bWin.document.body.innerHTML='<table border=1 cellpadding=5 cellspacing=0><tr><th>Link of ‘;
bWin.document.body.innerHTML+=document.title+'</th><th>Target</th><th>ID</th><‘;
bWin.document.body.innerHTML+=’th>Class</th><th>Broken?</th></tr>’+b+'</table>’;
}
}
</script>

To get some downloadable Javascript programming code for this bookmarklet please rename to BrokenLinks.js and copy its contents into the address of your Bookmarklet to try this yourself.

Okay, if you have downloaded, take a look at how similar it is to code above. So you just place javascript: in front of the Javascript code required to do something interesting, all squeezed together onto the one line (no pinheads please) … this is where the cluttered desk people may continue breathing easily but others may falter.

Well, if you can place this sort of thing into a browser Bookmark then that is a Bookmarklet. Remember the Javascript calculator rave in previous tutorials?

Bear in mind we show Firefox in tutorial but all browsers have something similar, whether that be called Bookmarks or Favourites. Our tutorial shows the Safari browser using this Bookmarklet.

Regarding this Bookmarklet tutorial topic I really like “JavaScript & Ajax” seventh edition by Tom Negrino and Dori Smith.

Click on picture above to go to tutorial about Bookmarklets.

Did you know …
JavaScript makes a great easy-access Calculator?

Try typing the lines below into the address bar of your favourite browser:

Javascript: eval(512 / 380);
Javascript: eval(512 * 380);
Javascript: eval(512 – 380);
Javascript: eval(512 + 380);
Javascript: eval(512 % 380);

These days we spend so much time on the Internet it is a much quicker way to get to a calculator!


Previous Bookmarklet via Javascript Primer Tutorial below …

Bookmarklet via Javascript Primer Tutorial

Bookmarklet via Javascript Primer Tutorial

Have you heard of Bookmarklets?

Are you a person with a cluttered (thoughtfully placed, of course) desk?

Yes? Read on … even if not … read on … why?


<html>
<head>
</head>
<body>
<script type=”text/javascript”>

while (“abracadabra” != prompt(“Guess the magic word?”).toLowerCase()) {
alert(“Bad Luck”);
}
document.write(“<html><body><p>You win a cupee doll!</body></html>”);

</script>
<a href=’#’ onclick=’javascript: while (“abracadabra” != prompt(“Guess the magic word?”).toLowerCase()) { alert(“Bad Luck”); } document.write(“<html><body><p>You win a cupee doll!</body></html>”);’>Click me for another (confirmed) go … but limited offer on cupee dolls!</a>
</body>
</html>

Look at the cutesy wootsey HTML/Javascript above. Isn’t it cuuuuuuute?!
Isn’t it sweeeeeet?!

♫ Oh, aint she sweet, when she’s walking down the street,
Well I ask you very confidentially … aint … she … sweet. ♫

Enough of a sell job?

Okay look at the Javascript of one vs Javascript of one below in the a tag onclick bit. So you just place javascript: in front of the Javascript code required to do something interesting, all squeezed together onto the one line … this is where the cluttered desk people may continue breathing easily but others may falter.

Well, if you can place this sort of thing into a browser Bookmark then that is a
Bookmarklet. Remember the Javascript calculator rave in previous tutorials?

Bear in mind we show Firefox in tutorial but all browsers have something similar, whether that be called Bookmarks or Favourites.

Click on picture above to go to tutorial about Bookmarklets.

Link to downloadable source code of HTML above is bmark.html which you need to rename in order to try.

Did you know …
JavaScript makes a great easy-access Calculator?

Try typing the lines below into the address bar of your favourite browser:

Javascript: eval(512 / 380);
Javascript: eval(512 * 380);
Javascript: eval(512 – 380);
Javascript: eval(512 + 380);
Javascript: eval(512 % 380);

These days we spend so much time on the Internet it is a much quicker way to get to a calculator!

If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.

This entry was posted in eLearning, Tutorials and tagged , , , , , , , , , , , , , , , , , , , . Bookmark the permalink.

Leave a Reply

Your email address will not be published. Required fields are marked *