Hi,
I am quite new to PHP and recently I have been attempting to create a login script, just one problem, the setcookie function isn't working.
I have tried a basic php file with nothing other than a function to set and retrieve the cookie but still nothing.
Why is this happening?
9 26142
hey ..
you make sure doing the right code for the sercookie -
examples:
-
-
-
setcookie("mycookie", $test, time() + 3600);
-
setcookie("mycookie","",time() - 3600);
-
-
setcookie('my_id', $_REQUEST['my_id'], time() + 60*60*24*365);
-
-
-
-
if still problem there plz mention..
Atli 5,058
Expert 4TB
Hi.
There are a lot of reasons why thins could be happening, and simply stating that the function isn't working doesn't really narrow the list down.
We need a lot more details to be able to help with this.
Code examples and error messages are always helpful to.
I have tried all examples mentioned by "prabirchoudhury" and none seem to work, everytime I try and retrieve the cookie, the page either comes up blank or displays Array ( ), depending upon the method I use to view them.
Unfortunately there are no error messages to provide an insight as to why this is happening.
P.S. I am using my own server which again I have only just begun to do, is there anything that I need to set in the PHP config file in order to get cookies to work?
Are you sure that you have cookies enabled in your browser?
Atli 5,058
Expert 4TB
Try this: - <?php
-
error_reporting(E_ALL);
-
ini_set("display_errors", true);
-
header("Content-Type: text/plain");
-
-
if(isset($_COOKIE['cookietest'])) {
-
var_dump($_COOKIE);
-
}
-
else {
-
$time = time();
-
setcookie("cookietest", $time, $time + 3600);
-
echo "Cookie set at: " . $time;
-
}
-
?>
When you first run it, it sets the cookie. Every request after that should show that cookie.
You shouldn't need to configure PHP in any way for this to work.
(I'm not even sure you can configure it to not support cookies :P)
If this doesn't work (if it keeps setting the cookie, rather than displaying it), then I'm guessing your browser doesn't support cookies.
Try using Firefox with the Web Developer plugin. It can show you all the cookies that are set on your browser, and if they are incorrectly set in some way.
I used the code you gave me and it seems to work, so I am now wondering, is the setcookie function the problem.
Here is my login script that I have tried to make, all of it works except for setting the cookie in any browser. -
<?php
-
$result = mysql_connect("*********", "******", "*********");
-
$result = mysql_select_db("test");
-
$user = $_POST["usr"];
-
$pass = $_POST["pss"];
-
$usr_stat = 0;
-
$pss_stat = 0;
-
$sql = "SELECT password FROM ".tbl_login." WHERE login = '$user';";
-
$result = mysql_query($sql);
-
$row_array = mysql_fetch_array($result);
-
$expire = time()+60*60*24*30;
-
-
if(!$result || (mysql_numrows($result) < 1)){
-
$usr_stat = 0;
-
}
-
else{
-
$usr_stat = 1;
-
}
-
if($pass == $row_array['password']){
-
$pss_stat = 1;
-
}
-
else{
-
$pss_stat = 0;
-
}
-
if($usr_stat == 1 && $pss_stat == 1){
-
setcookie ('curruser', $_POST['usr'], $expire);
-
header('Location: cktest2.php');
-
}
-
?>
-
<html>
-
<head>
-
<title>Studying PHP</title>
-
<link rel="stylesheet" href="css/main.css">
-
</head>
-
<body>
-
-
<h1>Login test</h1>
-
-
<form name="login" action="login.php" method="POST">
-
Username: <input type="text" value="" name="usr">
-
Password: <input type="password" value="" name="pss">
-
<input type="submit" value="Submit">
-
</form>
-
-
<?php
-
if(!$result || (mysql_numrows($result) < 1)){
-
echo "<p>Username invalid</p>";
-
}
-
else{
-
echo "<p>Username valid</p>";
-
}
-
if($pass == $row_array['password']){
-
echo "<p>Password valid</p>";
-
}
-
else{
-
echo "<p>Password invalid</p>";
-
}
-
if($usr_stat == 1 && $pss_stat == 1){
-
echo "<p>Login details valid</p>";
-
}
-
else{
-
echo "<p>Login details invalid</p>";
-
}
-
if(isset($_COOKIE['curruser'])){
-
echo "<p>Welcome ".$_COOKIE['curruser'].", you are now logged in using cookies.</p>";
-
}
-
else{
-
echo "<p>You are not logged in.</p>";
-
}
-
print_r($_COOKIE);
-
?>
-
-
</body>
-
</html>
-
Atli 5,058
Expert 4TB
In the SQL on line #8 you use a constant 'tbl_login', but you don't set it anywhere.
Where does it come from?
Is this script being included into another script, or anything like that?
Keep in mind that the setcookie function doesn't work if you send anything to the output buffer before it is used.
Even a white-space before the <?php tag will cause the function to fail.
I tried your script with minor modifications to switch your DB validation to a static validation, and it worked fine.
This is the modified code I used: - <?php
-
if(isset($_POST["usr"])) {
-
//$result = mysql_connect("*********", "******", "*********");
-
//$result = mysql_select_db("test");
-
$user = $_POST["usr"];
-
$pass = $_POST["pss"];
-
$usr_stat = 0;
-
$pss_stat = 0;
-
//$sql = "SELECT password FROM ".tbl_login." WHERE login = '$user';";
-
//$result = mysql_query($sql);
-
//$row_array = mysql_fetch_array($result);
-
$expire = time()+60*60*24*30;
-
-
if(false/*!$result || (mysql_numrows($result) < 1)*/){
-
$usr_stat = 0;
-
}
-
else{
-
$usr_stat = 1;
-
}
-
if(true/*$pass == $row_array['password']*/){
-
$pss_stat = 1;
-
}
-
else{
-
$pss_stat = 0;
-
}
-
if($usr_stat == 1 && $pss_stat == 1){
-
setcookie ('curruser', $_POST['usr'], $expire);
-
header('Location: test.php');
-
}
-
}
-
?>
-
<html>
-
<head>
-
<title>Studying PHP</title>
-
<link rel="stylesheet" href="css/main.css">
-
</head>
-
<body>
-
-
<h1>Login test</h1>
-
-
<form name="login" action="test.php" method="POST">
-
Username: <input type="text" value="" name="usr">
-
Password: <input type="password" value="" name="pss">
-
<input type="submit" value="Submit">
-
</form>
-
<pre>
-
<?php
-
if(isset($_POST["usr"])) {
-
if($usr_stat == 0){
-
echo "<p>Username invalid</p>";
-
}
-
else{
-
echo "<p>Username valid</p>";
-
}
-
if($pss_stat == 0){
-
echo "<p>Password valid</p>";
-
}
-
else{
-
echo "<p>Password invalid</p>";
-
}
-
if($usr_stat == 1 && $pss_stat == 1){
-
echo "<p>Login details valid</p>";
-
}
-
else{
-
echo "<p>Login details invalid</p>";
-
}
-
}
-
if(isset($_COOKIE['curruser'])){
-
echo "<p>Welcome ".$_COOKIE['curruser'].", you are now logged in using cookies.</p>";
-
}
-
else{
-
echo "<p>You are not logged in.</p>";
-
}
-
-
print_r($_COOKIE);
-
?>
-
</pre>
-
</body>
-
</html>
Ahh, it's now working :)
I now know what the problem was thanks to Atli, I was using the constant where I shouldn't have, such simple things.
Sorry about that, i'll try and remember not to do that again, silly mistake.
Thanks for all your help.
Atli 5,058
Expert 4TB
Glad you got it working.
Those little things, like spelling errors and such, always seem to cause the most trouble, don't they :)
Sign in to post your reply or Sign up for a free account.
Similar topics
by: Craig Matthews |
last post by:
hello, any idea why the following code does not work?!!
<?
$cookieExpire = 864000000;
setcookie("a", "love", $cookieExpire);
header("Set-Cookie: lc=50; expires=$cookieExpire");
|
by: Phil Powell |
last post by:
Fourth attempt.. it fails now in login, I check by printing
$_COOKIE and there is no value there! Guys, what
on earth do I do about this????
Here is the code that sets the cookie:
if...
|
by: TG |
last post by:
What is wrong with the following code? I have set allow all cookies on for
my browser. Why does this always redirect to NoCookies.htm?
Please see code below (both of the logic constructs below...
|
by: Ben |
last post by:
Hi all,
In my .php file, I'm using both session_start() and setcookie() before
<html> tag. It gives me following warning message:
Warning: Cannot modify header information - headers already...
|
by: Katherine Hall |
last post by:
I am trying to set a cookie and use it later, but as soon as put a redirect
or anything, I loose it.
So when I first print it out, it exists. When I go to my redirect page it's
gone.
first...
|
by: Rewire |
last post by:
This script seems to work fine with firefox but not with IE. It just sets style="display:none" or style="display:" to show / hide submenu items on my menu. I've just tried making it save to a cookie...
|
by: LayneMitch via WebmasterKB.com |
last post by:
Hello.
Got another one for you folks. I'm working on this problem that wants me to
1. Prompt for name
2. Use pop-up box with name
3. Display current date on page in format "October 30, 2000."...
|
by: SupraFast |
last post by:
I have two hosting accounts. On one, my setcookie script works fine; cookies are created. On the other, the same script doesn't work. The function returns TRUE, but no cookies is created.
I...
|
by: ryjfgjl |
last post by:
ExcelToDatabase: batch import excel into database automatically...
|
by: isladogs |
last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM).
In this month's session, we are pleased to welcome back...
|
by: Vimpel783 |
last post by:
Hello!
Guys, I found this code on the Internet, but I need to modify it a little. It works well, the problem is this: Data is sent from only one cell, in this case B5, but it is necessary that data...
|
by: jfyes |
last post by:
As a hardware engineer, after seeing that CEIWEI recently released a new tool for Modbus RTU Over TCP/UDP filtering and monitoring, I actively went to its official website to take a look. It turned...
|
by: ArrayDB |
last post by:
The error message I've encountered is; ERROR:root:Error generating model response: exception: access violation writing 0x0000000000005140, which seems to be indicative of an access violation...
|
by: CloudSolutions |
last post by:
Introduction:
For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
|
by: Defcon1945 |
last post by:
I'm trying to learn Python using Pycharm but import shutil doesn't work
|
by: Shællîpôpï 09 |
last post by:
If u are using a keypad phone, how do u turn on JavaScript, to access features like WhatsApp, Facebook, Instagram....
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome former...
| |