TA的每日心情 | 奋斗 2021-4-20 05:43 |
|---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑 3 T& j: L8 h$ Q( f
$ K& F% s' }1 P D2 _8 H; w4 ]0 x9 x
我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。9 D' b* G$ T7 }' v2 x0 B3 B
" A) b8 i$ N( u& B: y8 C$ `如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。) S7 X: b' x$ B2 j: r* d, F
! |, n5 A) f5 G' E; K最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。* b2 g( } {, J3 \: l4 C& j
$ g$ W/ P* a o# f4 Q我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。' \5 x$ z* ?& _- v) X
. x' N9 j; S" T* ~" r4 a
3 N. E3 j7 P; A' W$ o( k3 _9 y图片1: JS代码
9 a) j4 T0 u4 a$ Y) @2 P图片2: 原始文本- E# t! D& |' H) s9 ?, N% B
图片3: 加密后文本" f; _2 i/ S: K* t) q. k) E3 H
% `. b) c$ o2 N# y
服务器收到的是:- I( o4 T" |7 @! G- v
Parameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|