Solved

PHP Session id is not changing

Posted on 2009-04-10
3
650 Views
Last Modified: 2013-12-14
I have one login page and when it ask for user id password ..after authentication i put here a validation of yes and no ..if you are authorized  than click yes or no ..but whenever i am clcking no the session id remain same ..which i dont want ..i need to change session id on pressing no.

Please help!

The default page opens is index.php.
Code pressing no
-------------------------
 
if ($_POST['button']=="NO" ) {
    $query="UPDATE `web_access_log`
            SET accept_conditions='0'
            WHERE ID={$_SESSION['DB_Key']}";
    $result= mysql_query($query)
            or die (mysql_error()."<br>\nSQL: $query");
    include ("logout.php");
 
Logout.php
----------------
 
if (!$db) $db = db_connect();
 
$query="UPDATE `web_access_log` 
        SET logout_time=NOW(),  session_timeout='0'
        WHERE ID={$_SESSION['DB_Key']}";
 
$result = mysql_query($query) 
          or die (mysql_error()."<br>\nSQL: $query");
 
unset($_SESSION['userid']);
unset($_SESSION['ip']);
unset($_SESSION['DB_Key']);
unset($_SESSION['accept']);
session_destroy();
header("Location: index.php");

Open in new window

0
Comment
Question by:prashantchauhan
3 Comments
 
LVL 3

Assisted Solution

by:Bivek-jos
Bivek-jos earned 100 total points
ID: 24114731
Hi
Have a look at:
http://www.php.net/session_regenerate_id
Hope this helps. :)

Thank you
0
 
LVL 9

Assisted Solution

by:LinuxNubb
LinuxNubb earned 100 total points
ID: 24116602
You could also try to set your session variables to nothing:

$_SESSION['userid'] = '';

0
 

Accepted Solution

by:
prashantchauhan earned 0 total points
ID: 24183160
I am already using session_regenrate but still the problem same..

Please check the code below,...and suggest any changes required.
session_destroy();
session_regenerate_id();
 
unset($_SESSION['userid']);
unset($_SESSION['ip']);
unset($_SESSION['DB_Key']);
unset($_SESSION['accept']);
 
 
function UpdateSessID() {
    $old_sess_id = session_id();
    session_regenerate_id(false);
    $new_sess_id = session_id();
 
    $query = "UPDATE `session_table` SET `session_id` = '$new_sess_id' WHERE session_id = '$old_sess_id'";
        mysql_query($query);
}
 
 
session_destroy();

Open in new window

0

Featured Post

Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Part of the Global Positioning System A geocode (https://developers.google.com/maps/documentation/geocoding/) is the major subset of a GPS coordinate (http://en.wikipedia.org/wiki/Global_Positioning_System), the other parts being the altitude and t…
Jaspersoft Studio is a plugin for Eclipse that lets you create reports from a datasource.  In this article, we'll go over creating a report from a default template and setting up a datasource that connects to your database.
The viewer will learn how to synchronize PHP projects with a remote server in NetBeans IDE 8.0 for Windows.
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question