{"id":911,"date":"2012-09-17T07:35:43","date_gmt":"2012-09-17T07:35:43","guid":{"rendered":"http:\/\/www.websitedesignwebsitedevelopment.com\/?p=911"},"modified":"2014-03-19T09:13:46","modified_gmt":"2014-03-19T09:13:46","slug":"cross-site-request-forgery-csrf-updated","status":"publish","type":"post","link":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/","title":{"rendered":"Cross-site request forgery (CSRF) Updated"},"content":{"rendered":"<h2>Cross-site request forgery (CSRF) Updated<\/h2>\n<p><code>public function csrf_verify()<br \/>\n{<br \/>\n\/\/ If no POST data exists we will set the CSRF cookie<br \/>\nif (count($_POST) == 0)<br \/>\n{<br \/>\nreturn $this-&gt;csrf_set_cookie();<br \/>\n}<br \/>\nif((isset($_SERVER['HTTP_X_REQUESTED_WITH']) &amp;&amp; $_SERVER['HTTP_X_REQUESTED_WITH'] == \"XMLHttpRequest\") || isset($_SERVER['HTTP_REFERER']))<br \/>\n{<br \/>\nif(isset($_SERVER['HTTP_REFERER']))<br \/>\n{<br \/>\n$parse_url = parse_url($_SERVER['HTTP_REFERER']);<br \/>\nif($parse_url['host']!=$_SERVER['HTTP_HOST'] &amp;&amp; !in_array($parse_url['host'], array('apps.facebook.com')))<br \/>\n{<br \/>\n$this-&gt;csrf_show_error();<br \/>\n}<br \/>\nelse<br \/>\n{<br \/>\n\/\/echo 'Safe';<br \/>\n\/\/echo 'Host From: '.$parse_url['host'].'Host To: '.$_SERVER['HTTP_HOST'];<br \/>\n}<br \/>\n\/\/pre($parse_url);exit;<br \/>\n}<br \/>\n}<br \/>\nelse<br \/>\n{<br \/>\n\/\/ Do the tokens exist in both the _POST and _COOKIE arrays?<br \/>\nif(isset($_SERVER['HTTP_REFERER']))<br \/>\n{<br \/>\n$parse_url = parse_url($_SERVER['HTTP_REFERER']);<br \/>\nif($parse_url['host']!=$_SERVER['HTTP_HOST'] &amp;&amp; !in_array($parse_url['host'], array('apps.facebook.com')))<br \/>\n{<br \/>\nif ( ! isset($_POST[$this-&gt;_csrf_token_name]) &amp;&amp;<br \/>\n! isset($_COOKIE[$this-&gt;_csrf_cookie_name]))<br \/>\n{<br \/>\n$this-&gt;csrf_show_error();<br \/>\n}<br \/>\n\/\/ Do the tokens match?<br \/>\nif (<br \/>\n(<br \/>\nisset($_POST[$this-&gt;_csrf_token_name])<br \/>\n&amp;&amp;<br \/>\nisset($_COOKIE[$this-&gt;_csrf_cookie_name])<br \/>\n)<br \/>\n&amp;&amp;<br \/>\n$_POST[$this-&gt;_csrf_token_name] != $_COOKIE[$this-&gt;_csrf_cookie_name])<br \/>\n{<br \/>\n$this-&gt;csrf_show_error();<br \/>\n}<br \/>\n}<br \/>\n}<br \/>\n\/\/ We kill this since we're done and we don't want to<br \/>\n\/\/ polute the _POST array<br \/>\nunset($_POST[$this-&gt;_csrf_token_name]);<br \/>\n\/\/ Nothing should last forever<br \/>\nunset($_COOKIE[$this-&gt;_csrf_cookie_name]);<br \/>\n$this-&gt;_csrf_set_hash();<br \/>\n$this-&gt;csrf_set_cookie();<br \/>\nlog_message('debug', \"CSRF token verified \");<br \/>\nreturn $this;<br \/>\n}<br \/>\n}<br \/>\n<\/code><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Cross-site request forgery (CSRF) Updated public function csrf_verify() { \/\/ If no POST data exists we will set the CSRF cookie if (count($_POST) == 0) { return $this-&gt;csrf_set_cookie(); } if((isset($_SERVER[&#8216;HTTP_X_REQUESTED_WITH&#8217;]) &amp;&amp; $_SERVER[&#8216;HTTP_X_REQUESTED_WITH&#8217;] == &#8220;XMLHttpRequest&#8221;) || isset($_SERVER[&#8216;HTTP_REFERER&#8217;])) { if(isset($_SERVER[&#8216;HTTP_REFERER&#8217;])) { $parse_url = parse_url($_SERVER[&#8216;HTTP_REFERER&#8217;]); if($parse_url[&#8216;host&#8217;]!=$_SERVER[&#8216;HTTP_HOST&#8217;] &amp;&amp; !in_array($parse_url[&#8216;host&#8217;], array(&#8216;apps.facebook.com&#8217;))) { $this-&gt;csrf_show_error(); } else { \/\/echo &#8216;Safe&#8217;; \/\/echo &#8216;Host [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[34],"tags":[],"class_list":["post-911","post","type-post","status-publish","format-standard","hentry","category-codeigniter"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.9 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Cross-site request forgery (CSRF) Updated<\/title>\n<meta name=\"description\" content=\"Cross-site request forgery (CSRF) Updated\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Cross-site request forgery (CSRF) Updated\" \/>\n<meta property=\"og:description\" content=\"Cross-site request forgery (CSRF) Updated\" \/>\n<meta property=\"og:url\" content=\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\" \/>\n<meta property=\"og:site_name\" content=\"AndroidBubble Blog\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/pages\/Website-Design-Website-Development\/172363336135453\" \/>\n<meta property=\"article:published_time\" content=\"2012-09-17T07:35:43+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2014-03-19T09:13:46+00:00\" \/>\n<meta name=\"author\" content=\"Fahad\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Fahad\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\"},\"author\":{\"name\":\"Fahad\",\"@id\":\"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7\"},\"headline\":\"Cross-site request forgery (CSRF) Updated\",\"datePublished\":\"2012-09-17T07:35:43+00:00\",\"dateModified\":\"2014-03-19T09:13:46+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\"},\"wordCount\":10,\"articleSection\":[\"CodeIgniter\"],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\",\"url\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\",\"name\":\"Cross-site request forgery (CSRF) Updated\",\"isPartOf\":{\"@id\":\"https:\/\/androidbubble.com\/blog\/#website\"},\"datePublished\":\"2012-09-17T07:35:43+00:00\",\"dateModified\":\"2014-03-19T09:13:46+00:00\",\"author\":{\"@id\":\"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7\"},\"description\":\"Cross-site request forgery (CSRF) Updated\",\"breadcrumb\":{\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/androidbubble.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Website Development\",\"item\":\"https:\/\/androidbubble.com\/blog\/category\/website-development\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"PHP Frameworks\",\"item\":\"https:\/\/androidbubble.com\/blog\/category\/website-development\/php-frameworks\/\"},{\"@type\":\"ListItem\",\"position\":4,\"name\":\"CodeIgniter\",\"item\":\"https:\/\/androidbubble.com\/blog\/category\/website-development\/php-frameworks\/codeigniter\/\"},{\"@type\":\"ListItem\",\"position\":5,\"name\":\"Cross-site request forgery (CSRF) Updated\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/androidbubble.com\/blog\/#website\",\"url\":\"https:\/\/androidbubble.com\/blog\/\",\"name\":\"AndroidBubble Blog\",\"description\":\"Articles &amp; Posts\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/androidbubble.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7\",\"name\":\"Fahad\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/afab5bcad71955d142a69df1758e6710aed4ab9cc2b5da28c54a7c3f39801b73?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/afab5bcad71955d142a69df1758e6710aed4ab9cc2b5da28c54a7c3f39801b73?s=96&d=mm&r=g\",\"caption\":\"Fahad\"},\"sameAs\":[\"http:\/\/www.androidbubbles.com\/\",\"https:\/\/x.com\/phpFlex\"],\"url\":\"https:\/\/androidbubble.com\/blog\/author\/admin\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Cross-site request forgery (CSRF) Updated","description":"Cross-site request forgery (CSRF) Updated","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:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/","og_locale":"en_US","og_type":"article","og_title":"Cross-site request forgery (CSRF) Updated","og_description":"Cross-site request forgery (CSRF) Updated","og_url":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/","og_site_name":"AndroidBubble Blog","article_publisher":"https:\/\/www.facebook.com\/pages\/Website-Design-Website-Development\/172363336135453","article_published_time":"2012-09-17T07:35:43+00:00","article_modified_time":"2014-03-19T09:13:46+00:00","author":"Fahad","twitter_misc":{"Written by":"Fahad","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#article","isPartOf":{"@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/"},"author":{"name":"Fahad","@id":"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7"},"headline":"Cross-site request forgery (CSRF) Updated","datePublished":"2012-09-17T07:35:43+00:00","dateModified":"2014-03-19T09:13:46+00:00","mainEntityOfPage":{"@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/"},"wordCount":10,"articleSection":["CodeIgniter"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/","url":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/","name":"Cross-site request forgery (CSRF) Updated","isPartOf":{"@id":"https:\/\/androidbubble.com\/blog\/#website"},"datePublished":"2012-09-17T07:35:43+00:00","dateModified":"2014-03-19T09:13:46+00:00","author":{"@id":"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7"},"description":"Cross-site request forgery (CSRF) Updated","breadcrumb":{"@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/androidbubble.com\/blog\/website-development\/php-frameworks\/codeigniter\/cross-site-request-forgery-csrf-updated\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/androidbubble.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Website Development","item":"https:\/\/androidbubble.com\/blog\/category\/website-development\/"},{"@type":"ListItem","position":3,"name":"PHP Frameworks","item":"https:\/\/androidbubble.com\/blog\/category\/website-development\/php-frameworks\/"},{"@type":"ListItem","position":4,"name":"CodeIgniter","item":"https:\/\/androidbubble.com\/blog\/category\/website-development\/php-frameworks\/codeigniter\/"},{"@type":"ListItem","position":5,"name":"Cross-site request forgery (CSRF) Updated"}]},{"@type":"WebSite","@id":"https:\/\/androidbubble.com\/blog\/#website","url":"https:\/\/androidbubble.com\/blog\/","name":"AndroidBubble Blog","description":"Articles &amp; Posts","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/androidbubble.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/0a833b633f744c3a5e0de7c9a94e71f7","name":"Fahad","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/androidbubble.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/afab5bcad71955d142a69df1758e6710aed4ab9cc2b5da28c54a7c3f39801b73?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/afab5bcad71955d142a69df1758e6710aed4ab9cc2b5da28c54a7c3f39801b73?s=96&d=mm&r=g","caption":"Fahad"},"sameAs":["http:\/\/www.androidbubbles.com\/","https:\/\/x.com\/phpFlex"],"url":"https:\/\/androidbubble.com\/blog\/author\/admin\/"}]}},"views":684,"jetpack_featured_media_url":"","_links":{"self":[{"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/posts\/911","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/comments?post=911"}],"version-history":[{"count":12,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/posts\/911\/revisions"}],"predecessor-version":[{"id":1612,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/posts\/911\/revisions\/1612"}],"wp:attachment":[{"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/media?parent=911"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/categories?post=911"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/androidbubble.com\/blog\/wp-json\/wp\/v2\/tags?post=911"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}