ruby-on-rails – Rails API版本控制,路由问题

ruby-on-rails – Rails API版本控制,路由问题,第1张

概述我正在尝试使用基于 Railscasts #350 episode的版本控制来实现一个简单的rails api应用程序.我希望通过以下格式的Accept标头提供版本来访问应用程序的特定API版本:application / vnd.rails5_api_test.v1.当没有提供Accept标头时,请求将被路由到应用程序的当前默认版本.为了解决这个问题,我在lib目录中创建了一个api_const 我正在尝试使用基于 Railscasts #350 episode的版本控制来实现一个简单的rails API应用程序.我希望通过以下格式的Accept标头提供版本来访问应用程序的特定API版本:application / vnd.rails5_API_test.v1.当没有提供Accept标头时,请求将被路由到应用程序的当前默认版本.为了解决这个问题,我在lib目录中创建了一个API_constraints文件,该文件在路由中是必需的.

我创建了app v1和v2的两个版本,其中v1具有Users资源,v2具有Users和Comments资源.
一切都按预期工作,除了我通过使用Postman通过标题传递版本1来请求URL localhost:3000 / comments时,我从评论资源获得响应,显示所有注释.但我希望响应成为状态:404 Not Found,因为评论资源是版本2,请求的版本是1.

这是来自服务器的响应:

Started GET "/comments" for 127.0.0.1 at 2016-04-01 20:57:53 +0530Processing by API::V2::CommentsController#index as application/vnd.rails5_API_test.v1  Comment Load (0.6ms)  SELECT "comments".* FROM "comments"[active_model_serializers]   User Load (0.9ms)  SELECT  "users".* FROM "users" WHERE "users"."ID" =  liMIT   [["ID",1],["liMIT",1]][active_model_serializers] Rendered ActiveModel::Serializer::CollectionSerializer with ActiveModelSerializers::Adapter::JsonAPI (4.32ms)Completed 200 OK in 7ms (VIEws: 5.0ms | ActiveRecord: 1.5ms)

这是我的工作文件:
约束文件lib / API_constraints.rb:

class APIConstraints  def initialize(options)    @version = options[:version]    @default = options[:default]  end  def matches?(req)    req.headers["Accept"].include?(media_type) || @default  end  private  def media_type    "application/vnd.rails5_API_test.v#{@version}"  endend

路由文件,config / routes.rb:

Rails.application.routes.draw do  require "API_constraints"  scope module: 'API/v1',constraints: APIConstraints.new(version: 1) do    resources :users  end  scope module: 'API/v2',constraints: APIConstraints.new(version: 2,default: true) do    resources :users    resources :comments  endend

v1,API / v1 / users_controller.rb的用户控制器:

class API::V1::UsersController < ApplicationController  def index    @users = User.all    render Json: @users,each_serializer: ::V1::UserSerializer  endend

用户控制器为v2,API / v2 / users_controller.rb:

class API::V2::UsersController < API::V1::UsersController  def index    @users = User.all    render Json: @users,each_serializer: ::V2::UserSerializer  endend

用于v2,API / v2 / comments_controller.rb的注释控制器:

class API::V2::CommentsController < ApplicationController  def index    @comments = Comment.all    render Json: @comments,each_serializer: ::V2::CommentSerializer  endend

v1的user serializer,user_serializer.rb:

class V1::UserSerializer < ActiveModel::Serializer  attributes :ID,:name,:emailend

v2的user serializer,user_serializer.rb:

class V2::UserSerializer < V1::UserSerializer  has_many :commentsend

注释v2的序列化程序,comment_serializer.rb:

class V2::CommentSerializer < ActiveModel::Serializer  attributes :ID,:description  belongs_to :userend

我尝试删除路由中的default:true选项,然后它按预期工作.但我希望它与默认选项一起使用.

任何人都可以让我知道我在哪里弄错了,并分享你对这种方法的看法.如果这不是最好的方法,那么引导我完成实现它的正确方法.提前感谢任何需要时间帮助我的人. :)干杯!

解决方法 我不认为这可以轻易解决,因为v1没有评论v2将匹配,无论如何.

你是APIConstraints使用这种方法吗?

def matches?(req)    @default || req.headers['Accept'].include?("application/vnd.example.v#{@version}")  end

我认为这里的方法有点过于松散,看起来应该忽略那些有版本的请求.

def matches?(req)    (@default &&         req.headers['Accept'].grep(/^application/vnd.example.v\d+/$).empty?    ) || req.headers['Accept'].include?("application/vnd.example.v#{@version}")  end
总结

以上是内存溢出为你收集整理的ruby-on-rails – Rails API版本控制,路由问题全部内容,希望文章能够帮你解决ruby-on-rails – Rails API版本控制,路由问题所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1271181.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存