# Odoo丨Odoo框架源码研读一:前后端交互

2023-10-29

Odoo丨Odoo框架源码研读一:前后端交互

本期内容

Odoo框架源码研读之

前后端交互

Odoo框架是一款企业应用快速开发平台,适用于各种规模的企业应用,安装与使用十分广泛。

Odoo框架源码的第一篇研读内容——“前后端交互”。

*源码文件结构*

Odoo14.0源码结构:

.
|-- CONTRIBUTING.md
|-- COPYRIGHT
|-- LICENSE
|-- MANIFEST.in
|-- README.md
|-- SECURITY.md
|-- addons
|-- debian
|-- doc
|-- odoo
|-- odoo-bin
|-- requirements.txt
|-- setup
|-- setup.cfg
`-- setup.py
  • doc文件夹下是项目的帮助文档;
  • odoo-bin文件是Odoo的启动脚本,配合自定义的odoo.conf配置文件,用来启动项目;
  • odoo是Odoo的底层模块,包含项目的基础父类,以及项目启动需要的基础类;
  • addons中包含了odoo的基础业务模块,包括CRM、Sales等模块。

框架结构

经历了六个月的Odoo学习与实战,基于笔者对Odoo前后端交互的理解,总结出了下面的框架,供大家参考 ⬇

图片

*前后端交互*

Odoo的前端基础框架,以及和后台基础模块交互的API,都封装在了addons下的web模块。

Controller控制器

Odoo是通过Controller控制器,来控制前后台的交互。

然后再根据功能的不同,划分成了多个控制器,从下图中每个controller的命名中,可以了解各自对应的功能模块。

图片

这些Controller继承了Base模块中的Controller基类,并通过http.route装饰器的注解,将Controller中的方法标记为请求处理器,变成对外暴露的API接口,接收并处理http请求。

关于http.route的详细介绍,源码中有详细的注释。

此处以基础业务模块的Controller控制器DataSet查询列表数据接口search_read为例:

图片

http.route

图片

Dispatcher分发模块

通过调试代码,整理请求在到达Controller之前的处理流程如下:

图片

# Root

Root是Odoo的WSGI根应用,会在项目启动的时候创建。

请求到达Odoo后,会被Root接收,并调用Dispatch方法。

图片

# Root在Dispatch方法处理流程:

Step1:获取werkzeug中的原始request对象;

Step2:设置上下文环境,包括将状态绑定线程、设置session、数据库、语言等。

Root在设置DB的时候,会根据db_filter配置参数去获取匹配的数据库信息。

如果唯一,那么进入系统登陆页面的时候session中会带有db;

反之进入系统时Session中不会带有DB,并会进入数据库选择页面,选择之后才是登陆页面。

登陆时会把选择的数据库信息设置到Session中,以保证后面的请求,都会通过IrHttp映射器,分映射发请求到对应的方法。

Step3:通过get_request方法,将request对象封装成HttpRequest或者JsonRequest;

Step4:通过判断Session是否带有DB数据库名称,调用不同的分发逻辑。如果DB值为空,就会跳转到选择数据库的界面,否则会调用IrHttp请求映射器进行Dispatch。

# IrHttp

源码中,对IrHttp的描述是"HTTP Routing"或者是"Routing map"。

图片

请求在到了IrHttp._dispatch()后,做了如下操作:

Step1:根据请求中的path作为key去routeing_map中匹配对应的路由信息(方法、参数等);

图片

图片

Step2:根据获取到的路由信息中的auth,去进行权限校验;

Step3:根据获取的路由信息以及校验信息,封装requestHandler;

图片

# 调用Request的Dispatch方法:

请求在到了HttpRequest/JsonRequest的Dispatch方法后,都通过父类WebController的__call_function()方法。

根据在IrHttp时,已经封装好的entpoint路由信息,路由到对应的Controller中的接口方法。

除此之外,HttpRequest在call_function之前,还校验了csrf_token,而JsonHttp,则是根据配置打印debug日志,以及返回结果,封装json_response。

图片

图片

图片

至此,请求就顺利的到达了Controller控制器。

关于HttpRequest和JsonRequest,两者都继承了同一个父类WebRequest。可以看出:两者都具有处理异常、分发请求的功能。

相比于JsonRequest,HttpRequest多了是否校验cors、渲染html和处理404请求的功能;而JsonRequest,则多了封装json_response的功能。

具体对比如下:

图片

关于Odoo架构中前后端交互的内容,本篇就先讲到这里,下一期我们将给大家深入的介绍Odoo的ORM。

Odoo框架源码解读干货

用心奉上,欢迎交流~

你有更好思路或疑问

快来加入社群一起讨论哦⬇

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

# Odoo丨Odoo框架源码研读一:前后端交互 的相关文章

随机推荐

  • Intel(R) CFL Mobile/DeskTop Gra显卡驱动

    Intel R CFL Mobile DeskTop Gra这款显卡的驱动不好找 无论是百度还是谷歌 都找不到对应型号的显卡驱动 我找到一个igfx win10 100 9466 exe 可以支持Intel R CFL Mobile Des
  • 大数据技术中的伦理问题

    前言 从2012年开始 大数据 big data 一词越来越多地被提及 人们用它来描述和定义信息爆炸时代产生的海量数据 并命名与之相关的技术发展与创新 在现今的社会 大数据的应用越来越彰显他的优势 它占领的领域也越来越大 电子商务 O2O
  • 华为OD机试 Python 最大价值的矿堆

    题目 背景 你面前有一张地图 上面标有金矿 银矿和空地 这里的规则很简单 金矿值2分 银矿值1分 矿堆是由上下左右相邻的金矿或银矿组成的 现在的任务是 找出地图上价值最高的矿堆 并告诉我们它的总价值 地图说明 0 表示空地 1 表示银矿 2
  • 100天精通Python(进阶篇)——第39天:操作MySQL和SqlServer(pymysql、pymssql基础+代码实战)

    文章目录 一 安装第三方模块 二 pymysql模块使用说明 1 操作流程流程 2 导入pymysql模块 3 创建连接对象 4 获取游标对象 5 获取一条数据 6 获取多条数据 7 对数据增删改操作 三 pymssql模块使用说明 一 安
  • 用python来做regression 图

    我们直接上代码了 之前已经介绍了如何导入表格了 现在就用表格中的数据来进行画图 还是用之前的表格 import pandas as pd import matplotlib pyplot as plt data pd read csv 1
  • ChatGPT如何应用于代码注释和文档自动生成?

    作为一名Java高级软件开发专家 我们在平时的工作中经常会遇到需要撰写代码注释和文档的情况 为了提高编码效率和代码质量 越来越多的开发人员开始探索使用自然语言处理技术 如ChatGPT 来自动生成代码注释和文档 本文将介绍如何将ChatGP
  • x轴z轴代表的方向图片_数控机床的X,Y,Z轴分别指什么方向的运动

    展开全部 标准坐标系的规定 标准坐标系是一个直角坐标系 如图所示 按右手e69da5e887aa3231313335323631343130323136353331333366303836直角坐标系规定 右手的拇指 食指和中指分别代表X Y
  • 关于Ionic2\Angular2使用http的一些坑

    1 服务器接收key value key value类型的值 但服务器无法获取到Post请求的body的值 描述 使用url key value key value的形式可以正常请求到参数 但是把参数放入到body后 服务器估计获取到信息但
  • Kotlin项目类找不到bug:java.lang.ClassNotFoundException: kotlin.reflect.Kotlin Reflect Internal Error

    一 今天在创建了一个Kotlin Spring的项目 结果启动报错 org springframework context ApplicationContextException Unable to start web server nes
  • Python - selenium自动化-Chrome(wap模式)

    Selenium Chrome浏览器如何模拟手机操作 进入手机模式 打开谷歌浏览器 按F12 进入开发者模式 点击Toggle device toolbar 进入手机模式 设置Chrome的手机模式 deviceName可更改成Chrome
  • 人工智能 机器学习实验总结

    答案仅供参考 1 数据预处理 给定数据集datingTest 实验任务 读取DatingTest的数据文件 1 并输出第一列数据的最大 最小和均值 2 输出该文件有多少数据 3 计算第一条数据和第二条数据的欧式距离 import panda
  • 面试题 v-if跟v-show的区别

    v if v show 区别 展示形式不同 v if是 创建一个dom节点 V show 是 display none block 使用场景不同 初次加载 v if 要 比v show 好 页面不会做加载盒子 频繁切换 v show 要比
  • JDK8新特性(七)之Stream流的count()、filter()、limit()、skip()方法

    1 Stream流的count 方法 Stream流提供count方法来统计其中的元素格式 long count 该方法返回一个long值代表元素个数 基本使用 import java util ArrayList import java
  • cmake

    cmake的常用命令 cmake minimum required message project set add executable add compile options add subdirectory add library ta
  • python -- 替换netcdf文件中的时间

    最近 在处理nc文件时 在时间上存在部分缺失的数据 为了避免影响后续操作 这里通过复制前一时刻的nc数据进行替代 但是虽然缺失时刻的数据得到了填充 但是填充的数据的时间属性本质上仍然是前一时刻的 为了保证时间的一致性 这里通过一个更新时间的
  • ARM(IMX6U)裸机C语言蜂鸣器驱动实验(BSP+SDK)

    参考 Linux之ARM IMX6U 裸机C语言蜂鸣器驱动实验 驱动编写 编译 作者 一只青木呀 发布时间 2020 08 16 14 47 23 网址 https blog csdn net weixin 45309916 article
  • android adb常用指令

    Android 调试桥 adb 是多种用途的工具 该工具可以帮助你你管理设备或模拟器 的状态 可以通过下列几种方法加入adb 在设备上运行shell命令 通过端口转发来管理模拟器或设备 从模拟器或设备上拷贝来或拷贝走文件 下面对adb进行了
  • C++数组的正确释放方式

    include
  • mariadb日志报错:error while loading shared libraries: libjemalloc.so.2处理办法

    Linux下找不到so文件的解决办法 rznice 2016 03 11 16 39 27 19494 收藏 1 分类专栏 linux 版权 最近在安装完tengine 在启动tengine时报找不到libjemalloc so 2的提示
  • # Odoo丨Odoo框架源码研读一:前后端交互

    Odoo丨Odoo框架源码研读一 前后端交互 本期内容 Odoo框架源码研读之 前后端交互 Odoo框架是一款企业应用快速开发平台 适用于各种规模的企业应用 安装与使用十分广泛 Odoo框架源码的第一篇研读内容 前后端交互 源码文件结构 O