creating-a-rest-api-using-node-js
全部标签 目前我有一个Rails3应用程序,它使用devise插件进行网站身份验证。但现在我也将添加一个iPhone应用程序,因此我将向客户端设备(iPhone)公开api调用。我将如何实现身份验证模块,以便iPhone客户端可以对Rails站点进行身份验证并访问某些API?我应该创建一个oauth提供程序、基于token的身份验证还是简单的http身份验证? 最佳答案 在这种情况下,HTTP基本身份验证可以正常工作。如果您希望它更安全,您可以创建一个OAuth提供程序并创建您自己的TwitterxAuth实现。使其更加用户友好。本质上,您将
所以我想开始使用RSpec故事,但我不确定编写Controller、模型和View规范的位置。例如,您有“登录”故事和“用户提供错误的密码”场景,难道您最终测试的不是与Controller/模型规范相同的东西(response.shouldrender...,user.shouldbe_nil等)所以我的问题是:对于那些习惯于使用RoR进行bdd(或故事dd)的人,您是否仍然编写模型/Controller规范?如果是这样,您遵循的工作流程如何(“第一个故事,然后缩小到特定规范”)? 最佳答案 如果您现在开始使用故事(而不是拥有大量遗
我已经使用sinatra编写了一个基本的RESTAPI。有谁知道为它编写测试的最佳方法吗?我想使用Ruby来做到这一点。我已经使用curl完成了初步测试。但我想做一些更强大的事情。这是我的第一个API-有什么我应该测试的具体内容吗? 最佳答案 最好的方式见仁见智:)就我个人而言,我喜欢简单干净。使用像minitest这样的工具,Watir和rest-client,您可以对REST界面进行非常简单的测试,并通过实际浏览器(支持所有主要浏览器)测试您的Web服务。#!/usr/bin/ruby##Requiresthatyouhavei
RubyDoc有两个部分:核心和标准。核心是默认的,标准有额外的库/方法等。这是否意味着我必须要求这些标准库才能使用它们?我是这么想的,不需要任何东西就从标准库中选择了DateTime.now,它成功了。 最佳答案 是的,你没看错。核心功能是您无需要求即可使用的一切。DateTime似乎不在核心中(你是在Rails控制台中运行你的代码行吗?)DateTime.now#=>#~>-:1:in`':uninitializedconstantDateTime(NameError)但是时间是Time#=>TimeTime.now#=>201
我正在努力使用GoogleAPI客户端:https://github.com/google/google-api-ruby-client具体来说,我想使用以下google_contacts_api.rb通过GoogleAPI客户端访问Google通讯录:https://gist.github.com/lightman76/2357338dcca65fd390e2我正在尝试像这样使用google_contacts_api.rb(x是有意的,实际上是正确的键):require'./lib/google_contacts_api.rb'auth=User.first.authenticati
我正在使用Vagrant+VirtualBox为我的Rails应用设置虚拟机。我正在清理Vagrantfile中引用的.sh配置脚本,如下所示:config.vm.provision"shell",path:"script/provision-script.sh"配置脚本做了很多事情,但最后它应该安装rbenvRuby版本控制,然后使用rbenv安装Ruby2.2.1。供应脚本的那部分看起来像这样:echo"settinguprbenv"#executetheremainingcommandsasvagrantuser,insteadofrootsudo-H-uvagrantbash-
目前,我的Users数据库有一个名为“admin”的列,其值为bool值,默认设置为false。我有一个管理员用户播种到数据库中。如何编写我的应用程序以便是管理员的用户可以创建新用户,而不是的用户不能?(此外,用户应该仅由管理员创建)似乎应该有一种简单的方法可以在不涉及使用某些外部模块的设计中做到这一点。然而,到目前为止,我还没有找到满意的答案。我更有可能标记仅是设计的解决方案。(一个简单的标准MVC/Rails解决方案加分)但是,如果真的有更好的方法来做到这一点而不涉及CanCan,我可能也接受它。注意:我已经搜索了一段时间,发现了其他几个与这个问题非常相似的stackoverflo
我正在研究cursesgem的curses.rb,我发现它无处不在:defattrset(attrs)#Thisisastub,usedforindexingend#bkgdset(ch)##Manipulatethebackgroundofthecurrentwindow#withcharacterInteger+ch+##seealsoCurses.bkgdsetdefbkgdset(ch)#Thisisastub,usedforindexingend#bkgd(ch)##Setthebackgroundofthecurrentwindow#andapplycharacterInt
我们想设置自动化作业(通过Jenkins)以在第三方API出现故障或他们部署了不兼容的API时发出警报。我说的是针对真实的HTTPAPI进行测试,而不是模拟,但是因为我们已经使用rspec编写了模拟,所以我不确定我们是否应该通过编写两个独立的睾丸来重复这项工作。有人有这方面的经验吗?(如果其他工具可以提供帮助,我不限于Ruby/Rspec) 最佳答案 你看过VCR了吗??使用它,您可以“记录您的测试套件的HTTP交互并在未来的测试运行期间重播它们以进行快速、确定性、准确的测试”。在测试来自外部API的预期响应时,我将它与RSpec一
关于API管理工具,如今的市场已经把用户教育的差不多了,毫不夸张地说,如果我随机抽取一位幸运读者,他都能给我罗列出一二三四款大家耳熟能详的工具。可说到开源的API管理工具,大家又能知道多少呢?我们是否真的需要开源的API管理工具?我的回答是肯定的,百花齐放才是健康的生态,除了商业,应该得有开源的产品,因为开源的API具有这些优势:免费:开源API管理工具通常是免费的,这可以帮助小公司和个人开发者降低开发成本,快速构建自己的API服务。开放方式:开源工具通常是开放和透明的,用户可以查看和修改源代码,并且能够在社区中共享和交流,这使得开源工具更加灵活和可定制。社区支持:开源API管理工具通常有一个