草庐IT

crypto_serialization

全部标签

javascript - Crypto JS SHA3 在相同的输入上给出不同的输出

我们使用CryptoJSSHA3将我们的用户名和密码哈希在一起。该函数从两个html输入字段获取用户名和密码的输入,将它们与盐连接起来,并对它们进行哈希处理。第一个散列成功运行,但是再次散列相同的输出会产生不同的结果。这是相关代码:$prehash=$salt+$user+$pass;$prehash=CryptoJS.enc.Utf8.parse($prehash);varsha3=CryptoJS.algo.SHA3.create();sha3.update($prehash);varpassword=sha3.finalize().toString(CryptoJS.enc.He

javascript - nodejs 加密模块与 crypto-js

我是NodeJs的新手,正在尝试弄清楚如何使用“crypto”模块。在玩弄它时,我注意到NodeJs和crypto-js中的“crypto”模块之间的区别:使用crypto-js,我有:functionSHA256Hash(password,salt,iteration){varsaltedpassword=salt+password;varsha256=CryptoJS.algo.SHA256.create();for(vari=0;i然后调用:varhashedPassword=SHA256Hash("123456789","ASIN",3)并接收:saltedpassword=A

javascript - 未捕获的类型错误 : Cannot read property 'lat' of undefined when serializing leaflet data with $. 参数()

我想先说明一下:我是JavaScript的新手。我正在尝试使用Leaflet和AJAX调用发布用户位置和map边界。在我的事件处理程序stateUpdater.onLocationFound中,日志语句打印出正确的用户坐标和map边界,但是我在尝试时得到UncaughtTypeError:Cannotreadproperty'lat'ofundefined使用$.param()序列化这些值。我正在使用Leafletv0.7.2和jQuery1.11.0。varmap;$(document).ready(function(){map=newL.map('map').setView([41

javascript - 从 Web Worker 内部运行 window.crypto.getRandomValues()

我已经无计可施了。知道网络worker无法访问window对象,有什么办法可以做到这一点吗?请帮忙! 最佳答案 我知道这是一个老问题,但我偶然发现了这个问题,事情发生了变化。大多数浏览器现在都支持网络worker中的加密。在webworkers中,您可以访问self,它不包含所有“窗口”属性(尤其是与dom无关的属性),但包含加密函数等API方法。因此,您可以从webworker中简单地访问self.crypto.getRandomValues()。我做了一个fiddle作为例子:http://jsfiddle.net/jbrosi

javascript - Node : Good way to write Multiple API Calls in serial

是否有更好/更漂亮的方式来调用多个API(如我的示例所示)?varrequest=require('request');request('http://www.test.com/api1',function(error,response,body){if(!error&&response.statusCode==200){request('http://www.test.com/api1',function(error,response,body){if(!error&&response.statusCode==200){request('http://www.test.com/api

javascript - 使用 crypto.generateValues() 生成 0 到 1 的随机数

看起来Math.random()生成范围[0,1)中的64位float,而新的crypto.getRandomValues()API仅返回整数。使用此API在[0,1)中生成数字的理想方法是什么?这似乎可行,但似乎不是最理想的:ints=newUint32Array(2)window.crypto.getRandomValues(ints)returnints[0]/0xffffffff*ints[1]/0xffffffff编辑:澄清一下,我试图产生比Math.random()更好的结果。根据我对float的理解,应该可以得到52位随机数的完全随机分数。(?)编辑2:为了提供更多背景知

javascript - Node.js - crypto.js - PFX header 太长

我正在尝试从文件中加载PFX和密码,以便发出HTTPS请求。在开始之前,我已经知道PFX很好,这不是问题所在。我正在做以下事情:config.options.pfx=fs.readFileSync('file.pfx');config.options.passphrase='passphrase';我正在将我的选项传递给代理。config.options.agent=newhttps.Agent(options);然后我尝试构建rquest,但出现以下错误:crypto.js:143c.context.loadPKCS12(pfx,passphrase);^Error:headerto

javascript - crypto.pbkdf2 是异步的,如何将其视为同步?

我在node.js中使用pbkdf2来散列密码。我的问题是我正在响应身份验证请求,如果传递的凭据正确,我正在进行身份验证。我假设pbkdf2是异步的,因为它可能会花费大量时间(取决于迭代的大小)。然而,将剩余的身份验证逻辑移动到一个单独的方法中以利用回调似乎有点难看。有没有比使用计时器或将所有连续的身份验证逻辑放入一个单独的函数中更好的方法?我知道大多数人会说我应该使用回调,但在我的用例中这没有意义。在将pbkdf2应用于传递的密码之前,我无法继续身份验证。 最佳答案 根据Node.jscryptodocs,PBKDF2函数既有异步

javascript - Crypto.randomBytes 处理异常对熵不足有何影响?

在此方法的文档中,它声明如果没有足够的熵来生成数据,它将抛出异常。我的问题与熵有关。它是如何生成的,您能否通过提供足够的熵来防止抛出异常?抛出异常的频率有多高,还是未知?crypto.randomBytes的文档:crypto.randomBytes(size,[callback])//asynccrypto.randomBytes(256,function(ex,buf){if(ex)throwex;console.log('Have%dbytesofrandomdata:%s',buf.length,buf);});Generatescryptographicallystrongp

javascript - jQuery:如何将可排序的 ('serialize' ) 数组从最后一个反转到第一个?

讨论开始jQuery:Whattodowiththelistthatsortable('serialize')returns?如何从后倒序到前,updateList.php?id[]=5&id[]=4&id[]=3&id[]=2&id[]=1&&action=update?54321我的代码:$(document).ready(function(){order=[];$('#listul').children('li').each(function(idx,elm){order.push(elm.id.split('-')[1])});$.post('updateList.php',{