Perhaps you’ll remember me as the dingbat who forgot to save the plugin settings before, lol. I swear, this time I checked everything, so here it goes.
I ran into a small snag with the plugin. In the health check I get 2 critical issues dealing with an active PHP session and how it conflicts with the REST API. I don’t have many plugins installed on my site so it was not difficult to pin it down to this one.
At lines 58 and 107, ip2location-variables.php calls session_start()
. After doing some searching, I found that apparently WP doesn’t like sessions being started like this anymore(?)
I managed to “correct the problem” by editing the “offending code” from
if ( !session_id() ) {
session_start();
}
to
if ( !isset( $_SESSION ) {
session_start( [ 'read_and_close' => true ] );
}
Again, BOTH session_start calls had to be changed at lines 58 and 107; I suspect adding the argument to session_start()
is the only thing that is really needed, as I am sure !session_id()
and !isset($_SESSION)
accomplish the same thing.
I just updated the plugin today, when I noticed the critical issues in the Site Health screen. Both WP and the plugin are up to date.
I hope I helped and not broke the plugin or wasted your time with something this silly.
Thanks again for a great (free) plugin.
]]>The REST API request failed due to an error.
Error: cURL error 28: Operation timed out after 10001 milliseconds with 0 bytes received (http_request_failed)
]]>A PHP session was created by a session_start() function call. This interferes with REST API and loopback requests. The session should be closed by session_write_close() before making any HTTP requests.
Is it possible to use sessions with PHP 7.4 or 8.0 without downgrading the php version?
Thanks.
]]>-The header Cache-Control is returning “no-cache”, which means visitors will never get cached pages.
-The header Pragma is set to to “no-cache” which means visitors will never get cached content.
-A plugin or theme is setting a PHP session cookie on every pageload, which prevents caching.
I didn’t see anything in the settings that I could change. Any insight?
thanks!
]]>I am sure, there is much better way, to edit sessions, than I did.
Anyway, I am not able to make it work.
I need to setup session ID one time and left it there for 1year (expire time does not matter now – if 1day or 1year)
In future, when the code will work, there will be session created only after user complete the form.
The code bellow is typed into theme (DIVI) in functions.php
and to the site I call this code via shortcodes [edit_sessions] and [locked_fce].
That is working fine – what is not working fine, I can not see the session in Cookies in browser (I do not much care about this), but also the “coockie_lifetime” is not working for me. And it means, that when I closed browser …
now its working well because I have $_SESSION['veryS3cr3tK3Ywh1chNeverW1LLbeF0UND'] = "S0M3_D4T4_1_N33D_L4T3R";
without any condition
function edit_session_id_when_user_sent_data() {
add_action('init', 'myStartSession', 1);
add_action('wp_logout', 'myEndSession');
add_action('wp_login', 'myEndSession');
function myStartSession() {
if(!session_id()) {
session_start(['cookie_lifetime' => 876986798,]);
}
}
function myEndSession() {
session_destroy ();
}
$_SESSION['veryS3cr3tK3Ywh1chNeverW1LLbeF0UND'] = "S0M3_D4T4_1_N33D_L4T3R";
}
add_shortcode('edit_session', 'edit_session_id_when_user_sent_data');
function lock_until_login() {
if(isset($_SESSION['veryS3cr3tK3Ywh1chNeverW1LLbeF0UND'])) {
return "
<p><b>YOU ARE ALLOWED TO BE HERE</b></p>
<p><i>Your session id is FINE </i></p>
“;
}
}
add_shortcode(‘locked_fce’, ‘lock_until_login’);`
]]>I know you mentioned previously that you started using sessions in your php. The latest WordPress no longer supports it and my site is registering the critical error of the REST-API not talking to cURL, etc. We have taken our store offline and was hoping you were going to address this at some point through the code to alleviate this issue. Your plugin is the only one generating this issue on a site with many plugins. Thank you.
Howard Rosen
]]>we are currently using this plugin for handling session information.
We would like to embed our page to an externa domain via iframe. However, if we do so we loose the session functionality, as no cookie can be placed via external iframe.
Is there any suggestion on how this could be solved? Or, how would you tackle finding a solution?
Thanks for your help!
Alvaro
]]>Due to our website running over multiple servers, and needing sessions, we made the decision to override PHP’s default session behavior using session_set_save_handler()
and using mysql instead. It works fine with my own test database and such… Now I want to add it to WordPress. How can I achieve the equivalent to a table consisting of ID(contains the session id), access date and Data(contains all the session key-value pairs in the session)?
Should I add my own table, or does WordPress have something built in that works just as well?
]]>Any idea why session vars do not stick from page to page?
https://www.ads-software.com/plugins/wp-native-php-sessions/
]]>I have, like many others, a problem with this plugin to make it work with WPEngine. I’ve been opening a ticket for this and they told me that WPEngine does not support PHP sessions for their infrastructure. I’m suspecting this would apply also for other WordPress-only optimised hosts which are becoming increasingly popular.
Unfortunately, this plugin relies on PHP sessions (stored on the server) rather than cookies (stored on the user’s machine).
However, other “social logins” plugins do work on WPEngine (although they have other quirks or are just simply not as good), and I think it could be perfectly possible to make social connects work without the need of PHP sessions.
Would it be very hard to replace sessions by cookies? From an optimization point of view is also good approach to use server resources (if you have a really busy website where many people connect with social logins this could mean having many sessions used at the same time just for that).
Do you have other ideas? Has someone found a workaround?
Thank you!
https://www.ads-software.com/plugins/wordpress-social-login/
]]>