{"id":143,"date":"2022-05-09T12:51:35","date_gmt":"2022-05-09T07:21:35","guid":{"rendered":"https:\/\/magecurious.com\/blog\/?p=143"},"modified":"2022-07-11T10:28:43","modified_gmt":"2022-07-11T04:58:43","slug":"magento-2-create-custom-rest-api","status":"publish","type":"post","link":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/","title":{"rendered":"Magento 2 Create Custom Rest API"},"content":{"rendered":"\n<p>Hello Guys! \ud83d\udc4b<\/p>\n\n\n\n<p>In this blog, we learn how to create custom rest API calls.<\/p>\n\n\n\n<p>The REST API is a set of functions that call from request and response using the HTTP response.<\/p>\n\n\n\n<p>Magento 2 has a much-predefined REST API but in custom development, we need to create a custom REST API in our system.<\/p>\n\n\n\n<p>So this blog helps you create a custom REST API.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>STEP 1: Add <strong>webapi.xml<\/strong> in following path.\n<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>app\\code\\Vendor\\Extension\\etc<\/code><\/pre>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: xml; title: ; notranslate\" title=\"\">\n&lt;?xml version=&quot;1.0&quot;?&gt;\n&lt;routes xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot; xsi:noNamespaceSchemaLocation=&quot;..\/..\/..\/..\/..\/app\/code\/Magento\/Webapi\/etc\/webapi.xsd&quot;&gt;\n    &lt;route method=&quot;POST&quot; url=&quot;\/V1\/custom\/customapi\/&quot;&gt;\n        &lt;service class=&quot;Vendor\\Extension\\Api\\CustomapiInterface&quot; method=&quot;getData&quot;\/&gt;\n        &lt;resources&gt;\n            &lt;resource ref=&quot;anonymous&quot;\/&gt;\n        &lt;\/resources&gt;\n    &lt;\/route&gt;\n&lt;\/routes&gt;\n\n<\/pre><\/div>\n\n\n<pre class=\"wp-block-code\"><code>STEP 2: Add <strong>CustomapiInterface.php<\/strong> in following path<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>app\\code\\Vendor\\Extension\\Api\n<\/code><\/pre>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\nnamespace Vendor\\Extension\\Api;\n\ninterface CustomapiInterface\n{\n    \/**\n     * GET for Post api\n     * @param string $data\n     * @return string\n     *\/\n    public function getData($data);\n}\n\n<\/pre><\/div>\n\n\n<pre class=\"wp-block-code\"><code>STEP 3: Add <strong>di.xml<\/strong> in following path\n<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>app\\code\\Vendor\\Extension\\etc<\/code><\/pre>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: xml; title: ; notranslate\" title=\"\">\n&lt;?xml version=&quot;1.0&quot;?&gt;\n&lt;config xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot; xsi:noNamespaceSchemaLocation=&quot;urn:magento:framework:ObjectManager\/etc\/config.xsd&quot;&gt;\n    &lt;preference for=&quot;Vendor\\Extension\\Api\\CustomapiInterface&quot; type=&quot;Vendor\\Extension\\Model\\Api\\Customapi&quot;\/&gt;\n&lt;\/config&gt;\n\n<\/pre><\/div>\n\n\n<pre class=\"wp-block-code\"><code>STEP 4: Now add <strong>Customapi.php<\/strong> in following path<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>app\\code\\Vendor\\Extension\\Model\\Api<\/code><\/pre>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\nnamespace Vendor\\Extension\\Model\\Api;\n\nclass Customapi\n{\n    protected $json;\n\n    public function __construct(\n        \\Magento\\Framework\\Serialize\\Serializer\\Json $json\n    ) {\n        $this-&gt;json = $json;\n    }\n\n    \/**\n     * @inheritdoc\n     *\/\n    public function getData($data)\n    {\n        $response = &#x5B;&#039;success&#039; =&gt; false];\n        try {\n            \/\/ your custom code\n            $response = &#x5B;&#039;success&#039; =&gt; true, &#039;message&#039; =&gt; $data];\n        } catch (\\Exception $e) {\n            $response = &#x5B;&#039;success&#039; =&gt; false, &#039;message&#039; =&gt; $e-&gt;getMessage()];\n        }\n        $returnArray = $this-&gt;json-&gt;serialize($response);\n        return $returnArray;\n    }\n}\n<\/pre><\/div>\n\n\n<div style=\"height:17px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>Hope! It will help you<\/p>\n\n\n\n<p>Thank you \ud83d\ude0a<\/p>\n\n\n\n<div style=\"height:15px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n<!-- FeedbackWP Plugin --><div  class=\"rmp-widgets-container rmp-wp-plugin rmp-main-container js-rmp-widgets-container js-rmp-widgets-container--143 \"  data-post-id=\"143\">    <!-- Rating widget -->  <div class=\"rmp-rating-widget js-rmp-rating-widget\">          <p class=\"rmp-heading rmp-heading--title\">        How useful was this post?      <\/p>              <p class=\"rmp-heading rmp-heading--subtitle\">        Click on a star to rate it!      <\/p>        <div class=\"rmp-rating-widget__icons\">      <ul class=\"rmp-rating-widget__icons-list js-rmp-rating-icons-list\">                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Not at all useful\" data-value=\"1\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Somewhat useful\" data-value=\"2\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Useful\" data-value=\"3\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Fairly useful\" data-value=\"4\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Very useful\" data-value=\"5\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>              <\/ul>    <\/div>    <p class=\"rmp-rating-widget__hover-text js-rmp-hover-text\"><\/p>        <button class=\"rmp-rating-widget__submit-btn rmp-btn js-submit-rating-btn\">      Submit Rating    <\/button>    <p class=\"rmp-rating-widget__results js-rmp-results \">      Average rating <span class=\"rmp-rating-widget__results__rating js-rmp-avg-rating\">4.8<\/span> \/ 5. Vote count: <span class=\"rmp-rating-widget__results__votes js-rmp-vote-count\">18<\/span>    <\/p>    <p class=\"rmp-rating-widget__not-rated js-rmp-not-rated rmp-rating-widget__not-rated--hidden\">      No votes so far! Be the first to rate this post.    <\/p>    <p class=\"rmp-rating-widget__msg js-rmp-msg\"><\/p>  <\/div>  <!--Structured data -->        <\/div>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Hello Guys! \ud83d\udc4b In this blog, we learn how to create custom rest API calls. The REST API is a set of functions that call from request and response using the HTTP response. Magento 2 has a much-predefined REST API but in custom development, we need to create a custom REST API in our system. [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":185,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[4],"tags":[24,17,25],"class_list":["post-143","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-magento-2","tag-api","tag-magento-2-2","tag-rest-api"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Magento 2 Create Custom Rest API - Magecurious<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Magento 2 Create Custom Rest API - Magecurious\" \/>\n<meta property=\"og:description\" content=\"Hello Guys! \ud83d\udc4b In this blog, we learn how to create custom rest API calls. The REST API is a set of functions that call from request and response using the HTTP response. Magento 2 has a much-predefined REST API but in custom development, we need to create a custom REST API in our system. [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/\" \/>\n<meta property=\"og:site_name\" content=\"Magecurious\" \/>\n<meta property=\"article:published_time\" content=\"2022-05-09T07:21:35+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-07-11T04:58:43+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1260\" \/>\n\t<meta property=\"og:image:height\" content=\"496\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Magecurious\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Magecurious\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Magento 2 Create Custom Rest API - Magecurious","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/","og_locale":"en_US","og_type":"article","og_title":"Magento 2 Create Custom Rest API - Magecurious","og_description":"Hello Guys! \ud83d\udc4b In this blog, we learn how to create custom rest API calls. The REST API is a set of functions that call from request and response using the HTTP response. Magento 2 has a much-predefined REST API but in custom development, we need to create a custom REST API in our system. [&hellip;]","og_url":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/","og_site_name":"Magecurious","article_published_time":"2022-05-09T07:21:35+00:00","article_modified_time":"2022-07-11T04:58:43+00:00","og_image":[{"width":1260,"height":496,"url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","type":"image\/png"}],"author":"Magecurious","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Magecurious","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#article","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/"},"author":{"name":"Magecurious","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2"},"headline":"Magento 2 Create Custom Rest API","datePublished":"2022-05-09T07:21:35+00:00","dateModified":"2022-07-11T04:58:43+00:00","mainEntityOfPage":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/"},"wordCount":76,"commentCount":0,"publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"image":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","keywords":["API","Magento 2","REST-API"],"articleSection":["Magento 2 Blog"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/","url":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/","name":"Magento 2 Create Custom Rest API - Magecurious","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#primaryimage"},"image":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","datePublished":"2022-05-09T07:21:35+00:00","dateModified":"2022-07-11T04:58:43+00:00","breadcrumb":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#primaryimage","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","width":1260,"height":496,"caption":"Featured Image"},{"@type":"BreadcrumbList","@id":"https:\/\/magecurious.com\/blog\/magento-2-create-custom-rest-api\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/magecurious.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Magento 2 Create Custom Rest API"}]},{"@type":"WebSite","@id":"https:\/\/magecurious.com\/blog\/#website","url":"https:\/\/magecurious.com\/blog\/","name":"Magecurious","description":"Blog","publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/magecurious.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/magecurious.com\/blog\/#organization","name":"Magecurious","url":"https:\/\/magecurious.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","width":596,"height":113,"caption":"Magecurious"},"image":{"@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2","name":"Magecurious","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","caption":"Magecurious"},"sameAs":["https:\/\/magecurious.com"],"url":"https:\/\/magecurious.com\/blog\/author\/magecurious-wp\/"}]}},"jetpack_featured_media_url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/05\/Custom-API.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/143","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/comments?post=143"}],"version-history":[{"count":0,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/143\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media\/185"}],"wp:attachment":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media?parent=143"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/categories?post=143"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/tags?post=143"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}