Stop User from using "Print Scrn" / "Printscreen" key of the Keyboard for any Web Page
Asked Answered
U

11

62

I am currently doing a project, in which I need to stop the user from taking the snapshot of any Web Page, for which he can use the "Print Scrn" / "Printscreen" key available in any of the normal keyboards.

I have been trying to find its solution, but in vain. If possible, I need to take into account of the "Screengrab" add-on of the Firefox browser, by stopping it also.

Any help is greatly appreciated, and I am using PHP (as server-side language) & jQuery for my project.

Unpriced answered 28/6, 2010 at 8:30 Comment(9)
You also need to take into account, at least, Cmd+Alt+3, Cmd+Alt+4, Cmd+Alt+Shift+3, Cmd+Alt+Shift+4, Grab.app, WebSnapper, SnapsPro, the humble Print dialog and a myriad of other tools for Mac users. And let's not even get started with all the other Windows and Linux ways there are to take screenshots.Nari
Okay, I apologize in making such a foolish question. But then can't I ask any such question as to which I didn't know at all?Unpriced
This is a perfectly legitimate question regardless of the feasibility of the request. We have all faced requirements that are dubious at best. Answering questions such as this helps explain why such requirements can not, nor should not, be implemented.Galicia
Thanks for supporting, as this question just showed me what sort of sin I have performed asking here!Unpriced
Down voting this question is the wrong thing to do. The question is fine and a lot of non webby people ask similar questions (see also popup/unders) Clearly the answer is "don't and you cannot anyway" however punishing the OP does no one any good.Hazzard
Wow, what a vote swing on this question! Is everybody just following the mood of the latest comment? (For the record, I voted neither way, which expresses exactly how I feel about this question.)Nari
The last time such idiotic websites happened my way, and I needed to print something (and surprise! The print button was disabled too!), I ran the damned site in a virtual machine, and took a copy from that. As a result, I was able to discuss results with a group of people who needed to look at the printout rather than having the group huddle around my computer which, thanks to the website in question, would process each click oh so very slowly. Printing it saved hours of my time. (And before you ask... Yes, that was perfectly legal).Immaterialize
Perhaps it's because this question has been asked 935835 times before...Firstrate
Good question. I apologize on behalf of the try-hards who try to haymaker you. The question is a good question. It cannot be done 100% and may cost you in regards to UX. I still admire the question because I once wanted to know this. I also admire it because look at the tons of ideas that spilled out of very talented developers' brains. I have no idea why some experienced devs can be so harsh on the new guys. The site was designed to learn and grow, but some make people run away before they get going. Sad. Thanks for your question! I loved the ideas that it brought forward. Added value to SOTouchback
E
39

You can't disable screen grabbing from the Web browser, it would only be possible by installing additional software on the user's PC.

There are some IRM (Information Rights Management) tools available that do that e.g. by protecting Windows/DirectX API calls and also monitoring video memory such as Oracle IRM or such as Microsoft's IRM technology.

Especially the latter might be of interest as there is also a Rights Management Add-on for Internet Explorer.

But as other already said, any IRM/DRM technology is controversy and you should understand that it most often will limit or annoy your users.

Elastic answered 28/6, 2010 at 13:8 Comment(4)
I wouldn't say IRM is a "controversy". On the internet it is foolish to even consider it, but on a corporate environment it makes sense. Companies have IRM installed in every computer, and for a good reason. It sends a clear message to employees: "This data is sensitive". If it isn't trivial to copy the data, the employee wouldn't try further.Uncinus
@Chris - "Never attribute to malice that which is adequately explained by stupidity". If a hostile employee can see it she can steal it, however, IRM is very efficient in restricting data and preventing unintentional data leaks, and makes a good way of marking sensitive documents.Uncinus
Thank you for making it clear how user-hostile and poorly-received something to accomplish this would be.Eulogy
how netflix does that..no screnshot no printscreen screen record screensharing using app like skype..everything bocked there howGalangal
K
57

I hate the "it's not possible" sentence. Here's all solutions combined to help you:

1- You can grab the solution from Haluk:

<script type="text/javascript"> $(document).ready(function() {
    $(window).keyup(function(e){
      if(e.keyCode == 44){
        $("body").hide();
      }

    }); }); 
</script>

HOWEVER, you hide body, but's already "printed" to clipboard. You can fire another event that copy some text to your clipboard, as you can see on this answer "Edit as of 2016" Click button copy to clipboard using jQuery , it's something like this:

function copyToClipboard() {
  // Create a "hidden" input
  var aux = document.createElement("input");
  // Assign it the value of the specified element
  aux.setAttribute("value", "Você não pode mais dar printscreen. Isto faz parte da nova medida de segurança do sistema.");
  // Append it to the body
  document.body.appendChild(aux);
  // Highlight its content
  aux.select();
  // Copy the highlighted text
  document.execCommand("copy");
  // Remove it from the body
  document.body.removeChild(aux);
  alert("Print screen desabilitado.");
}

$(window).keyup(function(e){
  if(e.keyCode == 44){
    copyToClipboard();
  }
}); 

This will block a part of your problem. If user focus on another object outside this windows he will be able to take screenshots. **But there's another solution to that as well, simply disable the hole body when window get's unfocused. Full solution, from your dear brazillian friend:

function copyToClipboard() {
  // Create a "hidden" input
  var aux = document.createElement("input");
  // Assign it the value of the specified element
  aux.setAttribute("value", "Você não pode mais dar printscreen. Isto faz parte da nova medida de segurança do sistema.");
  // Append it to the body
  document.body.appendChild(aux);
  // Highlight its content
  aux.select();
  // Copy the highlighted text
  document.execCommand("copy");
  // Remove it from the body
  document.body.removeChild(aux);
  alert("Print screen desabilitado.");
}

$(window).keyup(function(e){
  if(e.keyCode == 44){
    copyToClipboard();
  }
}); 

$(window).focus(function() {
  $("body").show();
}).blur(function() {
  $("body").hide();
});

Here's the example working:

Here i try to unfocus the window, on unfocus i hide content and show modal

Kalfas answered 3/6, 2016 at 0:23 Comment(6)
I'v posted this months ago with my another facebook account. Anyway to change this answer to my current Facebook account?Stylopodium
Cool solution. Thanks. But it still has few flaws: Combination Win + Print screen. And of course, no one could prevent screenshotting simply by camera :)Perfunctory
In Windows 10 IE 11, I get an alert that says "Do you want to allow this web page to access your clipboard?...". This is unacceptable for our client. So it seems there isn't a way to do this for us.Rhetorical
For years I'v been saying developers should block IE. IE has been our nightmare and the chains that holded internet evolution for years . But here's a partial solution: show a message that user should allow copy/paste and show a huge text with symbols that he must copy and paste on a textbox. And recomend others browsers to user to avoid complications. Did I got too far?Stylopodium
I will suggest to use the "mouseover" instead the focus. $(window).mouseover(function () { $("body").show(); }).mouseout(function () { $("body").hide(); });Wheelhouse
Your solution works but as @Perfunctory said there's flaws where you can use win+print and still able to screenshot it. Is there any possible way to disable that as well?Syncope
S
46

This is not possible.

Sidwel answered 28/6, 2010 at 8:31 Comment(11)
And if it were, it would be circumvented quite quickly.Civies
The "print screen" key is an OS functionnality, and you have absolutely no right to alter its behaviour from a web page. This is like installing a software on the hard drive. Generally speaking, there is no real way to prevent an user from downloading the content of a website. You can just make it a little more difficult, but it would only be a matter of time.Octofoil
In general: at some point the data must be displayed to the user. At that point, any determined user can capture it. If nothing else, there are devices that will sit between your PC and monitor, completely seperate from the PC and record anything sent to the monitor.Vigorous
Or they can use a camera, which may be totally unattached to any computer. They could even use a camera which records on film without any digital components at all; no way to stop that other than to never show the information to the user at all.Eppie
Such a restriction would be so annoying to users that they would probably never go back to your page again. That would prevent them from printing, but I don't think that's what you want. BTW writing a code snippet that downloads a page is as easy as WebClient.DownloadString (if you write .NET) or any of the myriad equivalents in other languagesPervade
@JSmaga That'll be the most single-purpose OS ever: "Features: Can't take screenshots! " ;DNari
@Nari In 6 months you can release the service pack 1 including the "Anti copy-paste feature"Tiruchirapalli
@Nari @JSmaga well.... It still would be better than Vista! xkcd.com/528Pard
Even with an OS without screenshot abilities, you could still put the screen on a scanner or take a photo of it :pBaeda
@Baeda your comment was one of the funniest I have read on SOTullis
Is this even consider an answer?Loam
E
39

You can't disable screen grabbing from the Web browser, it would only be possible by installing additional software on the user's PC.

There are some IRM (Information Rights Management) tools available that do that e.g. by protecting Windows/DirectX API calls and also monitoring video memory such as Oracle IRM or such as Microsoft's IRM technology.

Especially the latter might be of interest as there is also a Rights Management Add-on for Internet Explorer.

But as other already said, any IRM/DRM technology is controversy and you should understand that it most often will limit or annoy your users.

Elastic answered 28/6, 2010 at 13:8 Comment(4)
I wouldn't say IRM is a "controversy". On the internet it is foolish to even consider it, but on a corporate environment it makes sense. Companies have IRM installed in every computer, and for a good reason. It sends a clear message to employees: "This data is sensitive". If it isn't trivial to copy the data, the employee wouldn't try further.Uncinus
@Chris - "Never attribute to malice that which is adequately explained by stupidity". If a hostile employee can see it she can steal it, however, IRM is very efficient in restricting data and preventing unintentional data leaks, and makes a good way of marking sensitive documents.Uncinus
Thank you for making it clear how user-hostile and poorly-received something to accomplish this would be.Eulogy
how netflix does that..no screnshot no printscreen screen record screensharing using app like skype..everything bocked there howGalangal
P
15

Try this

$(document).keyup(function(e){
  if(e.keyCode == 44) return false;
});

Hope it works

Pshaw answered 28/6, 2010 at 8:36 Comment(3)
This falls apart very quickly: simply focus on a different window, then screengrab.Vigorous
As I stated below, fairly sure the keyup event is fired after the screen is already "printed"...Geophyte
@MatthewScharley he can avoid using this code: $(window).focus(function() { $(".content").show(); }).blur(function() { $(".content").hide(); alert('nonono, no donut for you!'); });Stylopodium
P
15

Thankfully, this outrageous idea is not possible to implement reliably, neither the "disable screen grab" part nor the "disable user's Firefox extensions" one. And even if it were, as @kbok points out in his comment above, you don't have a right to do this.

The only way to protect your content online is copyright laws - mentioning those is often enough to scare people away from misusing it! - or not showing it at all.

Pard answered 28/6, 2010 at 8:41 Comment(2)
Mentioning copyright laws is frequently enough??? Says who? Millions of people across the globe steal media copyrighted by others. US protections do not suffice overseas. It's a federal crime with steep penalties including large six-digit fines and several years in jail. It's not an outrageous idea. Simply one from a new developer trying to help protect media he or his clients own. You have a right to do whatever you want with your website in regards to protection. UX may come into play. Not everyone can afford litigating copyright violations. Even if they could win, it takes time & money.Touchback
Several large tech companies, who I will refrain from naming, have stolen patented ideas and locked the patent up in court for years and spent millions of dollars to fight until little guy has to leave his prize.Touchback
H
6

You can change the contents of the clipboard using JavaScript or Flash. This already helps a bit.

Honky answered 29/6, 2010 at 5:20 Comment(0)
B
4

Like @Sjoerd said, this is not possible.

If it is pictures you want to protect, I suggest you for example display lower quality images that are watermarked instead and only display the non watermarked high quality ones when appropriate.

But yeah... If you want them to be impossible to copy... don't put them online.

Baeda answered 28/6, 2010 at 8:44 Comment(4)
I don't like this term "not possible"... of all the things in the universe this is not something I would say is "not possible". I think the word unfeasible is better suited. Maybe I’m being pedantic, but I just don't like us, as the human race, selling ourselves short. Someone could do it if they really wanted. Hence... entirely possible.Osteoclasis
Although you don't like, there are many imposible things. And this is one of those.Camarilla
Yeah, how on earth would you make that impossible? If it's on the screen, it's nothing you can do. How would you prevent someone from taking a camera and shooting a photograph of the screen for example?Baeda
It is "not possible"... if it can be viewed, it can be copied in some fashion.Geophyte
U
4

There is no direct method to do that, however, there is a way to protect your content as much as possible from prnt scrn.

The idea is this:

  1. make your content inaccessible if java is disabled, and use some script like Artist Scope's copy protect.

  2. Detecting prnt scrn will send a message to the admin with the registered user info, this means that restricted content that is accessible by members only can benefit from this. sending IP addresses sounds like a good idea, but banning IPs is not, so you won't gain a lot of benefit from that.

  3. Once outside your website's window, your content will be covered with an overlay that can't be removed unless you get back to your website and activate it, which will re-activate the prnt scrn detection code mentioned in the previous point.

  4. If the device is a mobile, you can either hide images, or as in my case, redirect to a "we're sorry" page.

  5. snipping tool and other similar browser extensions and add-ons will be useless. except one tool that I have found called full page screen capture

    • this tool captures web content after about 3 seconds from pressing button, which is enough time to dismiss the overlay and get back to your content
    • a good turnaround is to start a counter when "dismiss overlay" is clicked that will need 5 seconds or more, ie. after this extension has already taken a snapshot
  6. There's also an indirect method to prevent video capture, still working on it, will post it here or in my blog.

  7. If your content is really that much worth it, users might still capture it using their cameras, there might be a method for that too! But I sill need to do some research before talking about it.

I will be updating this post in my blog for other techniques that I've used/ will use for more protection. Please check this quiz (still under development) for a demo.

Uric answered 20/10, 2014 at 18:26 Comment(0)
S
4

You can copy to clipboard something else, when user click key print screen. This is example and I copy user text.

<p id="test">test</p>

function copyToClipboard(elementId) {

  // Create a "hidden" input
  var aux = document.createElement("input");

  // Assign it the value of the specified element
  aux.setAttribute("value", document.getElementById(elementId).innerHTML);

  // Append it to the body
  document.body.appendChild(aux);

  // Highlight its content
  aux.select();

  // Copy the highlighted text
  document.execCommand("copy");

  // Remove it from the body
  document.body.removeChild(aux);

}
$(document).ready(function(){
    $(window).keyup(function(e){
      if(e.keyCode == 44){
        copyToClipboard('test');
      };
    });
});
Steric answered 7/12, 2015 at 12:38 Comment(1)
It's not even getting to $(window).keyup(function(e){ partAngilaangina
T
2

Why do you want to prevent the print screen?

If it's some photos you want to protect, you might want to put it in low resolution, and include some kind of copyright logo programmatically in php.

I think that's pretty much it.

Tiruchirapalli answered 28/6, 2010 at 8:58 Comment(0)
B
2

Here is another solution:

<script type="text/javascript"> $(document).ready(function() {
    $(window).keyup(function(e){
      if(e.keyCode == 44){
        $("body").hide();
      }

    }); }); </script>

This is similar to @ZX12R's solution. The upside is this code will work even if the print screen catching software is a 3rd party tool (eg snagIt).

You can replace $("body").hide(); with something which will suit you better. For instance you can hide all the pictures $("img").hide(); and maybe show them back a second later.

The downside is it will not work if the web page is not the active window.

Bobbee answered 20/9, 2011 at 19:54 Comment(3)
I am pretty sure the "print screening" has already occurred before the keyup event is fired...Geophyte
Can also use the Snipping tool or similar, or just press the print screen key without the window active, and the webpage won't even get the event.Baeda
Unfortunately this will not work on OS X since the key combo is completely different.Disincentive

© 2022 - 2025 — McMap. All rights reserved.