为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

RISEBY 2023-06-27 16:42:16
所以我需要创建一个 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 来做到这一点。有关如何更好地实施它的任何提示。
查看完整描述

2 回答

?
蝴蝶刀刀

TA贡献1801条经验 获得超8个赞

我用一种非常简单的方式解决了我的问题。


代码:


@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

查看完整回答
反对 回复 2023-06-27
?
波斯汪

TA贡献1811条经验 获得超4个赞

如果您想返回 Json(对于 REST-API),您只需在 Response 对象中返回它即可。

确保您已从Response导入odoo.http。然后你可以像这样返回json数据:

return Response(json.dumps({'order_id': order_id}), status=200, content_type="application/json")

我通常将此逻辑包装在一个单独的函数中(在控制器外部),该函数在更新的 Odoo 对象上记录请求和响应,然后返回 Response 对象。这样,它也可以在错误处理中轻松重用(然后您可以在其中返回 Json 格式的自定义错误响应)

编辑:还要确保您没有包含Content-Type: application/json在请求中,在这种情况下,Odoo 会认为这是一个 JSON-RPC 请求。


查看完整回答
反对 回复 2023-06-27
  • 2 回答
  • 0 关注
  • 170 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信