草庐IT

cdp-node

全部标签

node.js - 如何将所有redis记录传递给查看?

我想将所有记录从Redis传递到View。我认为我对redis值做错了,因为我无法将它推送到数组或对象。我试过这样:app.get('/',function(req,res,next){varitems=[];client.keys('*',function(err,obj){for(vari=0,len=obj.length;i当我控制台记录我得到的值时for(vari=0,len=obj.length;i值显然是一个对象...我需要对其值进行for循环吗?或者也许有更简单的方法。 最佳答案 那是因为你正在进行异步调用,试试这个代

javascript - Array.push 不保留 node.js 中的数组值

我已经promise缓存数据并将Json值数组推送到新数组中的代码,但在链接之后,数组显示未定义。这是代码片段。'usestrict';constPromise=require('bluebird');let_connectResolve,_connectReject,onConnected=newPromise((resolve,reject)=>{_connectResolve=resolve;_connectReject=reject;}),redis=require("redis"),redisClient=redis.createClient({host:'localhost

node.js - 执行 redis eval 命令以在 nodeJS 中运行 Lua 脚本

在Redis中,我通过CLI运行Lua脚本,如下所示:-$redis-cli--evaldebug_script.luakey1key2key3key4,arg1arg2因此,我的Lua脚本接受4个键和2个参数。现在我想在Node.js中运行相同的脚本。我正在使用this用于在我的应用中导入Redis的库。我没有找到任何示例来说明用于执行Lua脚本的redisClient.eval(...)函数的参数。因此,我只是随便打一些可能有用的东西。但似乎没有任何效果。我的app.js是这样的:varredis=require("redis")varclient=redis.createClie

node.js - Node.js、Redis、套接字

我有一个nodejs应用程序,它从redis读取数据,但我无法将其推送到套接字中。在c.write(message)部分,如果我硬编码(例如c.write('hello'),消息将被放入套接字但是当我把它作为c.write(message)时,没有任何东西会进入套接字。提前致谢varnet=require('net');varsplit=require('split');varRedis=require('ioredis');varredis=newRedis();varserver=net.createServer(function(c){console.log('clientcon

javascript - 登录系统 - Node.js 和 Redis

这个问题在这里已经有了答案:WhyismyvariableunalteredafterImodifyitinsideofafunction?-Asynchronouscodereference(7个答案)关闭5年前。我想使用node.js和Redis(Redis包)创建登录系统,但每次我将输入数据与数据库数据进行比较时,我都会得到一个令人困惑的结果。这是第一种方法:constRedis=require("redis");constclient=Redis.createClient();exports.userLogin=(username,password,errMsg,success

node.js - 将 NodeJS 连接对象保存在共享数据库/内存中

我正在运行带有NodeJS6的Debian8,并且正在使用IBMWatsonIoT平台:https://github.com/ibm-watson-iot/iot-nodejs我在IBM中创建了一个网关,并且能够使用以下代码连接并向其发布数据:vargatewayClient=newiotf.IotfGateway(config);gatewayClient.connect();gatewayClient.on('connect',function(){gatewayClient.publishGatewayEvent("status","json",'{"d":{"cpu":60,"

node.js - Redis 到永久存储的迁移

目前,我的网络应用程序在Redis数据库(所有数据库)上。它需要超过4GB的RAM,这让我付出了很多代价。我想将我的应用程序的某些部分迁移到永久存储数据库(SQL、mongo...)那么,谁能告诉我哪个是最佳选择(SQL、mongo...)?我的应用程序的技术堆栈:nodejs(express)角度redis 最佳答案 这实际上取决于您的设计。您的数据是否高度相关?Redis被认为是一种NoSQL技术,所以我猜MongoDb会有些相似,但实现将基于文件而不是键值集。如果你需要你的数据在每个数据集之间有很强的关系,那么SQL系列就是为

node.js - 如何使用套接字安全地实现通知系统?

我目前正在使用MEAN堆栈开发Web应用程序。它具有社交方面的功能,因此我希望能够向用户推送通知。我现在的做法是,当某件事发生时,它应该是一个通知,它被存储在一个带有未读标志的mongo数据库中。每个客户端将每30秒向服务器发送一个获取请求,并将收到标记为未读的每个通知,然后将其标记为已读。我想改用消息队列和套接字,这样可以减少网络资源的使用,同时为用户提供实时体验。我考虑过使用redis及其pubsub结构,但我似乎无法弄清楚如何安全地执行此操作。如果我向受影响的用户推送通知,恶意的人是否很容易订阅其他人的channel并收到不适合他们的通知?我是否遗漏了什么,或者对于这样的系统来说

node.js - 如何保护 Redis 和 Socket.IO 实时服务器,以便只有经过身份验证的用户才能收听?

我正在构建一个具有聊天功能的网络应用程序。我在后端使用Laravel5.4,在前端使用Angular4。一切正常(意味着我可以广播和接收),但我完全不确定如何保护它。聊天将始终是1对1,因此它是私密的并且必须是安全的。每个聊天室都有一个唯一的ID,但仍然有人可以收听。目前,当我从前端向我的API发出请求时,我正在使用JWT进行身份验证,但我不确定是否可以为此实现类似的东西。我知道我可以使用query选项从前端传递token,但我不确定如何解析它,我也不确定如何验证它确实属于正在尝试的用户访问聊天(我应该向API发出请求以在server.js中进行验证吗?这似乎效率不高。将token的用

node.js - 连接到集群时如何关闭ioredis(nodejs模块)?

我已经编写了一个使用ioredis的模块和一些测试。问题是,当我在集群模式下连接ioredis时,mocha在完成后挂起,即使我调用了redis.disconnect()。似乎有些东西仍然绑定(bind)在事件循环上。这是我的测试:it('connectstoredisclustermode',async()=>{//redisClientFactroyismymoduleletredisClientFactory=redisClientFactoryInit({host:'localhost',port:7000})//itreturnsaredis.clusterinstancei