我在我的Web应用程序中使用AngularJS.我必须从UI获取密码并将其以加密格式保存到数据库中.
我必须将其检索并解密.我的想法是读取js文件中的文本字符串,然后在保存到数据库之前在服务中对其进行加密.
有什么建议 ?
解决方法
正如
Dmitry Bychenko所说,创建一个工厂服务来散列密码.然后存储并比较哈希值.
angular.module("myApp").factory("sha1",function () { function sha1(msg) { function rotl(n,s) { return n<<s|n>>>32-s; }; function tohex(i) { for(var h="",s=28;;s-=4) { h+=(i>>>s&0xf).toString(16); if(!s) return h; } }; var H0=0x67452301,H1=0xEFCDAB89,H2=0x98BADCFE,H3=0x10325476,H4=0xC3D2E1F0,M=0x0ffffffff; var i,t,W=new Array(80),ml=msg.length,wa=new Array(); msg += fcc(0x80); while(msg.length%4) msg+=fcc(0); for(i=0;i<msg.length;i+=4) wa.push(msg.cca(i)<<24|msg.cca(i+1)<<16|msg.cca(i+2)<<8|msg.cca(i+3)); while(wa.length%16!=14) wa.push(0); wa.push(ml>>>29),wa.push((ml<<3)&M); for( var bo=0;bo<wa.length;bo+=16 ) { for(i=0;i<16;i++) W[i]=wa[bo+i]; for(i=16;i<=79;i++) W[i]=rotl(W[i-3]^W[i-8]^W[i-14]^W[i-16],1); var A=H0,B=H1,C=H2,D=H3,E=H4; for(i=0 ;i<=19;i++) t=(rotl(A,5)+(B&C|~B&D)+E+W[i]+0x5A827999)&M,E=D,D=C,C=rotl(B,30),B=A,A=t; for(i=20;i<=39;i++) t=(rotl(A,5)+(B^C^D)+E+W[i]+0x6ED9EBA1)&M,A=t; for(i=40;i<=59;i++) t=(rotl(A,5)+(B&C|B&D|C&D)+E+W[i]+0x8F1BBCDC)&M,A=t; for(i=60;i<=79;i++) t=(rotl(A,5)+(B^C^D)+E+W[i]+0xCA62C1D6)&M,A=t; H0=H0+A&M;H1=H1+B&M;H2=H2+C&M;H3=H3+D&M;H4=H4+E&M; } return tohex(H0)+tohex(H1)+tohex(H2)+tohex(H3)+tohex(H4); }; return sha1; });
用于SHA1功能的信用this answer.