TA的每日心情 | 奋斗 2021-4-20 05:43 |
---|
签到天数: 300 天 [LV.8]合体
|
本帖最后由 可梦之 于 2021-4-15 18:10 编辑 " m- I$ M- e L$ m. A
5 |1 k Q, U$ l+ s6 t
我们生活在云时代,数据安全越来越重要。HTTPS解决了传输过程中安全问题,但是我们的数据对服务器端还是透明的。包括我们的密码,服务器想把明文存下来技术上没任何问题,主要取决于网站的人品。
: G4 s! ? p; ] k- m# \! B, Y9 m0 _: I9 W
如果想让数据对服务器不可见,就需要客户端加密。著名的TG就支持端到端加密,当然各国政府都反对。4 F7 e* N# Q h
# v$ Y& i$ ?! y2 J& i7 X/ l% J7 c* {
最近学习了一下,用JS做客户端加密,加密之后的数据再传给服务器,这样服务器都不知你的内容是什么。当然,如果密码忘记了,谁都帮不了你了。( \7 E0 Q6 V, n7 [ U& W7 }! I
/ H0 q& p; R$ P! N& K% i我用的是crypto-js里的AES算法。JS是脚本语言,谁都可以看到源代码,想搞猫腻都不容易。
* K3 F0 r1 s' W9 ]/ R$ ?3 P# F* S( ^
. s5 S7 t3 ~0 P) {# W
图片1: JS代码
% H3 [0 G. K. D* e# ~" h4 {9 f! W图片2: 原始文本
7 o: r* r& Y5 n2 ]/ l |' x/ o; q" L图片3: 加密后文本
+ q$ d$ O, b; F9 z3 _+ I1 f4 b( `% d* Y7 v2 U; D3 X, h7 o& j- p
服务器收到的是:2 C: T! U9 e4 ~
Parameters: {"authenticity_token"=>"/go+Dm9e7V5uWTqdPQOQ8CrsIBNag7a77/KNQNFCeBRrdTvVzHbxoc2WJb2XA4Z4e3wi5GkAvaI4ahFPryq2yw==", "title"=>"第一篇日记", "date"=>"2021-04-15", "content"=>"U2FsdGVkX18Qo7jf6y1hpeVjApkbiox1A+vdQFF4LVlke39DYte1pRAs+UdKA9W5", "commit"=>"修改", "locale"=>"zh-CN", "table_slug"=>"pl2e", "id"=>"1"} |
评分
-
查看全部评分
|