首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PayPal大规模采用GraphQL探索和实践

由于 REST API服务器决定了数据形状,我们 UI 团队花费了大量时间客户端过滤和解析数据,通常使用诸如 Redux 之类库来格式化和存储数据。...GraphQL 帮助解决了这个问题,因为它允许我们一次往返中获取所需一切。 使客户端保持最新:我们 REST API 中大量使用 API 版本号。...与 API 集成时开发人员体验不一致: REST API 中,不同团队对同一变量有不同约定,例如 user、username, 使得理解 API 变得更加困难。...PayPal 有一套庞大 REST API,支持应用程序核心功能,并且非常靠近数据库。GraphQL 我们应用程序中用作编排层。...范式转换:由于 GraphQL 要求采用设计优先方法,我们启用业务用例时考虑 GraphQL,并在考虑客户情况下构建 API。 更快交付速度:我们能够更快地交付功能。

3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    不容错过 Node.js 项目架构

    Express.js 是用于开发 Node.js REST API 优秀框架,但是它并没有为您提供有关如何组织 Node.js 项目的任何线索。 虽然听起来很傻,但这确实是个问题。...正确组织 Node.js 项目结构将避免重复代码、提高服务稳定性和扩展性。...这篇文章是基于我多年来处理一些糟糕 Node.js 项目结构、不好设计模式以及无数个小时代码重构经验探索研究。...这是我要谈论 Node.js 项目结构。 我构建每个 Node.js REST API 服务中都使用了下面这个结构,让我们了解下每个组件功能。...其思想是使用关注点分离原则将业务逻辑从 Node.js API 路由中移开。 ? 图片描述 因为有一天,您将希望一个 CLI 工具上来使用您业务逻辑,又或从来不使用。

    5.9K30

    基于场景选择微服务API范式:REST、GraphQL、Webhooks和gRPC

    总之,REST是现代微服务API领域非常高效、有效和强大解决方案。 二、REST案例:PayPal REST API一个示例应用是PayPal REST API。...为此,PayPal API设计理念是易于理解和易于集成。...在这一成熟度模型中第4级,使用超媒体作为应用状态引擎(HATEOAS);多个URI,多个HTTP方法资源表达中包含了链接信息。客户端可以根据链接来发现可以执行动作。...Webhook范式下,服务器更新所需提供资源,然后自动将其作为更新发送到客户端(服务器是推数据),客户端不是请求者,而是被动接收方。...因此,做好功课,并从一开始就选择正确方法,以获得一些真正收益。你代码将更加简洁,响应性更强,并且适合当前情况。

    2.6K30

    REST架构】OData、JsonAPI、GraphQL 有什么区别?

    它们都描述了用于创建和使用 RESTful API 标准协议。GraphQL 是一种完全不同 API 设计方法,并指定了一种查询 API 资源不同方式。...有许多用于流行编程语言库 - .NET、Java、JavaScript、PHP 和 Ruby。该规范允许动态资源,并且有一个服务文档列出了所有 API 端点供客户端发现。...这种新模型更适合开发人员使用,但它相对于 REST 优势是值得商榷。鉴于其年轻,生态系统尚未成熟。 为了清楚和完整起见,我将 OpenAPI 包括列表中,尽管它并不完全是 API 规范。...总之,OData 和 JSON API 都是 JSON 数据格式,它们在数据周围添加上下文和特征(例如链接),GraphQL 是一种完全不同查询和变异 JSON 数据方法,而 OpenAPI 是声明和记录任何数据标准方法...选择上述任何一项好处都很小,特别是如果您项目是中小型项目。您 API 实现规范是否重要?应该不多吧。只需专注于构建一致且记录良好 API

    1.5K20

    VS Code 扩展巡礼-REST Client

    我们可以官方介绍中关注两点 1 基本 HTTP 请求模拟,HTTP 输入和 HTTP 响应 2 VS Code 自带辅助功能,如自动补全 Http Content-Type 等信息 ?...项目中可以将报文以 http 文件形式归档整理,作为项目的一部分。 2 报文格式,严格按照 RFC 2616,主要是一行一个元素。...分割,加载这个新 url 发送到服务器(表单默认提交数据格式)。 当请求为 post 时,浏览器把 form 数据封装到 http body 中,然后发送到 server。...如果 ContentType 不一致,就是造成传递与接收参数位置不对应,客户端传值正确,服务器端接收不到值情况。...网上转变方法基本都是写添加下面这句: curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded

    2.2K40

    RESTful API生命周期管理

    基于架构风格简单较小学习曲线。 学习曲线更高,但是使用标准化协议优点是合理。 了解REST和SOAP之间好处和差异进行关于API开发架构/设计决策时至关重要。...请记住,可以使用您API产品来支持REST和SOAP。这通常是一种首选方法,取决于客户需求。 接口模型 RESTful服务使用统一接口,将架构解耦并分解成以下四个约束。...自我描述性消息 作为REST消息一部分,指定了互联网媒体类型(以前称为MIME类型),以便可以调用正确解析器。常见互联网媒体类型是“application / json”。...API安全 安全模型 RESTful应用程序依赖于API生态系统底层安全性,而不是REST架构风格中包含安全性。...API笔记本:为开发人员提供测试API,操纵API调用结果以及使用JavaScript语言连接到多个API环境。

    3.6K70

    微服务架构实战:Swagger规范RESTful API

    因此,引入Swagger进行Rest API文档管理对项目来说,效率和产出会更高。数字化企业云平台团队经过调研后决定采用Swagger来进行REST API管理。...(注:Microsoft,PayPal等公司也已经引入Swagger 来定义自己REST API 文档。)...在数字化企业云平台项目中同时引入了Swagger-Maven-plugin,通过已有的API接口中添加少量annotation, 同时配置Pom.xml文件,即可在Maven compile期间自动生成对应...RESTful架构项目中引入Swagger对REST API进行文档管理优势是显而易见,数字化企业云平台后续也将基于自动生成Swagger文件引入API Mock。...曾就职于Emerson Network power和Tibco CDC,并担任Team Leader,期间成功领导多个项目的研发,同时拥有丰富Cloud经验。

    1.5K90

    BeLink - 支持生成多种URL 缩短网址PHP源码

    工作区/团队——创建多个工作区并邀请团队成员就活动、链接、自定义域等进行协作。 链接旋转器——将多个链接放入一个组中,并使用该组短链接将用户重定向到该组中随机链接。...(可选)SaaS 模式 –使用内置高级订阅系统赚钱。为用户创建不同订阅计划,并控制每个计划功能和限制。Paypal 和 Stripe 集成已完全内置。...API –功能齐全 REST API 允许通过 REST API 执行网站上可能任何操作。还包括交互式 API 文档。...链接组——将多个链接组合在一起,以允许查看该组中所有链接统计信息,并查看不同组相互比较时表现。...安装要求和更新日志 要求 PHP 8.1 或更高版本 PDO 扩展(默认启用) php_fileinfo 扩展(默认启用) MySQL 数据库服务器 更新 2024 年 5 月 24 日 - 版本 3.0.8

    12310

    Yii2.0 RESTful API 认证教程

    access token, 然后通过 HTTP Bearer Tokens 发送到 API 服务器。...2.使用数据迁移方式 进入项目根目录打开控制台输入以下命令: php yii migrate/create add_access_token_to_user 打开 你项目目录/console/migrations...,因此我们到api\models\User.php中添加此方法 namespace api\models; use Yii; use yii\base\NotSupportedException; use...接下来我们围绕这两步来实现: 添加一个REST控制器 因我这里暂未设计其他数据表 所以我们暂且还使用User 数据表吧 api\controllers\新加一个控制器 命名为 ArticleController...魏曦老师 学 魏曦教你学 写完认证发现我们接口返回数据不是很直观,现实生活中通常也不是这样子,我们可能会返回一些特定格式 自定义响应内容 打开 api\config\main.php components

    1.6K30

    标准化API设计流程!

    下图显示了REST和GraphQL之间快速比较。 REST 使用标准HTTP方法,如GET,POST,PUT,CRUD操作。...GraphQL非常适合复杂或频繁变化前端需求,而REST适合那些首选简单和一致合同应用程序。 这两种API方法都不是银弹。仔细评估需求和权衡对于选择正确风格很重要。...❝有两种方法可以处理与外部PSP通信。 1.短轮询 向PSP发送支付请求之后,支付服务继续询问PSP关于支付状态。经过几轮之后,PSP最终返回状态。...出于安全原因,我们需要在API网关中设置适当规则。 我们需要在外部服务注册正确URL。 如何提高API性能? 下图显示了提高API性能5个常用技巧 分页 当结果大小很大时,这是一种常见优化。...API网关中设计适当HTTP头字段或设计有效速率限制规则同样重要。

    11310

    yii2 restful 风格搭建(二)接口认证

    只输入用户名认证需要在你 user identity class 类中实现 findIdentityByAccessToken() 方法 (2)如果需要验证用户名和密码,HttpBasicAuth 中注释中也说明了配置方法...Tokens 发送到API 服务器。...() 方法 3、JSONP请求: \yii\filters\auth\QueryParamAuth URL请求参数中加入 access_token,这种方式应主要用于JSONP请求,因为它不能使用...access-token=123 二、根据需求,为 restful api 增加业务逻辑增加验证和接口返回码 1、业务需求 (1)用户注册接口 (2)用户登录接口 (3)获取商品信息接口 (4)三个接口调用时...sign=sdasds 返回: {"code":401,"msg":"auth error"} (2)正确 sign,可是没有传 register 必须参数 ($params = []) 命令: curl

    1.2K31

    挖洞经验 | 看我如何利用上传漏洞PayPal服务器上实现RCE执行

    当你看到这篇文章标题时,是不是很吃惊,PayPal服务器RCE漏洞?Dafaq?WTF?真的吗?这当然是真的,很幸运,我通过枚举和域名查找方法发现了该漏洞。...从头说起 最近,我通过4个月夜以继日学习努力,突破重重考验,终于获得了OSCP渗透测试认证。这么长时间花费,以至于我根本没时间参与一些漏洞众测项目。所以,接下来打算挖挖漏洞赚点零花钱。...上传漏洞发现 某个周末,我和往常一样博客和Youtube上研究技术,碰到了关于PayPal漏洞一些writeup,于是,打算在PayPal漏洞赏金项目中查点资料。...Burp拦截器关闭状态下,我访问了PayPal漏洞赏金项目主页,发现了一些东西,如下: 打开主页后,Burp中可以得到以上响应信息,仔细观察,其响应头内容安全策略(CSP)保护中包了多个PayPal...在这里得到工单号目录为/366/,由于不知道存储目录,所以具体php文件也无人知晓。 但是,从前述JPG上传过程中,我们知道系统把上传文件转储后还会仍然同一个目录下保存原文件。

    1.3K50

    Restfull API

    什么是Restfull API Restfull API 从字面就可以知道,他是rest接口,所以就要先了解什么是rest rest 不是一个技术,也不是一个协议 rest 指的是一组架构约束条件和原则...,提供了一个新架构设计思路,满足这些约束条件和原则应用程序或设计就是 RESTful REST规则中,有两个基础概念:对象、行为 对象就是我们要操作对象,例如添加用户操作,那么对象就是user...行为有4种常用:查看、创建、编辑、删除 rest提出者很巧妙利用http现有方法来对应这4种行为: GET - 查看 POST - 创建 PUT - 编辑 DELETE - 删除 为什么用...Restfull API 例如常用MVC结构中,前后端融合还是比较紧密,用户访问一个网址,例如 http://test.com/a.php,请求先发送到动态php处理,php中处理逻辑,然后使用页面模板来输出显示给用户...,如果开发人员用了一个没有明确意义名字,那就需要看文档或者代码才能知道含义了 而Restfull API 通过 GET 方法就知道是查看操作,通过tasks就知道查看对象是什么

    90990

    通俗易懂RESTful,如何设计RESTful风格API「建议收藏」

    大家都知道”古代”网页是前端后端融在一起,比如之前PHP,JSP等。...从应用角度来分析: 一、REST描述是在网络中client和server一种交互形式;REST本身不实用,实用是如何设计 RESTful APIREST风格网络接口); 二、Server提供...比如: DELETE http://api.qc.com/v1/friends: 删除某人好友 (http parameter指定好友id) POST http://api.qc.com/v1/...根据项目的需求不同,我们API设计规范也存在差别,完全看自身理解,满足自身需求,大理念不变,根据需求制定项目API规范就是好RESTful,下面附上一些设计规范,可自行参考。...参考资料: Richardson Maturity Model – steps toward the glory of REST PayPal REST APIs 阮一峰RESTful设计规范 Richardson

    67610

    把 WordPress 变成 BaaS 服务:API 调用指南

    可惜是, 2022 年,有一个社区用户向官方提问这个项目是否还在维护[8],得到答复是否定项目不再积极维护,不过官方说社区用户依旧可以提交 PR 来做一些细微改进。...不过,庆幸是, WordPress 最新发布 6.5.0 版本变更记录中[10],依旧对 REST API 功能做了保留和支持[11]。...社区中也依旧有许多方便可以调用 SDK 方案和资料参考。 让我们分别来聊聊这两种 API 方案使用方法和细节注意事项。...方案一:WP CLI 使用 WP CLI 官方网站[12] 中,我们能够得到 WP CLI 下载、安装方法。...WP CLI 安全加固 这个方案使用场景不论是 “管理员 WP 安装环境敲命令行” 或者 “远程控制软件执行服务器命令”,都需要 “WordPress 安装环境” 正确安装和配置了 “WP CLI

    11410

    初始Streams Replication Manager

    Cloudera SRM服务 Cloudera SRM服务由REST API和Kafka Streams应用程序组成,以聚合和显示集群、主题和消费者组指标。...SRM随附自定义扩展收集并聚合Kafka复制指标,并通过REST API使它们可用。Streams Messaging Manager(SMM)使用此REST API来显示指标。...客户还可以使用REST API实施自己监视解决方案,或将其插入第三方解决方案。这些指标使集群复制状态对最终用户可见,然后最终用户可以根据需要采取纠正措施。...复制流程概述 熟悉复制和复制流程概念。 复制涉及将记录从源集群发送到目标集群。SRM中,复制涉及到源和目标集群对、数据流向和要复制主题。可以SRM配置文件中指定源目标集群对。...您可以构造扇入复制流,其中将来自多个源集群记录聚合到单个目标集群中。 图1.扇入复制流程 ? 同样,您也可以构造扇出复制流,其中将单个集群复制到多个目标集群。 图2.扇出复制流程 ?

    1.3K10

    把 WordPress 变成 BaaS 服务:API 调用指南

    可惜是, 2022 年,有一个社区用户向官方提问这个项目是否还在维护,得到答复是否定项目不再积极维护,不过官方说社区用户依旧可以提交 PR 来做一些细微改进。...让我们分别来聊聊这两种 API 方案使用方法和细节注意事项。方案一:WP CLI 使用在 WP CLI 官方网站 中,我们能够得到 WP CLI 下载、安装方法。...核心文件 wp-includes/functions.php 中,我们能够看到新增函数 wp_is_serving_rest_request:function wp_is_serving_rest_request...WP CLI 安全加固这个方案使用场景不论是 “管理员 WP 安装环境敲命令行” 或者 “远程控制软件执行服务器命令”,都需要 “WordPress 安装环境” 正确安装和配置了 “WP CLI”...调用过程中,做好身份鉴权,这里可以借助一些其他插件,比如 plugins/wp-rest-api-authentication/等。

    13810
    领券