2012-03-15 13 views
7

me gustaría evitar que un usuario sea:copia Prevenir/pegar y haga clic en el botón derecho del significado de cuadro de texto (correo electrónico)

  1. Copiar y pegar desde el primer cuadro de texto a la segunda
  2. botón derecho del ratón y use el menú contextual para copiar y pegar desde el primer cuadro de texto hasta el segundo.

esto no está funcionando.

<html> 
    <head runat="server"> 
    <title>Confirm email page</title> 
    <script type="text/javascript" language="javascript"> 
    function DisableRightClick(event) { 
     //For mouse right click 
     if (event.button == 2) { 

     } 
    } 
    function DisableCtrlKey(e) { 
     var code = (document.all) ? event.keyCode : e.which; 
     // look for CTRL key press 
     if (parseInt(code) == 17) { 
      window.event.returnValue = false; 
     } 
    } 
    </script> 

    </head> 
    <body style="font-family: Verdana; font-size: 1em"> 
    <form id="form1" runat="server"> 
     <div> 
     <h1>Confirm Email</h1> 
     <asp:Label ID="Label2" runat="server" Text="Enter Email Address: "></asp:Label> 
     <asp:TextBox ID="TextBox2" runat="server" oncopy="return false" onMouseDown="DisableRightClick(event)" ></asp:TextBox><br /> 
     <asp:Label ID="Label3" runat="server" Text="Confirm Email Address: "></asp:Label> 
     <asp:TextBox ID="TextBox3" runat="server" onKeyDown="return DisableCtrlKey(event)"></asp:TextBox><br /> 
     </div> 
    </form> 
    </body> 
</html> 

GOT IT WORKING !!!!

<div> 
<h1>Copy Paste Preventer!!!</h1> 
    <asp:Label ID="Label1" runat="server" Text="Enter Username: "></asp:Label> 
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox><br /> 
    <asp:Label ID="Label2" runat="server" Text="Enter Email Address: "></asp:Label> 
    <asp:TextBox ID="email" runat="server" oncopy="return false" onpaste="return false" oncut="return false" oncontextmenu="forms[0].elements[0].value++; return false"></asp:TextBox><br /> 
    <asp:Label ID="Label3" runat="server" Text="Confirm Email Address: "></asp:Label> 
    <asp:TextBox ID="TextBox3" runat="server" oncopy="return false" onpaste="return false" oncut="return false" oncontextmenu="forms[0].elements[0].value++; return false"> </asp:TextBox><br /> 
</div> 
+0

Por favor no uses el prefijo sus títulos con "C# ASP.Net" y tal. Para eso son las etiquetas. –

Respuesta

2
<div> 
<h1>Copy Paste Preventer!!!</h1> 
    <asp:Label ID="Label1" runat="server" Text="Enter Username: "></asp:Label> 
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox><br /> 
    <asp:Label ID="Label2" runat="server" Text="Enter Email Address: "></asp:Label> 
    <asp:TextBox ID="email" runat="server" oncopy="return false" onpaste="return false" oncut="return false" oncontextmenu="forms[0].elements[0].value++; return false"></asp:TextBox><br /> 
    <asp:Label ID="Label3" runat="server" Text="Confirm Email Address: "></asp:Label> 
    <asp:TextBox ID="TextBox3" runat="server" oncopy="return false" onpaste="return false" oncut="return false" oncontextmenu="forms[0].elements[0].value++; return false"> </asp:TextBox><br /> 
</div> 
4

cuando se utiliza jQuery esto es bastante simple y es totalmente compatible con ASP.NET:

<script type='text/javascript' src='http://jqueryjs.googlecode.com/files/jquery-1.3.2.min.js'> 
</script> 
<script type="text/javascript"> 
    $(function() { 
    $('input[id$=TextBox2]').bind('cut copy paste', function(e) { 
      e.preventDefault(); 
      alert('You cannot ' + e.type + ' text!'); 
     }); 
    }); 
</script> 

Aquí es un artículo que explica cómo funciona esto, junto con ASP.NET:
http://www.dotnetcurry.com/ShowArticle.aspx?ID=398

mientras Scott señaló: en la producción, se debería poner la referencia jQuery en la parte inferior de su html sin embargo (aún dentro del cuerpo de la etiqueta).

ACTUALIZACIÓN
Dado que pidió a prevenir el menú contextual del todo se puede hacer algo como esto:

Añadir este script:

<script type="text/javascript"> 
    document.getElementById('TextBox2').oncontextmenu = function(){ 
     return false; 
    }; 
</script> 

El elemento de menú no se muestra cuando se devuelve false . He aquí un resumen de browsersupport para esto:
http://help.dottoro.com/ljhwjsss.php

+0

Yo seleccionaría los elementos por clase $ (". NoCopy"). Bind (... Luego esta restricción se puede colocar en cualquier elemento con esa clase CSS – David

+0

+1 para esta respuesta. Solo para ser completo, cualquier Javascript La solución se puede eludir mediante la desactivación de JS en el navegador. Pero eso está más allá del usuario promedio. – mgnoonan

+0

Gracias. El problema es que no quiero una alerta. Preferiría que el menú contextual de Windows no aparezca cuando usted ... haga clic en y que las funciones de copiar y pegar ctrl no están permitidas. – Susan

Cuestiones relacionadas