广西经贸职业技术学院论坛
标题:
[建站技术]网页加密完全攻略
[打印本页]
作者:
月中水
时间:
2009-10-16 01:19
标题:
[建站技术]网页加密完全攻略
现在专业性的网站越来越多,许多网友们都在网上建立起了自己的小家。不过辛辛苦苦制作的网页被人拿去改头换面却是件非常痛心的事,所以大家都想保护自己独创的作品,为自己的网页上把锁,今天就让我带大家了解一下如何给我们的网页加上一把密码锁。
9 A- d5 F# Y. C
+ T- L! m1 r* g1 H
一、常用JavaScript密码锁
. H5 t8 j- y1 R7 O* ?' x
+ w2 q! V4 G- h1 Q& [6 Q5 o
1. 了解javascript
- i0 ?4 | N% q0 N6 S6 j1 d
6 \7 Y) A% ~( q/ a: T0 o# ~ }! }( E
JavaScript是一种新的网页描述语言,是由Sun公司以及网景Netscape公司开发的,此一语言可以被嵌入HTML的文件之中,使用它可以让你设计交互性的网页内容。
) L) ?$ s+ D3 E% W8 q
& j3 W- P: b) p F
2. javascript特点
1 ]& O# z# K1 e9 i, O9 R ~
0 d" D1 w4 i* x: O! z {
使用javascript非常简单,只是一小段代码,就可以让网页发生千奇百怪的效果,而且使用javascript来加密的方法是网络中加密最常用的方法。
% k2 T. m b) g# F; i5 j
8 d. t+ X1 S0 `% s. K
3. 使用javascript加密
. ]& a$ x2 M$ _0 W* v9 K8 ~
) [3 p( I5 g2 f3 w9 Q0 y1 J
使用javascript加密最简单的结果就是让浏览者不能使用鼠标右键,当他点击右键想对图片进行保存或者复制文字的时候就会弹出一个警告窗口或是弹出收藏夹等。
# W! s5 k) \) ^3 m+ `! L
$ ?5 E0 R: f* e. Y" F6 E5 W
实现方法:
$ z: K( I& ~ b5 T4 G" O) x) ^* r; W0 R; P
) _4 _6 t2 L# e5 \$ k
(1)利用弹出窗口封锁鼠标右键将下面这段代码放在网页HTML代码的<head></head>标志中,就可以实现封锁右键,给网页加密。
. ^1 x# {8 u. Q+ M& q3 @
: I" m+ L3 c5 x; j0 n v+ m
: `. T: `" f! c$ ^
% b0 u8 [* G% V
<script language="javascript">function click() {if (event.button==2) {alert('本站不准使用右键,使用左键吧!^_^') }}document.onmousedown=click</script>
3 G: H: z- ]* b: s6 g& I+ o
' D! {4 k7 N% ~$ @
9 R9 O* s3 H0 `* z7 f6 O' ]
8 I* [0 b$ P* O6 R$ n2 ?
/ i/ z. r+ K% ^) l6 B, N# k
% u6 c8 P. d0 k9 w$ t6 [
(2)弹出“添加收藏夹”封锁鼠标右键将下面这段代码放在网页的HTML代码的<head></head>标志中。实现点击右键出现“添加到收藏夹”选项。
) J9 r" k+ E1 B4 S
8 v' j# I$ d8 A* Y& s' g8 F
6 J! M1 L4 C8 G; }
2 w& k' N& z' @! _; _5 z
<script language="javascript">function click() {if (event.button==2) {window.external.addFavorite('http://www.51CTO.com/,' 51CTO')}}document.onmousedown=click</script>
0 u# f: |, [ v1 k% e h) H3 i' `
4 L* d+ N) C/ Q7 r7 i1 n3 L: x% [& R
0 v- G$ k# K3 U/ E( L
& s0 D& f$ E7 ^6 J! @; c
! A2 q" T% H7 @ f. X
) ^- D& G% N) r/ ^8 K
(3)彻底封锁鼠标右键将下面这段代码放在网页的HTML代码的<head></head>标志中能够实现彻底封锁鼠标右键的效果,由于这个脚本在右键按下时调用一个函数,所以可以改为很多种类型。即使按下左键,再按下右键,放开左键,再放开右键的方法也还是破解不了。
: Q/ o! y9 }" j# _. K/ B/ s. b
4 _3 M# P9 G. o9 P0 \( x* I; y
<script>function DM(e){if(!ns){if(event.button>1)window.external.addFavorite('http://www.popunet.com/,' 大众网络报')}else{if(e.which>1)return false}}ns=navigator.appName=="Netscape";if(ns)document.captureEvents(Event.MOUSEMOVE|Event.MOUSEDOWN);document.onmousemove=DM;document.onmousedown=DM;</script>
6 _% r8 C5 r0 x6 t. L0 X
) J$ m* i8 w0 S( A$ e7 \) W( ~9 v
( _; d. z% V8 y
& e$ k$ d+ W' o: y2 {
2 S- l$ s5 v4 Q/ ?2 Z! R
2 S: }) P* K5 H2 R
(4)禁止查看源文件将下面这段代码放在网页的HTML代码的<head></head>标志中则可以实现禁止利用IE浏览器查看源文件。
: m- Y: P& W# S
/ l0 Z! q# U3 f( N4 p2 j+ B: Z: m7 Y
% l6 {7 r) G$ J, T/ w3 q
+ G/ E( p! m% m6 ~5 C! O
<script language="JavaScript"><!--document.onmousedown=clickfunction click() {if ( event.button==2) {alert('不准查看源文件') }if ( event.button==3) {alert('不准查看源文件') }}//--></script>
& E( Y4 C. r5 E0 A, j& A
! i$ G& O8 x$ W* j, W/ r
& Y6 T9 }. f9 O1 R
, f- T7 n8 K5 e+ @2 j& ^6 o
6 L' M9 d9 U$ }3 O) K4 j
. L4 u; Z) v4 h+ a& \
(5)用乱码显示链接、调用地址加密。利用某些函数把URL字符转换成ASCII码,从而达到隐藏链接Frame页面和*.js,*.asp等脚本的目的。返回ASCII码escape(character),ASCII码为%XX格式,XX是十六进制,如空格键为%20。返回字符unEscape(string)
" O, D7 W% H- y, J8 h
2 q0 s* g3 D0 j: r! |
如:
$ t8 O/ x* W5 v5 W& u3 O
# ~# d, e" Y3 U) q4 T, g) F+ B! ?
' [' d; {, X) U. H$ @, Q
( o9 r+ g$ t1 G( s: B/ x' h
<!—var Words=" %3Cframeset%20BORDER%3D%220%22%20FRAMEBORDER%3D%220%22%20FRAMESPACING%3D%220%22%20rows%3D%22100%25%22%3E%0D%0A%20%20%3Cframe%20SRC%3D%22http%3A//XXX.XXX.COM/XXX/XXX/%22%20NAME%3D%22oos1%22%20"//--></script>
% h% U- i @, m7 @
" Z, s* s; _+ ?7 J$ ` o# ]
: K1 G' o0 O. ^
; T7 a" }% R9 V3 y2 {( J
% b, ^! N a' ^5 X/ n3 ~+ m1 L
利用javascript还可以使用调用脚本显示页面加密、密码校验等加密方法,但是由于代码繁杂而不经常使用,这里就不多讲了。
: x/ q) e2 b0 ~) R
. W1 L' U: \8 i9 H9 p/ {1 k
二、使用IIS的密码锁
$ l8 Q" G$ u/ v3 F
1 |. `, M+ Q2 k% P% l$ J" R- f
不要以为只有javascript可以加密,使用IIS也可实现加密,只要你电脑上安装的Web服务器是IIS,而你又是管理员权限的用户时,就可以用一种简单的方法来实现密码验证。(注意:使用Win 2000 Server版并安装了IIS及域用户管理器)
; H0 i7 ~6 H! C% ^( N1 E; I
3 t+ {# f6 q0 }. k) X
1. 启动“Internet 服务管理器”
; i3 |( n! ~! l& d6 r, ~
6 h0 D- B( w o- @% X: J
步骤一:单击“开始”>“设置”>“控制面板”,双击进入到“管理工具”中,打开“Internet 服务管理器”,展开左窗口的“默认Web站点”,然后在其所展开的目录中选中我们想对其进行加密的目录(如:lastcoco),然后单击“属性”按钮,打开“lastcoco属性”对话框(如图1)。
1 z# Z! {' Y# b+ Q& \' o7 D# l
5 y! l& B7 {. g/ m& L, I$ s
3 Q2 n/ l* h3 k3 F$ W- W) E( r
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_720fe38fbd4a2df.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_720fe38fbd4a2df.jpg" border=0>
! K. d$ \* R7 c1 L% g" m
& ^% z# |; w& G L. J5 l, Q
图 1
8 u) {% U0 r3 y# x: a' h
" k! w4 X/ }2 Q0 |) q2 c
步骤二:选择“lastcoco属性”对话框中“目录安全性”标签,单击“匿名访问及验证控件”域中的“编辑”按钮。这时会弹出“验证方法”对话框,在“验证方法”对话框中,取消“允许匿名访问”选项前面的勾选,然后勾选“基本验证(密码用明文送出)”选项,最后单击“确定”按钮退出(如图2)。
4 l$ T4 A* O# U2 Z$ k! T
. ]+ _! G# Q& p6 I) y7 _
# O# W7 `5 S! C5 w" |! y" u/ J3 }
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_f6813cfa62ffc57.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_f6813cfa62ffc57.jpg" border=0>
2 t/ H+ x% o e5 i* ~7 H/ Y
图 2
, S- f) e6 u& k+ r$ O, u) t0 k
/ }5 } U: j- A' G# y$ ?( a
2. 使用“域用户管理器”设置用户的名称及密码
2 U4 U4 b5 S4 F$ S k0 |0 z
7 u+ E+ u; n# h' I4 R
光对目录的安全设置了还不行,为了让上网的朋友们只有在输入用户名称和密码后才可以浏览放在该目录下的网页,我们还要使用“域用户管理器”设置用户的名称及密码。
2 j. r' D) [! X( G1 z
5 T9 l$ s B3 \+ o ]1 i1 X- d
单击“开始”>“程序”>“系统管理工具”(公用)>“域用户管理器”,启动“域用户管理器”(如图3)。在这里我们给域用户里添加新用户,选择“用户”>“新用户”,然后在“新用户”窗口中输入新用户的“用户名及密码”等等,然后取消“用户下次登录时须改变密码”的选项。
/ y5 E* r' H5 Y) @8 M; m
0 ~. f# G6 h2 m' C! P3 x
h0 [) U7 w5 x- }( l
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_7a91f6d2b01e86e.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_7a91f6d2b01e86e.jpg" border=0>
- z4 n; v! K2 d$ r1 e- Y
图 3
3 ~3 T# n$ x" F
+ R# N/ q8 k3 H6 b( m7 {
到此为止,利用IIS服务器来给网页加密就全部完成了,当用户想访问安全目录下的网页时。只要在出现的“输入网络密码”窗口中输入我们在“域用户管理器”中设置的新用名名及密码就可以进入安全设置目录(如图4)。
* `2 e& J( X; f% ~" ?2 F
! P; {6 R6 v& s! a; Y
6 Z7 H( }0 n7 `8 E& U
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_b59491193af79ec.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_b59491193af79ec.jpg" border=0> 图 4
2 X# z2 V) V, D2 _' i2 V7 t
) P4 U9 p# a# g+ S S; c5 f4 \& |
三、使用ASP程序密码锁
7 v, X+ L- S# E, j
# U& T4 N: i' q7 g; J
除了使用IIS服务器来给网页加密,我们还可以使用ASP程序来给网页进行加密,一般来说利用程序来进行密码验证的方法比较通用,现在大多数网站都使用ASP程序,它对Web服务器没有具体要求,而其加密就是借助数据库及ASP程序进行设计,来实现一种通用网页加密。
2 D4 }* ~, @! V( y" W7 ?1 K: z
1 p" |* `! i3 I! m% T8 {
1. 打开Microsoft Access,建立一个“用户名及密码”的数据表,假设将这个表取名为User,数据库名为lastcoco.mdb,数据表的结构如下:
* l! N8 H% M8 a# z, e9 k# F! [% T* N
& {) o8 \! |' O( _
字段说明 字段名称 数据类型 数据长度
! T* T4 @' K7 A# l5 r% i
& _% e; X* m2 ^: _7 L
用户名称 ID文本 15
# Z& V, F, C7 A! c
9 v5 J$ ]; X, q4 @
密码 PWD 文本 15
# {4 `' U. d3 X% F) f
; B5 J, e1 ~! q! D$ p/ Y
2. 编辑一个PASS.ASP的验证文件,源代码如下:
2 l$ i: O) X. }0 Q
4 y6 e0 Z6 U; W9 h
. [+ N/ v% v1 X* v; ^$ d& q
& |0 i0 B. ?- m `3 L+ n
<%Function Check( ID, Pwd )Dim conn, par, rsSet conn = Server.CreateObject("ADODB.Connection")par = "driver={Microsoft Access Driver (*.mdb)} "conn.Open par && ";dbq=" && Server.MapPath("lastcoco.mdb ")sql = "Select ? From users Where ID='" && ID && "' And Pwd = '" && Pwd &&"'"Set rs = conn.Execute( sql )If rs.EOF ThenCheck= FalseElseCheck= TrueEnd IfEnd Function%><%If IsEmpty(Session("Passed")) Then Session("Passed") = FalseHead = "请输入用户名和密码"ID = Request("ID")Pwd = Request("Pwd")If ID = "" Or Pwd = "" ThenHead = "请输入用户名和密码"Else If Not Check( ID, Pwd ) ThenHead = "用户名称或密码有错"ElseSession("Passed") = TrueEnd IfIf Not Session("Passed") Then %><html><head> <title></title> </head><body BGCOLOR="#FFFFFF"><h2 ALIGN="CENTER"><%=Head%></h2><hr WIDTH="100%"><form Action="<%=Request.ServerVariables("PATH_INFO")%>" Method="POST"><table BORDER="1" CELLSPACING="0"><tr><td ALIGN="RIGHT">用户名称:</td><td><input Type="Text" Name="ID" Size="12" Value="<%=ID%>"></td></tr><tr> <td ALIGN="RIGHT">密码:</td><td><input Type="Password" Name="Pwd" Size="12" Value="<%=Pwd%>"></td> </tr></table><p><input Type="Submit" Value="确定"> </p> </form><hr WIDTH="100%" align="center"></body> </html><%Response.EndEnd If %>
t5 d9 C& |4 P
& r- _& w" u, Z/ K$ Q
7 K1 ^! m6 E' W/ g+ S$ A
$ R+ i# [5 }& e# B
& c* g. P5 {- J/ Y
3. 在需要加密网页的HTML代码最前面加上〈! --#include file="pass.asp"--〉就可以了。由于这个验证合法性的页面具有通用性,所以非常方便使用。
8 s" G/ k- ?; ], ~8 ]: ~
, c: q& w1 q2 Z# h# s
四、使用软件密码锁
$ S0 N) M. |. `% e/ @: z# c
6 B& E% b7 ^3 z' P/ d* y5 S
现在给网页加密的软件非常多,这里就不一一讲解,其基本原理都是利用javascript代码,只不过是这些软件都自动准备好了这些代码,只需使用者将网页源代码粘进去按一下加密按钮就OK了。
4 O* D( k( ?( X7 ?* v7 R# a
! U) Q9 D0 U. o. E" m
在这里我们介绍一款绿色的小软件“世纪鸟网页加密精灵”,大家不要小看这只鸟,通过这只小鸟,能更方便快速的对网页进行加密。
' G4 O! r* f* P5 f
5 j% w; d2 j5 r* m: i9 }
下载双击打开这只小鸟,只见XP风格的界面跳到眼前,左边竖着一排是加密选项按钮,分别是“网页代码加密”、“网页登录密码”“鼠标右键屏蔽”、“网页选择屏蔽”、“鼠标右键对话”、“框架包含限制”这些。右边则是网页代码加密对话框,在这个对话框中进行对网页的加密,而且在对话框上方给出每个选项的解释,在对话框下方则是建议。
; r G1 Y( f9 @: [2 D
# ?+ K0 J; y* g4 M+ y! H
这里我用实例给大家讲解使用“世纪鸟网页加密精灵”的“网页登录密码”选项来给网页加密。
* T* K- b: K# d% v6 i
# F. H; t$ [' M
1. 打开要加密的网页,复制出HTML源代码,然后打开“世纪鸟网页加密精灵”软件,选择“网页登录密码”选项,这时在右边就会出现一些输入框内的代码说明(如图5)。
; K& E8 e+ r! |+ b7 s6 }
& T3 I; [. p- r$ u7 c
- A* P8 Z' r2 ~0 _, d+ ^8 D
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_4bc7d3a1b1188ab.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_4bc7d3a1b1188ab.jpg" border=0>
% c4 D0 \2 I7 P% O! g' f4 C0 m
图 5
5 U8 p9 ^* @' |/ x, M
$ S7 x+ V. A- M; e7 n
2. 在“请输入登录密码”的输入框中输入长度小于10位的密码,然后单击“生成并复制密码页面程序”按钮,这时软件会自动在下方的javascript代码中加入你输入的登录密码做为验证信息,并将这段代码复制到你的剪贴版中(如图6)。
: n7 ?% T; ^" B
: C9 x' E# z7 r a+ h- s$ ^
* r% a9 G) ^3 I, p. _' J: [
=780) window.open('http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_6e55ffb19ce7294.jpg');" src="http://bbs.security.ccidnet.com/attachment/Mon_0706/25_419427_6e55ffb19ce7294.jpg" border=0>
& C+ G. @2 x- S6 }" g2 h
图 6
$ G: J$ U7 O# n. s
/ ~( Z4 o; Q" s' n# |
3. 接下来再将这段代码粘贴到网页中,并将网页改名为(你输入的登录密码).htm,这样就可以对此文件加密了。
5 j' \4 S, K c/ ^
7 D/ o, ?2 F9 w" G: x6 Y
OK,现在你的网页就再也不用担心被人偷用了。
欢迎光临 广西经贸职业技术学院论坛 (http://gxjmbbs.com/)
Powered by Discuz! X3.2