TA的每日心情 | 奋斗 2021-4-20 05:43 |
|---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑 $ B8 [0 z G- b+ T- }( y" h) a
5 U5 z+ y$ V- J6 s我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。
- j. u e1 v( p, G$ Z, g3 o- K2 U! @4 v5 q1 l
如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。/ |. {5 U- ~4 A9 h2 J
, u2 G$ F: K7 G1 R
最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。4 u/ ]- Z9 \! P: D+ \* x
, ?8 E; W# D% s8 r* k5 U5 A* Z4 J我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。
3 `9 H, V0 a% z# r% r u( S* v5 s7 e; t" H! ^
/ I8 M/ W) A. u/ u; D) e图片1: JS代码+ h7 X/ j3 }- e ]7 z9 Z; B
图片2: 原始文本7 X% J7 q! q2 _. d
图片3: 加密后文本" x' o9 w3 A3 j4 j" r& [
, c b1 F# p0 k) J0 a
服务器收到的是:
% `% }5 C4 B1 I( u1 Y, s) ~% b+ u3 Y2 ZParameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|