如何使用MongoDB / Node.js创建友好的URL?

时间:2012-04-23 04:34:48

标签: url node.js mongodb

例如,假设在设计博客应用程序时我需要类似

的内容

domain.com/post/729

而不是

domain.com/post/4f89dca9f40090d974000001

Ruby有以下

https://github.com/hakanensari/mongoid-slug

Node.js中是否有等价物?

3 个答案:

答案 0 :(得分:2)

MongoDB中的id实际上是一个十六进制值,可将其转换为数值,您可以使用以下代码在数据库中搜索数值,如1,2,3 ..此代码将该值转换为适当的值十六进制

article_collection.db.json_serializer.ObjectID.createFromHexString(id)

其中article_collection是您的集合对象

答案 1 :(得分:1)

GitHub上有许多不同的项目,如https://github.com/dodo/node-slughttps://github.com/stipsan/String.Slugify.js,但他们专注于使用字符串制作有效的网址(通常是帖子主题或文章标题)。我没有看到任何采用随机数和一些如何产生更短的随机(?)和唯一数字。

就个人而言,我的post对象上只有一个令牌字段,其中包含的唯一值比直接使用DB id(并且更安全一点)更短。如果您使用的是Mongoose,则可以通过在Mongoose模型上挂钩“保存”事件来自动生成令牌。

答案 2 :(得分:1)

有几种方法:

1-假设您正在尝试为每篇博文提供唯一ID。 为什么不在博客集合中覆盖文档的“_id”字段? 样本文件将是:

{ "_id" : 122 , "content" : { "title: ..... }

你必须注意一种生成自动增量id的方法,这很容易。 但是不建议使用这种类型的主键。 http://www.mongodb.org/display/DOCS/How+to+Make+an+Auto+Incrementing+Field

2-让_id字段保持原样,并且另外存储一个整数的'blogid'键,你必须在'blogid`字段上运行ensureIndex,尽快通过blogid进行访问。存储开销很小,因为您将在文档中存储更多的键名和整数。

示例文档将是:

{ "_id" : xxxxxxxxxx ,"blogid" : 122, "content" : { "title: ..... }