TA的每日心情 | 奋斗 2021-4-20 05:43 |
---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑
; ~+ e! u% X% ?4 F. z6 K6 K9 M0 x
. |, O7 U9 i6 V% y: ?& Y/ f/ ^% Z# p我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。
( ]; P6 k4 \" F" g! u+ D" _( j9 V& k9 [! S1 ?8 L
如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。
$ l! W% K1 X5 l# Z
9 Y9 Y) E/ } z: ?2 x' o3 p最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。
: M9 G& H9 _ d6 n
- `! O: k3 e& r; Y我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。
8 z7 P- v# B I3 E; b9 H( S) c4 c/ l# R! L$ e0 H
0 f6 d6 R" y, B
图片1: JS代码) C, t+ K2 d% c5 P9 t4 o3 m2 }
图片2: 原始文本! j, ]/ Q' n7 h8 d2 T! G8 |
图片3: 加密后文本
/ T0 y0 S9 P- Y, d4 k4 f
5 m1 T9 Y% }8 L3 K服务器收到的是:
) X* y" X% [% Z$ _' f( K4 EParameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|