TA的每日心情 | 奋斗 2021-4-20 05:43 |
|---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑
/ r J# C0 [& C) R" P# X( B1 X
8 T1 [& C" l9 D5 w我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。# I+ _/ ]; z: x. ~2 W" l$ U
; G0 \0 y+ I @& c4 Z) h/ n. s& _. L) K如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。# k1 d8 e) t: Y, ^6 A2 z! `. ?, b$ S/ g
( u% Y% H( J5 v% \" v* K
最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。
8 `5 y1 ^/ G' C; y' D
; O2 h5 V$ ^2 d4 e" f我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。
/ a3 c# B' y7 D7 c; Z! l; z! e4 ~
3 ?9 h) h$ t/ Q, j) s- V* p9 R' H+ t8 Q; |4 f8 W: D
图片1: JS代码
8 h C- m: F$ G9 ~图片2: 原始文本
7 F7 { v( `* i9 V图片3: 加密后文本
: k( K5 K' Q0 }) `$ E* j& f. c% U0 e/ z2 ^
服务器收到的是:2 j: w: ]8 R2 H8 i5 K
Parameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|