ecshop会员登录记录用户名

ecshop登陆的时候,很多情况下,为了提高用户体验,或者方便用户登陆。我们可以在用户退出的时候,记录他们的登陆名称。
   下次登陆的时候,只需要填写密码就可以了。
  思路:
 只需要 在每次登陆的时候 写一个cookie 存用户名
 然后每次打开登陆页面的时候  查找并显示这个用户名就行了
user.php
1,setcookie('username',$username,time()+24*3600*30);//添加cookie保存时间
2,$smarty->assign('username', $_COOKIE['username']);//存cookie的值,用于保存登录的值

user_password.dwt
3,增加value="{$username}" 的值 用于登录
 
 
/* 2用户登录界面 */
elseif ($action == 'login')
{
    if (empty($back_act))
    {
        if (empty($back_act) && isset($GLOBALS['_SERVER']['HTTP_REFERER']))
        {
            $back_act = strpos($GLOBALS['_SERVER']['HTTP_REFERER'], 'user.php') ? './index.php' : $GLOBALS['_SERVER']['HTTP_REFERER'];
        }
        else
        {
            $back_act = 'user.php';
        }

    }


    $captcha = intval($_CFG['captcha']);
    if (($captcha & CAPTCHA_LOGIN) && (!($captcha & CAPTCHA_LOGIN_FAIL) || (($captcha & CAPTCHA_LOGIN_FAIL) && $_SESSION['login_fail'] > 2)) && gd_version() > 0)
    {
        $GLOBALS['smarty']->assign('enabled_captcha', 1);
        $GLOBALS['smarty']->assign('rand', mt_rand());
    }
 $smarty->assign('username', $_COOKIE['username']);//保存cookie的值,用于登录
    $smarty->assign('back_act', $back_act);
    $smarty->display('user_passport.dwt');
}

/* 1处理会员的登录 */
elseif ($action == 'act_login')
{
    $username = isset($_POST['username']) ? trim($_POST['username']) : '';
    $password = isset($_POST['password']) ? trim($_POST['password']) : '';
    $back_act = isset($_POST['back_act']) ? trim($_POST['back_act']) : '';


    $captcha = intval($_CFG['captcha']);
    if (($captcha & CAPTCHA_LOGIN) && (!($captcha & CAPTCHA_LOGIN_FAIL) || (($captcha & CAPTCHA_LOGIN_FAIL) && $_SESSION['login_fail'] > 2)) && gd_version() > 0)
    {
        if (empty($_POST['captcha']))
        {
            show_message($_LANG['invalid_captcha'], $_LANG['relogin_lnk'], 'user.php', 'error');
        }

        /* 检查验证码 */
        include_once('includes/cls_captcha.php');

        $validator = new captcha();
        $validator->session_word = 'captcha_login';
        if (!$validator->check_word($_POST['captcha']))
        {
            show_message($_LANG['invalid_captcha'], $_LANG['relogin_lnk'], 'user.php', 'error');
        }
    }

    if ($user->login($username, $password,isset($_POST['remember'])))
    {
        update_user_info();
        recalculate_price();
        setcookie('username',$username,time()+24*3600*30);//添加cookie保存时间
        $ucdata = isset($user->ucdata)? $user->ucdata : '';
        show_message($_LANG['login_success'] . $ucdata , array($_LANG['back_up_page'], $_LANG['profile_lnk']), array($back_act,'user.php'), 'info');
    }
    else
    {
        $_SESSION['login_fail'] ++ ;
        show_message($_LANG['login_failure'], $_LANG['relogin_lnk'], 'user.php', 'error');
    }
}




 

  

  

       
         
           
           
         
         
           
           
         
         
         
           
           
         
         
         
           
         
         
           
           
         
  
     
{$lang.label_username}
{$lang.label_password}
           
           
{$lang.comment_captcha}
            captcha
 
           
           
           
           
{$lang.get_password_by_question}   {$lang.get_password_by_mail}

   

 

 

    {$lang.user_reg_info[0]} 

    {$lang.user_reg_info[1]}:

   
    {$lang.user_reg_info[2]}

   
   
    {$lang.user_reg_info[8]}

   
    {$lang.user_reg_info[3]}:

    1. {$lang.user_reg_info[4]}

    2. {$lang.user_reg_info[5]}

    3. {$lang.user_reg_info[6]}

    4. {$lang.user_reg_info[7]} 

   
 



你可能感兴趣的:(ecshop,php资料库)