Prevent theft of the image links to other sites.

Collapse
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

    Prevent theft of the image links to other sites.

    prevent theft of the image links to other sites

    for facing the theft of files relating to other sites may use the code below:
    (.zip)

    primarily towards normal view this script uses renaming and copying a folder of images which can be viewed,
    this folder is emptied periodically, blocking the binding of images from other sites.
    first, to rename and copy the image into a temporary folder.
    then displays the image in that folder, renamed.
    to finally empty folder view to prevent third parties sites use path to.
    use two folders: storage and view.



    note: the storage folder must be hidden and can be used as folder upload
    in attach see the script, folders and demo image

    code:

    <?php
    /*
    prevent theft of the image links to other sites

    for facing the theft of files relating to other sites may use the code below:

    primarily towards normal view this script uses renaming and copying a folder of images which can be viewed,
    this folder is emptied periodically, blocking the binding of images from other sites.

    note: the storage folder must be hidden and can be used as folder upload
    */

    // this is the original image in classic way to view
    echo "ORIGINAL IMAGE<br />";
    echo "<img src = \"storage/original_image.jpg\" alt =\"original\"/><br />";


    // prevent hot link start

    // create code @rename + image
    function create_code($length=8,$use_upper=1,$use_lower=1,$u se_number=1,$use_custom=""){

    $upper="ABCDEFGHIJKLMNOPQRSTUVWXYZ";

    $lower="abcdefghijklmnopqrstuvwxyz";

    $number="0123456789";

    if($use_upper){

    $seed_length+=26;

    $seed.=$upper;

    }
    if($use_lower){

    $seed_length+=26;

    $seed.=$lower;

    }
    if($use_number){

    $seed_length+=10;

    $seed.=$number;

    }
    if($use_custom){

    $seed_length+=strlen($use_custom);

    $seed.=$use_custom;

    }
    for($x=1;$x<=$length;$x++){

    $code.=$seed{rand(0,$seed_length-1)};
    }

    return($code);

    }

    /*
    echo create_code(); // returns for example a7YmTwG4
    echo create_code(16); // returns for example Z77OzzS3DgV3OxxP
    echo create_code(8,0,0); // returns for example 40714215
    echo create_code(10,1,1,1,";,:.-_()"); // returns for example or)ZA10kpX
    */

    // rename the image
    // path may be ' $path = "".$row['picture'].""; ' by mysql
    $path = "original_image.jpg";

    // attach the code
    $repath = create_code(16);

    // copy image into view folder
    copy("storage/$path", "view/$repath".'_'."$path") ;
    echo "TEMP IMAGE<br />";
    echo "<img src = \"view/$repath".'_'."$path\" alt =\"original\"/><br />";


    // clean view dir after each view at 5 seconds
    function cleantmp() {
    $seconds_old = 5;
    $directory = "view";

    if( !$dirhandle = @opendir($directory) )
    return;

    while( false !== ($filename = readdir($dirhandle)) ) {
    if( $filename != "." && $filename != ".." ) {
    $filename = $directory. "/". $filename;

    if( @filemtime($filename) < (time()-$seconds_old) )
    @unlink($filename);
    }
    }
    }

    echo cleantmp();

    ?>

    the sistem delete the view folder and hot linking are not available, anyway you may use this error like 404 to redirect into your site,ads,etc

    remember, this is just a personal idea
    Attached Files
    Last edited by blackhowk; 03.10.09, 18:18.
    http://ngeo.ro

    #2
    thanks fella

    Comment


      #3
      Nice thanks

      Comment


        #4
        Bandwidth is the amount of data (information) being sent from the host server to the visitors computer. Each text letter, image, web page, and so forth is all really a bunch of data. A visitor comes to your web page, and all the data for displaying in their browser is transferred into their computer.

        Bandwidth theft (or hotlinking) is when someone else's site is linking directly to an image (or something) on your site instead of downloading the image and uploading it to their own server.

        This may not sound like a problem, but in some cases it can be a big one. Imagine you made an image and 100 other sites coded THIER pages to find that image on YOUR hosted area. If it was just your page alone, the bandwidth data transfer would be very small. Now that a hundred other sites are using the image on your server, that data transfer amount has just gone through the roof. Although this may not impact your site itself, your host server will be bogged down with all this extra transferring. Thus they may make you pay more dollars for hosting and/or cut you off entirely!

        This is not a solution to prevent a visitor from taking (saving) your image for use on their site. It is a prevention of linking directly to the image from your site to thiers.

        Using htaccess, you can have the hotlinked image appear as a broken (not found) image or you can replace it with a new image of your own design.

        IMPORTANT! Before doing any of this, you have to find out from your web host if they support mod_rewrite. If it does not, the rest of this page won't help you.
        You verified that mod_rewrite is active? Good. Now organize your image files a bit so they are in one separate directory. Most people do this already and it helps for main organization anyways.

        Now in the htaccess file that you save in that image directory, put this coding in...
        RewriteEngine on
        RewriteCond %{HTTP_REFERER} !^$
        RewriteCond %{HTTP_REFERER} !^http://(www\.)?mydomain.com/.*$ [NC]
        RewriteRule \.(gif|jpg)$ - [F]
        Replace mydomain.com with your actual domain name. That would take care of GIF and JPG files. You could add more to the coding to include MID and other file types. A broken or missing image should now appear on the other person's site.

        To add in a replacement image...RewriteEngine on
        RewriteCond %{HTTP_REFERER} !^$
        RewriteCond %{HTTP_REFERER} !^http://(www\.)?mydomain.com/.*$ [NC]
        RewriteRule \.(gif|jpg)$ http://www.mydomain.com/badimage.gif [R,L]
        As before, replace the mydomain.com with your own actual domain name and now replace the new image file location.

        IMPORTANT : make sure the replacement image is not being stored inside a hotlink protected directory. it must be in an "open" directory.
        http://ngeo.ro

        Comment

        Working...
        X