TA的每日心情 | 奋斗 2021-4-20 05:43 |
|---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑
( _5 B, Q) b/ F' x2 f0 Q6 B. V2 W/ F# e5 M( H, L1 Y
我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。6 J b# k; Q/ H3 J# W* M+ A! g
: @& t' f7 A# e0 W
如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。) f4 M) r! k9 _9 V. k5 L
) o6 w* k6 T/ _0 C3 m: D/ y! \
最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。, R9 z2 l, B3 O# W; e0 l
) z# b" U! ^5 D, Y, }
我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。8 E/ Z/ w* a9 e5 V6 x4 ?/ q
# a- T# y7 f+ k" ?5 ?3 ?' f" J5 v+ v" v; i) b( B/ n u
图片1: JS代码2 b- c0 E4 ^5 Y, _, B4 D! f
图片2: 原始文本
" S" o( X2 h+ `图片3: 加密后文本
' P5 T/ S3 O M2 s5 \9 t: N- S/ z, u& J: I& A# ^& x& _1 ?" `
服务器收到的是:
$ k* o; p! h5 s9 i6 nParameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|