猿问

如何从 JSON 控制器调用 Odoo 数据?

所以我需要创建一个 Rest 服务,它将调用特定模型中的数据。


为了做到这一点,我必须创建一个控制器。


我是 Odoo 和 Json 的新手,我找不到任何可以解决这个问题的东西。


到目前为止,除了 http 请求之外,我所需要的就是我所需要的。


class RestService(http.Controller):

    @http.route('/orders/<model("sale.order"):order>', auth='none', website=True)

    def consulta_orden(self , order):

        return request.render('consulta_pedidos.order', {'order': order})

        

        return {'order_id': order_id}

这个想法是,当我加载数据时,我可以在模板中呈现这些数据。已经用 Http 请求做到了这一点,但我需要用 Json 来做到这一点。有关如何更好地实施它的任何提示。


RISEBY
浏览 171回答 2
2回答

蝴蝶刀刀

我用一种非常简单的方式解决了我的问题。代码:@http.route(['/orden_detalle', '/orden_detalle/<int:order_id>'], type='json', auth='user')    def orden_detalle(self, order_id=None):        if order_id:            domain = [('id', '=', order_id)]        else:            domain = []        sales_rec = request.env['sale.order'].search(domain)        sales = []        for rec in sales_rec:            vals = {                'id': rec.id,                'name': rec.name,                'partner_id': rec.partner_id.name,                'user_id': rec.user_id.name,            }            sales.append(vals)        data = {'status': 200, 'response': sales, 'message': 'Sale(s) returned'}        return data

波斯汪

如果您想返回 Json(对于 REST-API),您只需在 Response 对象中返回它即可。确保您已从Response导入odoo.http。然后你可以像这样返回json数据:return&nbsp;Response(json.dumps({'order_id':&nbsp;order_id}),&nbsp;status=200,&nbsp;content_type="application/json")我通常将此逻辑包装在一个单独的函数中(在控制器外部),该函数在更新的 Odoo 对象上记录请求和响应,然后返回 Response 对象。这样,它也可以在错误处理中轻松重用(然后您可以在其中返回 Json 格式的自定义错误响应)编辑:还要确保您没有包含Content-Type: application/json在请求中,在这种情况下,Odoo 会认为这是一个 JSON-RPC 请求。
随时随地看视频慕课网APP

相关分类

Python
我要回答