本文共 8978 字,大约阅读时间需要 29 分钟。
认证包含了身份和身份认证两层含义。
q 身份—我是谁?
q 身份认证—这就是我。
认证的目的就是为了认出用户是谁?而授权的目的是为了决定用户能够做什么。
认证实际上就是一个验证凭证的过程。
一般为了安全与用户体验性,采用“双因素”验证的比较多,例如支付中的密码和手机动态密钥。
我认为在用户注册的时候应该检测一下用户使用的是否是弱密码。这就代表着我们需要在系统中建立一套“弱密码表”,弱密码表如下。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 | 000000;c984aed014aec7623a54f0591da07a85fd4b762d 000000000;0f58d5a5515f1a8a9d179aa58858b67b2f8a3388 0000000000;8104ba1dc0409b259f487ed07db477c38f205a30 111111;3d4f2bf07dc1be38b20cd6e46949a1071f9d0e3d 11111111;a642a77abd7d4f51bf9226ceaf891fcbb5b299b8 111111111;3f196cfb6c4cffe3002c0495a1bc822521b6aa36 112233;3acd0be86de7dcccdbf91b20f94a68cea535922d 11223344;b986415c93241513d33d01fcf532a6c47ac4f3ee 123123;601f1889667efaebb33b8c12572835da3f027f78 123123123;88ea39439e74fa27c09a4fc0bc8ebe6d00978392 123321;4d9012b4a77a9524d675dad27c3276ab5705e5e8 123456;7c4a8d09ca3762af61e59520943dc26494f8941b 123456a;360e46f15f432af83c77017177a759aba8a58519 12345678;7c222fb2927d828af22f592134e8932480637c0d 123456789;f7c3bc1d808e04732adf679965ccc34ca7ae3441 987654321;bfe54caa6d483cc3887dce9d1b8eb91408f1ea7a 654321;dd5fef9c1c1da1394d6d34b248c51be2ad740840 abcdef;1f8ac10f23c5b5bc1167bda84b833e5c057a77d2 abcdefg;2fb5e13419fc89246865e7a324f476ec624e8740 abcabc;f8c1d87006fbf7e5cc4b026c3138bc046883dc71 abc123;6367c48dd193d56ea7b0baad25b19455e529f5ee a1b2c3;2f4c5ce01f30865d02b2cc2b60d50b0bc5a1ee75 123qwe;05fe7461c607c33229772d402505601016a7d0ea qwerty;b1b3773a05c0ed0176787a4f1574ff0075f7521e qwertyuiop;b0399d2029f64d445bd131ffaa399a42d2f8e7dc asdfghjkl;5fa339bbbb1eeaced3b52e54f44576aaf0d77d96 zxcvbnm;93ec71b22793a81569c94ca17e4d9c293d8e201f qweasd;94cd166631d14dab533858b9b47e9584a2ff3f65 admin;d033e22ae348aeb5660fc2140aec35850c4da997 password;5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8 p@ssword;36e618512a68721f032470bb0891adef3362cfa9 passwd ;30274c47903bd1bac7633bbf09743149ebab805f iloveyou;ee8d8728f435fd550f83852aabab5234ce1da528 5201314;39693fd4a45b386c28c63100cc930238259891a2 5211314;817fbb7fa898c2b5d494fbd1f46bc6437d1eae33 woaini1314;79cbc25ac7de525cdc27d2977dbf3c0f13f04924 222222;273a0c7bd3c679ba9a6f5d99078e36e85d02b952 333333;77bce9fb18f977ea576bbcd143b2b521073f0cd6 444444;42cfe854913594fe572cb9712a188e829830291f 555555;b7c40b9c66bc88d38a59e554c639d743e77f1b65 666666;1411678a0b9e25ee2f7c8b2f7ac92b6a74b3f9c5 777777;fba9f1c9ae2a8afe7815c9cdd492512622a66302 888888;1f82c942befda29b6ed487a51da199f78fce7f05 999999;1f5523a8f535289b3401b29958d01b2966ed61d2 aaa111;4a0cde71aee7158542d013fc0c9f5acfc735c612 bbb222;6be712a6e73d979726c02a308b3457f9f5cf148e letmein;b7a875fc1ea228b9061041b7cec4bd3c52ab3ce3 aaaaaa;f7a9e24777ec23212c54d7a350bc5bea5477fdbb aaaaaaaa;b480c074d6b75947c02681f31c90c668c46bf6b8 abcde12345;61d6504733ca7757e259c644acd085c4dd471019 19216801;c1018a89c6ea96ad0b85f6b96e6a857accd23644 19216811;76baff4a5e6ed84f77bab8160f35646e042e4e1c 1a2b3c4d;b01afc2b077956acc69f99e0b7df1cb70cb01331 1q2w3e4r5t;b80a9aed8af17118e51d4d0c2d7872ae26e2109e asdfgh;7ab515d12bd2cf431745511ac4ee13fed15ab578 fuckyou;dd2edb87ea9eb7a32fd4057276d3a1fab861c1d5 @163.com;900a0dc861cfb4e8692e2c9e3ac3e402244148e5 @126.com;09b66030ce0e0ce02bf5c9f1acb3d3ed43b03d29 @sina.com;9315152529553e529d7a104749a5091018335c41 @yahoo.cn;45131950280623973e2990a1c712ff7bbac47ef2 @hotmail.com;67f34d4020041d47084e416d2a3b69a41d5004b5 @sohu.com;70cb33735b8f48126644c4b73d5f202b3787d345 @139.com;a3495fafa58826efb7bd72afe7c65037ed8bc3e5 zxc123;d5a1bdf9ce989fd6161063e94b92bdeacb94ed23 a123456;895b317c76b8e504c2fb32dbb4420178f60ce321 a123456789;82e19fa12aab7cfc718a002fc82c0f074bf070e7 1234567890;01b307acba4f54f55aafc33bb06bbbf6ca803e9a qq123456;1e9c48fedb74c408cfa764c2e6579345ad38b059 abc123456;370194ff6e0f93a7432e16cc9badd9427e8b4e13 123456789a;8bc5de83cf1daf79ed5b2f13f93d7c05d01d0388 147258369;345120426285ff8b1d43653a4d078170b4761f75 12345678910;9048ead9080d9b27d6b2b6ed363cbf8cce795f7f qq123456789;c62ff83c569e4167f2d4a6d437c37c4c99f62abb 123456789.;ed005b69bc65e50b86efbfa2eee5a9a9522c4a79 7708801314520;32b912e96e3af75977851c4c0ae1ab76fa2342bd woaini;18f3e922a1d1a9a140efbbe894bc829eeec260d8 5201314520;f33d1c19fca267f74c49d287359e438c25080a13 q123456;6373050ac6f292c7f40103686db60eabe536615a 123456abc;a172ffc990129fe6f68b50f6037c54a1894ee3fd 1233211234567;dd3fdc04319ba92de10e6f4ced669daf40c34774 123123123;88ea39439e74fa27c09a4fc0bc8ebe6d00978392 123456.;76d91c3bdf12cb2a5ed8d590390df02efb77fb91 0123456789;87acec17cd9dcd20a716cc2cf67417b71c8a7016 asd123456;b2b7258d833cda1f75ff068edcbfa93faf899273 aa123456;89e89c17f877ca2821b557f633cec3253b0aa941 135792468;ed0e9283310c98094b1f5c0c42385c7a3c6818da q123456789;acd7236e31641b4de86fd7af037655976d76c9c6 abcd123456;756de479126e911b6f3400ae686d663d9d26b509 12345678900;545c562a9d01dfaef9fb4e72c14010d2c4862a8b woaini123;9635549628ffb5028a456b7e381cce375f598be7 zxcvbnm123;b487af41779cffb9572b982e1a0bf83f0eafbe05 w123456;4bd79e74a4e75df4226379434fc60f3274e1f4e3 aini1314;1c9a13456920a7a86a8f3ccf561039f2e4f3f244 abc123456789;33c76f70af66754ca47d19b17da8dc232e125253 1314520520;581cf6ca317edbca904de1540c031f8209beb779 1234567891;64ea0dc7dadd49a337f1ef14815bd3f428141c7d qwe123456;e0ad1156a8de997c18dd27d85253a963433d8cec asd123;2891baceeef1652ee698294da0e71ba78a2a4064 1472583690;9de1d8a075935f3d9746cc1419dd16576fdd5b6f 1357924680;33787d9003e53554aa48e7b3a2d2f793edb7d7a0 789456123;4b4b04529d87b5c318702bc1d7689f70b15ef4fc 123456789abc;a63d2f9ac1d341ae389920e6fe5712ca27768a72 z123456;63b597584b223523684957a1646a366f80c1776d 1234567899;fa213fbfd3c4bd1e298a01faee0652ce8aece66e aaa123456;63a573e536a133d9ce53d63cdefaa3a6ff7a7ef9 abcd1234;7ce0359f12857f2a90c7de465f40a95f01cb5da9 www123456;82d878eae8ed4c9633a85c3ffbc2fe6e08439d5f 123456789q;e4af001202394bea766da25ca5a83adc8dfb1fe1 123abc;4be30d9814c6d4e9800e0d2ea9ec9fb00efa887b qwe123;c53255317bb11707d0f614696b3ce6f221d0e2f2 w123456789;fdf78847507ea581d669dfb4bb7acdd49f6fd167 7894561230;255f53c62ddcd8771941fe7fc3d316761f204966 123456qq;0213711d8b8773c12c52eaf8b4da9dc479a6f33c zxc123456;20894d135e5493a4b13adb05545e4327f78ba5a5 123456789qq;a4d1643ef5edd2d052a9a74eb0daebc4bb5601be qazwsxedc;cbf2510a5f9f7eece23428da7125c06115839e2b qwerty;b1b3773a05c0ed0176787a4f1574ff0075f7521e 123456..;21e279011385c910548bcfe8449607d66cf079af 1234554321;ece4e6b27cf0a2c5c9d83e44bfd5a71795f8a6e0 123456q;bfff2dd4f1b310eb0dbf593bd83f94dd8d34077e 123456aa;80e126659c008667cb626baef0c86e7b7dd00e20 9876543210;9cd656169600157ec17231dcf0613c94932efcdc 110120119;c611407915728260ac0ab216a71dab84ccedc267 qaz123456;d480bd8b8bdd111efd9f7acf13b8e889c97a8704 qq5201314;d54afcea69f4206f91549578f5f10ae3ba1456aa 123698745;46faecb386d33e643afdabc62393fa7e84f5bf66 as123456;7e02cc3aedfaec1fc5863c6ae846378874218186 5841314520;cdfee1c0470223f479f457b4c36db0028aaaaf67 z123456789;23aa667a74a65343dfe41a015dae1c9208bb972e a123123;787c8ad9f686d6ae66a053497de9ae15b6b13364 caonima;430dcd10accf33c72ec127813ec7e2c93a697314 a5201314;0638a978a2c43b4d01739436cd7ada21d94d938f wang123456;341f61d91c70014c2c867be0f3edcd237f04a70d abcd123;7c3607b8e61bcf1944e9e8503a660f21f4b6f3f1 123456789..;b4d333d3afcb4ab2169709d1f9ee928053818a13 woaini1314520;69f64f206fe9f88e93ac54e6a5ce057a7a0efbee 123456asd;ba3da472cb1a59f523b87f74c4e42c860c2aa5d0 aa123456789;48df1dc02ccb17787d25e40f42c2e721cf200511 741852963;863dae13577340b98c4c247f4a05b204a3543248 a12345678;3dd635a808ddb6dd4b6731f7c409d53dd4b14df2 |
注:上述弱密码已经经过SHA1加密,原文与密文以“;”分割
密码尽可能的使用单向加密算法或者md5
除了一般的密码之外,动态口令,数字证书,U盾,第三方证书等都是可用于用户认证的。这些不同的手段可以相互结合,使得认证的过程更加安全可靠。密码不再是唯一的认证手段,在用户密码失窃的情况下,仍可保障用户账户的安全。
Session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存息。
但程序需要为某个客户端的请求创建一个session的时候,服务器首先检查这个客户端的请求里是否包含了一个session标识-称为 Session id,如果已经包含一个Session id则说明以前已经为此客户创建过Session,服务器就按照Session id把这个Session检索出来使用(如果检索不到,可能会新建一个,这种情况可能出现在服务端已经删除了该用户对应的session对象,但用户人为地在请求的URL后面附加上一个JSESSION的参数)。如果客户请求不包含Session id,则为此客户创建一个Session并且同时生成一个与此Session相关联的Session id,这个Session id将在本次响应中返回给客户端保存。
保存Session id的几种方式:
q 保存Session id的方式可以采用Cookie,这样在交互过程中浏览器可以自动的按照规则把这个标识发送给服务器。
q 由于Cookie可以被人为的禁止,必须有其它的机制以便在Cookie被禁止时仍然能够把Session id传递回服务器,经常采用的一种技术叫做URL重写,就是把Session id附加在URL路径的后面,附加的方式也有两种,一种是作为URL路径的附加信息,另一种是作为查询字符串附加在URL后面。网络在整个交互过程中始终保持状态,就必须在每个客户端可能请求的路径后面都包含这个Session id。
q 另一种技术叫做表单隐藏字段。就是服务器会自动修改表单,添加一个隐藏字段,以便在表单提交时能够把Session id传递回服务器。
防范SessionFixation攻击:用户认证后一定要变换SessionID。随机算法需要足够强大。
防范Session保持攻击:
在一定的时间或特定的条件强制注销Session。如发出的Session的IP或者UserAgernt或者地点或者多个Session的情况时候。
对于单点登录的一下缺陷,可以在指定的系统应用中加“双因素”验证。
参考:http://dotnet.blog.51cto.com/272325/51559/
转载地址:http://vyfco.baihongyu.com/