去先说session / e6 t. H: |1 b5 `
) q; h! {2 G, `- K3 w1 i c
对SESSION的争论好象一直没有停止过,不过幺麽能理解SESSION的人应该占90以上。
* @4 D& d$ Y, @. i但还是讲讲,别嫌老~ : q" g9 ]( Q- B( a4 H
! ~( G" A% K% y 有一些人赞成用SESSION,有一些人不赞成。但这个问题到底要怎么说。不妨听听我的看法
) Y& D% V, _% d* E' `7 G! m# r3 |' {
如果有错误请不要朝丢东西,金条和硬币除外。 : H8 A# p2 x: D9 H; d
( B) z! B8 r2 l, j
有些人应该知道我是做江湖程序的,而江湖程序做看中的就是效率,但这里不谈设计,而 " `- N) j6 q* F4 j
$ f4 K I. g2 ?( c 从一些比较实际的角度看SESSION。 # {+ u3 j, W5 Z. l$ g% O
& Z s' B, [1 F' Y+ s8 v
首先要先说SESSION是干什么的,SESSION是可以存储针对与某一个用户的IE以及通过其当
+ M4 H6 a" ?# N$ s& E# Q0 E* H
, v2 v( r7 i' L% ` 前窗口打开的任何窗口具有针对性的用户信息存储机制。为什么要这样说。看下边 * o$ H2 T1 Z8 d0 t
5 T0 t6 D: d6 @/ L1 f+ K+ P( D, N
先研究SESSION是如何启动的,当打开IE以后浏览网站后会发出一个指令请求SESSIONID以
" T4 M! N- U0 `& H
% r/ | I& J0 P) } 及对各个类型数据的下载许可,如图片,声音以及FLASH。 ) ]& g3 F4 e) g7 A3 b) w
数据实际传输内容:IE到服务器 2 ^0 A5 g' M5 J* e0 g: u% d+ X& N
GET / HTTP/1.1
+ c' L9 P2 Z- cAccept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, */*
% i3 j1 V# f& ?8 @# IAccept-Language0: zh-cn ' W4 x3 _6 }4 {9 G( F" Z
Accept-Encoding: gzip, deflate
& r% a/ ^8 @6 @4 R- E! [# fUser-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)
( s" `. @5 H4 y1 m& x; EHost: www.jh521.com % X. o% ?$ n( ]+ ~( k# i: M
Connection: Keep-Alive ' g0 b9 `% w0 i% G7 U4 A* V3 e" Y
服务器会返回一个没有被使用的SESSIONID让IE使用,当时IE就对返回SESSIONID做存储 ) z; d$ _* Z3 M5 C( M7 U
. n5 ?) n" j& r* `5 j+ e
并同时返回相关页面的下载数据,如下:服务器到IE
9 n5 f ~) I% A+ C0 OHTTP/1.1 200 OK
/ h' y/ V8 Z/ i/ w+ }& _, TServer: Microsoft-IIS/5.0
( i. R% e4 F) ^$ N9 MDate: Sun, 30 Nov 2003 16:41:51 GMT & }' g2 Z1 @* I8 H4 T$ ?0 Q; R* @
Content-Length: 21174..Content-Type: text/html ?# Y* N" J' I; T5 y6 E
Set-Cookie: ASPSESSIONIDCACBBBRT=IBOMFONAOJFEEBHBPIENJFFC; path=/
9 P& Y% H* h3 q0 t% X$ \! ]Cache-control: private
) |& ~3 C$ O# Q/ d- R然后就是页面HTML代码 / b! C$ X) k4 t! D5 B" O+ H6 I
6 r; L0 ]1 _! I. S 此时这个IE程序(不是客户机)的SESSIONID就为IBOMFONAOJFEEBHBPIENJFFC
# z. o+ C/ _; P9 S# h& I) M( f' |) S$ e2 O9 v3 v
而当IE在访问任何这个站点的ASP程序的时候,就会把IBOMFONAOJFEEBHBPIENJFFC发送 # \$ E! c( e" S4 g& o
" N# k7 C% a, h* l# O# H! [4 p: z 给服务器,服务器就会知道IBOMFONAOJFEEBHBPIENJFFC是表示你
- S. h% P8 G2 ~5 n* `而在服务器上设置SESSION("name")="name"
/ `6 a0 J4 _0 z5 h完全可以看成是
9 |7 T: v$ a$ iSESSION("IBOMFONAOJFEEBHBPIENJFFC")("name")="name"
4 j8 D4 o W& k7 @3 D或者
0 Z' z1 l1 m0 V: K# \# z9 W% V# V( R" iSESSION(SESSIONID)("name")="name"
' d1 \, x. o$ ?' D Y这样,SESSION就区分开用户了。 1 Z+ }5 C F6 N1 g2 Q7 j4 a+ e: {
而当服务器反馈这个ID的时候会看这个ID有没有被使用。如果有在换一个
L9 K9 h6 L$ }$ f, V! R _7 a反正不会让你重复,如果想模拟某人的SESSION的ID来进行欺骗是可以的。不过要获取到
& _' ^# g* J1 F/ D; E& F- X- M r; K I) H
对方IE传输信号,并且在保证当时这个SESSIONID没有被取消的情况下才可能实施。 ' s8 x5 T, M! O
( ~- r: U0 u! R+ j0 g 不过要是我有那时间直接通过POST信号找他NAME和PASS了。我可不费这个劲
' z9 p. P% W" s$ O$ d2 m/ `& Q5 s2 h# V3 D5 j# P' l( ?
想必一些人明白了了SESSIONID到底是如何工作的 6 j8 _0 | B9 P6 W. B1 t
2 m5 F! d( ` k* O( G! p4 \+ g' i 那么就在看看COOKIE,有人说SESSIONID就是COOKIE,按照技术上来讲他们不属于同类 6 \# |' y6 s( ]+ [
, g) }7 N. d) ~" `' H# @
但是属于一种工作模式,用户和服务器传输私有数据
2 I. F: `0 Z9 ~ X1 \
! \) b2 V0 T- P' O" A 当我设置COOKIE的时候,服务器会反馈给IE一个指令。IE通过这个网络指令生成COOKIE并
/ V: q2 }. A2 _1 X% d& q! l/ v+ c3 j1 C- Y' F3 Q+ H8 x l! C8 m
存放,在特定的时候会取得这个这个信息如在访问这个站点并且COOKID有效的时候。
8 b, j! b d: \( S5 F
# S( Q J* ^" S2 a4 F$ K+ P) h 那么为什么要用COOKIE而不用SESSION呢 1 F8 F8 n0 ?9 {& L
看下区别 ( z5 s! v8 p1 T |2 E' j
" E8 _5 l$ x' F
有效时间以及存储方式 传输内容
& Q' V$ U3 z. W) V5 QCOOKIE 可设置并在本地保留 明码信息
3 C: }) H2 ], A+ ^' ?: i- Z5 V& d, y6 N3 F' }
SESSION 在IE不关闭并服务器不超时 只有SESSIONID
$ I1 N: f( ]8 v- P9 f; N$ r" h1 S a$ g) R/ h- [1 D
当如果想让用户下次登入网站不需要输入用户名或者密码的时候就只能用COOKIE, 9 ~# C# A- \; R/ h- @% H8 Z) v: ?
_( S+ g9 {) M7 ~4 D 因为他可以保留相当长的时间(在COOKIE记录被删除或者失效日期之前) " l5 e+ [ {" v, n7 X J3 H8 y; C
6 b2 s1 a, [/ F$ r6 o* m' J# X
而SESSION就不可以,他不会保留太长时间,而且IE在关闭后就自动清除了SESSIONID记录 ) {$ `/ S3 S$ ]2 j3 d, o
, x' D: y( k+ w8 t5 ^ 在下次登入的时候会请求新的SESSIONID 3 I% ? k s0 Z5 J5 @6 a
& C3 U# l6 h6 G/ G
而服务器想通过用户个人变量校验用户的状态的时候,就不能用COOKIE 6 u0 ?$ C h% ~; V; i: c( T
+ W" r& S( g& Z( T5 }4 _' d; a 如果用设置用户权限是USER。而IE访问的时候就把USER的明码传输到服务器。
( ?1 a. {& f- O$ y( E
; k" P" f* q# r 那么如果我通过一定手段,比如直接修改COOKIE记录,把USER修改成ADMIN呢~~ 5 ]; p9 @! A! d7 E) c' @
& M# ^ p$ k5 `) T1 Z$ z 就麻烦了。
% w9 u: ?& c& L( [% D% N5 M
1 |/ w5 y8 U3 l2 _3 D4 P 但存储用户名和密码或者网站的配色方案这样的信息,用COOKIE是最好的
1 b ^) j" U1 c6 d+ a2 Q5 H8 |$ e( [+ n2 O% ], U) [
' n9 s7 P# i3 O& A# @
好,有点累了,在说说这个东西 / S% h) U' m9 v* f! J2 B
Request.ServerVariables("HTTP_REFERER")
6 h3 T) i- n3 r0 E0 K$ t% l6 V4 q( ~% [8 N
我想有一些人通过这个Request.ServerVariables("HTTP_REFERER")
" S' |6 M/ o4 y2 A来进行一些关键性限制,特别是对付远程提交以及非法侵入。 / A# V l: Y- g: i& G
那么我就要提醒下服务器取得的HTTP_REFERER信息完全是IE传输给服务器的,可以模拟 $ T* ]* l' s$ ?" p
而且难度不大,用不到半个小时就可以用VB做出一个针对HTTP_REFERER入侵程序。
+ W' \) W1 X6 `& |1 N(可惜我原先那他没干正经事情,做WEB游戏挂机程序来的)
( g3 i) X$ m3 ~5 E. T9 F P |