ruby-on-rails – ActiveResource如何从具有单数名称的REST API获取资源?

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – ActiveResource如何从具有单数名称的REST API获取资源?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图从具有以下API的第三方库中获取数据:

https://foo.com/user.json?username=\u0026lt;USERNAME\u0026gt;

我无法弄清楚如何强制ActiveResource使用“user.json”而不是“users.json”.可能吗?

我使用了reactive_resources gem …有没有办法在纯粹的ActiveResources中做到这一点?

解决方法

  1. class User < ActiveResource::Base
  2. self.element_name = "user"
  3. end

接下来,您将询问如何从URL中查找ActiveResource的一个元素为//foo.com/user.json而不是//foo.com/user/.json

  1. User.find(:one,:from => "https://foo.com/user.json?username=#{<USERNAME>}"

编辑以回应评论

有没有办法这样做,而不必每次我想使用find()时输入请求的完整URL?

一种方法是在类中定义一个方法来为您执行完整的URL.

  1. class User < ActiveResource::Base
  2. self.element_name = "user"
  3.  
  4. def self.find_by_username(username)
  5. find(:one,:from => "https://foo.com/user.json?username=#{username}"
  6. end
  7.  
  8. def find
  9. self.class.find(:one,:from => "https://foo.com/user.json?username=#{username}"
  10. end
  11. end

另一种方法是重新定义element_path.

  1. class User < ActiveResource::Base
  2. self.element_name = "user"
  3.  
  4. def self.element_path(id,prefix_options = {},options = {})
  5. "https://foo.com/user.json?username=#{prefix_options["user_id"]}"
  6. end
  7. end

有些人称之为猴子修补,其他人称之为面向对象编程.我说当你进入代码或使用Ruby的动态性质来改变基本行为时,它只是猴子修补,这是在面向对象编程中做事的一种完全合法的方式.但是,Ruby社区并没有太多使用OOP,几乎忽略了继承而支持更松散(和不太好的)混合,并且只使用duck-typing来实现多态.

不得不混淆ActiveResource来构建一个URL,你无法重新定义Web服务以接受ActiveResource约定的问题是许多人使用HTTParty的原因. “如果你必须构建URL,也可以使用HTTParty.”

猜你在找的Ruby相关文章