socket连接多层程序安全性简述 - 数据
剩下三种数据包/数据包完整性/数据包保密性
0 Y# j; r+ f$ y& a5 E3 G其实只是一种安全机制的不同级别实现而已
数据包对发送者的身份加密,完整性和保密性
# |" T$ s4 x& W1 W N2 b- S# W' ?! t是对其的有益补充
3 X8 a9 `) z# u u5 c/ w8 A" G; c- A
实际上数据包模式对发送者身份加密实现方法任意
% F3 V. n- [* ^( s) w比如可以用Windows提供的那套加密库
呵呵,反正只要你在服务器端对其进行检验
' X9 `( Y6 b" A" Z5 p- a0 H! x传送中途数据包被截留不会泄露发送人身份或
可以证明发送人身份的数据即可
% O( a- O, b7 h0 E. A0 j9 v
而完整性可以通过各种算法保证,比如crc,md5都是
7 J3 L$ o; s) Z- Y& t可行的,甚至简单一点按位and/or也不失一种办法
只是比较简陋罢了,呵呵,总之要保证数据不会被
( V) v$ ^- L2 i中途截留者更改
( g! j9 E/ N2 v5 o4 }7 [1 X& ^3 E \. `
至于保密性,找一种对称加密算法对全部数据进行
加密,然后将密匙用另外的非对称算法再次加密即可
具体这方面的安全考虑问题可以看看《应用密码学》
一书,非常不错的这方面的权威书籍
这里需要提及的是这三种模式的实现,
简单一点的可以类似上一个呼叫模式中
在IAppServer::AS_GetRecords或者
其他类似的事件里面实现,参见上篇文章
不过很幸运的是borland提供了一种更加简单可行的方案
IDataIntercept接口
__interface IDataIntercept;
Q* Z8 @2 a6 ~typedef System:
elphiInterface<IDataIntercept> _di_IDataIntercept;
__interface INTERFACE_UUID("{B249776B-E429-11D1-AAA4-00C04FA35CFA}") IDataIn
tercept : public IUnknown
: J* A1 z, {8 K& n{
9 i c1 `& V, S* r/ n$ L1 opublic:
7 }' [; ^5 [* Wvirtual void __stdcall DataIn(const _di_IDataBlock Data) = 0 ;
% E: m' V2 v% q3 l: Z# evirtual void __stdcall DataOut(const _di_IDataBlock Data) = 0 ;
};
他在TSocketConnection类传送数据时会自动被使用
7 Y, q% D% y B呵呵,用它实现数据完整性和保密性都是非常合适的选择
外加还可以对数据进行压缩,呵呵
具体使用可以看看Delphi5\Demos\Midas\Intrcpt\目录的例子
* A6 X9 U- m- v2 B% J; Q7 K
MS对这几种安全机制的分类是高级别兼容低级别
实际上在我们自己使用的时候完全可以根据我们的需要
自己灵活混合几种机制进行处理,选择最适合自己项目的解决方案
btw:本来想随便写写,发现好像很多问题都几句话说不清
3 q! v/ k5 H( N8 a9 J( z等到下个月有时间偶把这些东东好好总结一下写篇
- d" g I5 \8 ]7 H) [& p象样一点的文章出来,呵呵
1 |* U8 ~+ q9 K* w3 [3 F p1 _' S; R% G6 y
其实这些安全模式的实现方式还有很多,偶只是挑出
偶比较熟悉的比较容易说清楚的介绍,简介嘛,呵呵
希望能够对大家有帮助,也希望大家积极讨论,批评指正
| 欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) | Powered by Discuz! X2.5 |