{"id":8080,"date":"2016-05-27T09:05:08","date_gmt":"2016-05-27T07:05:08","guid":{"rendered":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/"},"modified":"2016-05-27T09:05:08","modified_gmt":"2016-05-27T07:05:08","slug":"pki-ssl-certificates-management-with-java-keytool-and-openssl","status":"publish","type":"post","link":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/","title":{"rendered":"PKI &#8211; SSL certificates management with Java keytool and OpenSSL"},"content":{"rendered":"<p><a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java.jpg\"><img loading=\"lazy\" decoding=\"async\" class=\" size-full wp-image-8871 aligncenter\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java.jpg\" alt=\"java\" width=\"258\" height=\"195\" \/><\/a><\/p>\n<p>In this blog, we will cover all steps to enable SSL encryption for a particular server. The procedure described here applies mostly for Java based servers and applications, with usage of a <strong>keystore<\/strong>.<\/p>\n<p>In the case the organization into which the certificate has to be deployed has its own PKI, usage of OpenSSL is not necessary. In this case Java <strong>keytool<\/strong> usage will be enough.<\/p>\n<p>In the case you have to sign by yourself, server certificate with the Root CA key, and\/or create your own Root certificate, then usage of OpenSSL is mandatory.<\/p>\n<p>In real case, most of the times, servers have to be reachable from at least 2 DNS names. For instance, its short host name, and its FQND. The developed scenario will cover this situation as well.<\/p>\n<p>Refer to &#8220;<strong>subjectAltName<\/strong>&#8221; certificate attribute documentation for more information.<\/p>\n<p>It is recommended to use <strong>keytool<\/strong> application binary of the Java Runtime Environment used for the application execution. It is located under bin folder.<\/p>\n<p>Consider \u201c<strong>hostname<\/strong>\u201d and \u201c<strong>hostname.fqdn.com<\/strong>\u201d as DNS aliases of the server.<\/p>\n<p>Consider <strong>changing passwords<\/strong> (*****) and values of \u201c<strong>CN<\/strong>\u201d, \u201c<strong>OU<\/strong>\u201d, \u201c<strong>O<\/strong>\u201d, \u201c<strong>L<\/strong>\u201d, \u201c<strong>S<\/strong>\u201d, and \u201c<strong>C<\/strong>\u201d certificate attributes for both CA and server certificates.<\/p>\n<p>Refer to <strong>keytool<\/strong> documentation for more information.<\/p>\n<p>&nbsp;<\/p>\n<p><strong>1 &#8211; Create keystore and certificate<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"text-align: left;\">keytool -genkeypair -keystore keystore.jks -dname &#8220;CN=<strong>hostname.fqdn.com<\/strong>, OU=<strong>IT<\/strong>, O=<strong>Company<\/strong>, L=<strong>City<\/strong>, S=<strong>Country<\/strong>, C=<strong>CountryAcronym<\/strong>&#8221; -keypass\u00a0<strong>*****<\/strong> -storepass <strong>*****<\/strong> -keyalg RSA -alias server -validity 731 -ext SAN=dns:<strong>hostname<\/strong>,dns:<strong>hostname.fqdn.com<\/strong>\u00a0 -ext KU=digitalSignature,keyEncipherment -ext EKU=serverAuth<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><strong>\u00a0<\/strong><\/p>\n<p><strong>2 &#8211; Create a certificate request for signature to the certification authority<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td style=\"text-align: left;\">keytool -certreq -keystore keystore.jks -keypass <strong>*****<\/strong> -storepass <strong>*****<\/strong> -alias server -file<strong> hostname<\/strong>.csr<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3 -Server certificate signature<\/strong><\/p>\n<p>In the case your organization has its own PKI, just send the CSR and wait for the signed server certificate.<\/p>\n<p>In the case you want to manage or create a new PKI, go to 3-1 section for Root CA certificate creation, and\/or server certificate signature with OpenSSL.<\/p>\n<p>&nbsp;<\/p>\n<p><strong>4 &#8211; Import provided Root CA and signed certificate of the server from certification authority<\/strong><\/p>\n<p>&#8211;\u00a0\u00a0 Import of root CA:<\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">keytool -import -alias cert1 -file root.pem -keystore keystore.jks -storepass <strong>*****<\/strong><\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>-&gt;&gt; trust the certificate when prompted<\/p>\n<p>&#8211;\u00a0\u00a0 Eventually import other mid-certificate in the chain (repeat and change alias for all intermediate certificates in the chain)<\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">keytool -import -alias cert2 -file sub.pem -keystore keystore.jks -storepass <strong>*****<\/strong><\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&#8211;\u00a0\u00a0 Finally import signed certificate<\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">keytool -import -trustcacerts -alias server -file <strong>hostname<\/strong>.cer -keystore keystore.jks -storepass <strong>*****<\/strong><\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p>*******************************************************<\/p>\n<p>Create Root CA and sign server certificate with OpenSSL<\/p>\n<p><strong>3-1 &#8211; Generate key for Root CA<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">openssl genpkey -algorithm RSA -out rootkey.pem -pkeyopt rsa_keygen_bits:4096<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3-2 &#8211; Generate certificate CSR for Root CA self-signing<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">openssl req -new -key rootkey.pem -days 5480 -extensions v3_ca -batch -out root.csr -utf8 -subj &#8216;\/C=<strong>CountryAcronym<\/strong>\/O=<strong>Company Root CA<\/strong>\/OU=<strong>IT<\/strong>\/CN=<strong>Company Root CA<\/strong>&#8216;<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3-3 &#8211; Create an extension file (openssl.root.cnf) with following content<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">basicConstraints = critical, CA:TRUE<\/p>\n<p style=\"text-align: left;\">keyUsage = keyCertSign, cRLSign<\/p>\n<p style=\"text-align: left;\">subjectKeyIdentifier = hash<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3-4 &#8211; Self sign Root CA certificate and append extensions<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">openssl x509 -req -sha256 -days 3650 -in root.csr -signkey rootkey.pem -set_serial 1 -extfile openssl.root.cnf -out root.pem<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3-5 &#8211; Sign server certificate request with Root key<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td>\n<p style=\"text-align: left;\">openssl\u00a0 x509\u00a0 -req\u00a0 -CA root.pem -CAkey rootkey.pem -in <strong>hostname<\/strong>.csr -out <strong>hostname<\/strong>.cer -days 731\u00a0 -CAcreateserial<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&nbsp;<\/p>\n<p><strong>3-6 \u2013Trust Root CA certificate<\/strong><\/p>\n<p>Eventually import \u201c<strong>root.pem<\/strong>\u201d Root CA certificate to you browser\u2019s CA and\/or into your Java Runtime Environment lists.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>In this blog, we will cover all steps to enable SSL encryption for a particular server. The procedure described here applies mostly for Java based servers and applications, with usage of a keystore. In the case the organization into which the certificate has to be deployed has its own PKI, usage of OpenSSL is not [&hellip;]<\/p>\n","protected":false},"author":40,"featured_media":8082,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[197,368],"tags":[840],"type_dbi":[],"class_list":["post-8080","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-application-integration-middleware","category-development-performance","tag-ssl-signature-java-keytool-openssl-certificate-pki-subjectaltname-subject-alt-name"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v27.2 (Yoast SEO v27.2) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>PKI - SSL certificates management with Java keytool and OpenSSL - dbi Blog<\/title>\n<meta name=\"description\" content=\"PKI management with Java keytool and OpenSSL including subject alternative names\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"PKI - SSL certificates management with Java keytool and OpenSSL\" \/>\n<meta property=\"og:description\" content=\"PKI management with Java keytool and OpenSSL including subject alternative names\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\" \/>\n<meta property=\"og:site_name\" content=\"dbi Blog\" \/>\n<meta property=\"article:published_time\" content=\"2016-05-27T07:05:08+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"258\" \/>\n\t<meta property=\"og:image:height\" content=\"195\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Middleware Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Middleware Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\"},\"author\":{\"name\":\"Middleware Team\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1\"},\"headline\":\"PKI &#8211; SSL certificates management with Java keytool and OpenSSL\",\"datePublished\":\"2016-05-27T07:05:08+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\"},\"wordCount\":593,\"commentCount\":0,\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg\",\"keywords\":[\"SSL signature Java keytool openssl certificate PKI subjectAltName subject Alt Name\"],\"articleSection\":[\"Application integration &amp; Middleware\",\"Development &amp; Performance\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\",\"name\":\"PKI - SSL certificates management with Java keytool and OpenSSL - dbi Blog\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg\",\"datePublished\":\"2016-05-27T07:05:08+00:00\",\"author\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1\"},\"description\":\"PKI management with Java keytool and OpenSSL including subject alternative names\",\"breadcrumb\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg\",\"contentUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg\",\"width\":258,\"height\":195},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"https:\/\/www.dbi-services.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"PKI &#8211; SSL certificates management with Java keytool and OpenSSL\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/\",\"name\":\"dbi Blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1\",\"name\":\"Middleware Team\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g\",\"caption\":\"Middleware Team\"},\"url\":\"https:\/\/www.dbi-services.com\/blog\/author\/middleware-team\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"PKI - SSL certificates management with Java keytool and OpenSSL - dbi Blog","description":"PKI management with Java keytool and OpenSSL including subject alternative names","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:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/","og_locale":"en_US","og_type":"article","og_title":"PKI - SSL certificates management with Java keytool and OpenSSL","og_description":"PKI management with Java keytool and OpenSSL including subject alternative names","og_url":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/","og_site_name":"dbi Blog","article_published_time":"2016-05-27T07:05:08+00:00","og_image":[{"width":258,"height":195,"url":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg","type":"image\/jpeg"}],"author":"Middleware Team","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Middleware Team","Est. reading time":"3 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#article","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/"},"author":{"name":"Middleware Team","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1"},"headline":"PKI &#8211; SSL certificates management with Java keytool and OpenSSL","datePublished":"2016-05-27T07:05:08+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/"},"wordCount":593,"commentCount":0,"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg","keywords":["SSL signature Java keytool openssl certificate PKI subjectAltName subject Alt Name"],"articleSection":["Application integration &amp; Middleware","Development &amp; Performance"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/","url":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/","name":"PKI - SSL certificates management with Java keytool and OpenSSL - dbi Blog","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage"},"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg","datePublished":"2016-05-27T07:05:08+00:00","author":{"@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1"},"description":"PKI management with Java keytool and OpenSSL including subject alternative names","breadcrumb":{"@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#primaryimage","url":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg","contentUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/java-1.jpg","width":258,"height":195},{"@type":"BreadcrumbList","@id":"https:\/\/www.dbi-services.com\/blog\/pki-ssl-certificates-management-with-java-keytool-and-openssl\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"https:\/\/www.dbi-services.com\/blog\/"},{"@type":"ListItem","position":2,"name":"PKI &#8211; SSL certificates management with Java keytool and OpenSSL"}]},{"@type":"WebSite","@id":"https:\/\/www.dbi-services.com\/blog\/#website","url":"https:\/\/www.dbi-services.com\/blog\/","name":"dbi Blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/8d8563acfc6e604cce6507f45bac0ea1","name":"Middleware Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/ddcae7ba0f9d1a0e7ae707f0e689e4a9c95bb48ec49c8e6d9cc86d43f4121cb6?s=96&d=mm&r=g","caption":"Middleware Team"},"url":"https:\/\/www.dbi-services.com\/blog\/author\/middleware-team\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/8080","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/users\/40"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/comments?post=8080"}],"version-history":[{"count":0,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/8080\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media\/8082"}],"wp:attachment":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media?parent=8080"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/categories?post=8080"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/tags?post=8080"},{"taxonomy":"type","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/type_dbi?post=8080"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}