我是Ruby on Rails中的新成員。我正在使用Rails 5.1,活動記錄序列化器,門衛和設計寶石製作Rails API。與rails API的HABTM關係不起作用
我有一個Order
表,它有許多產品。訂單和產品之間的關係是多對多的。
訂貨型號:
class Order < ApplicationRecord
validates_presence_of :brute, :net
has_and_belongs_to_many :products
end
產品型號:
class Product < ApplicationRecord
belongs_to :category
validates_presence_of :name, :price
validates_uniqueness_of :name
has_and_belongs_to_many :orders
end
我有一個名爲orders_products
連接表。
訂購串行:
class OrderSerializer < ActiveModel::Serializer
attributes :id, :discount, :brute, :net, :payed, :payed_at, :products
def products
object.products.map do |product|
ProductSerializer.new(product, scope: scope, root: false, event: object)
end
end
end
產品序列化:
class ProductSerializer < ActiveModel::Serializer
attributes :id, :name, :price, :description
has_one :category
end
令控制器:
module Api
class OrdersController < ApiController
before_action :set_order, only: [:show, :update, :destroy]
# GET /api/orders
def index
@orders = Order.all
render json: @orders
end
# GET /api/orders/1
def show
render json: @order
end
# POST /api/orders
def create
@order = Order.new(order_params)
if @order.save
render json: @order, status: :created, location: api_order_url(@order)
else
render json: @order.errors, status: :unprocessable_entity
end
end
# PATCH/PUT /api/orders/1
def update
if @order.present?
if @order.update(order_params)
render json: @order
else
render json: @order.errors, status: :unprocessable_entity
end
end
end
# DELETE /api/orders/1
def destroy
@order.destroy if @order.present?
end
private
# Use callbacks to share common setup or constraints between actions.
def set_order
@order = Order.find(params[:id])
rescue ActiveRecord::RecordNotFound
Rails.logger.error{ 'Order record is not found' }
nil
end
# Only allow a trusted parameter "white list" through.
def order_params
params.require(:order).permit(:discount, :brute, :net, :payed, :payed_at, product_ids: [])
end
end
end
當我發佈的API生成器應用中的一些秩序JSON數據,如郵差/失眠,訂單正在保存在訂單表中,但沒有保存在orders_products
連接表中的數據。
我的訂單JSON的請求(POST http://localhost:3000/api/orders):
{
"discount": 110,
"brute": 100,
"net": 200,
"payed": null,
"payed_at": null,
"product_ids": [3]
}
我試圖找到解決辦法,但我失敗了。
我不使用序列化程序,所以我不太熟悉你的一些代碼。雖然您可以指出您的代碼中的哪個位置可以將產品添加到您的訂單中嗎?也許你可以複製視圖(erb)文件,在這裏處理太多.. – Maxence
我也面臨同樣的問題。但是在使用活動記錄序列化程序gem時沒有erb文件。 –