Как я могу обрабатывать веб-сеансы с помощью CGI :: Session на Perl?

Я создаю веб-приложение на Perl, используя CGI. Это приложение реализует архитектуру Model View Controller, и система имеет следующую структуру в корневом каталоге:

-models -Просмотры -контроллеры -index.pl

Файл index.pl включает только соответствующие представления в соответствии с определенными параметрами, которые отправляются в него (с использованием функции param ()):

Вот мой index.pl:

###############################################
# INDEX.PL
###############################################

#!/usr/bin/perl

use Switch;
use CGI qw/:standard/;
use strict;
use CGI::Session ( '-ip_match' );

my $session = CGI::Session->load();

print header, start_html;
print "

Menu

"; if(!$session->is_empty){ #links to other files to which only logged users have access; } print '

Login

'; if(defined(param('p'))){ switch(param('p')){ } ##login form in html, which sends param('login') back to index.pl case 'login' { require('views/login/login.pl'); } else{ print "Page not found"; } } if(defined( param('login'))){ ##if param is defined we execute login2.pl require ('views/login/login2.pl'); }

Как вы можете видеть при переходе по ссылке «Вход в систему» ​​отобразится форма входа в систему, затем в форме входа в систему после отправки адреса электронной почты и пароля предполагается загрузить файл login2.pl:

login2.pl

###############################################
LOGIN2.PL
###############################################
#!/usr/bin/perl
  use CGI qw/:standard/;
  use lib qw(../../);
  use controllers::UserController;
  use CGI::Session ( '-ip_match' );

  my $session;

  my $mail = param('mail');
  my $password = param('password');

  my $userc = new UserController();
  my $user = $userc->findOneByMail($mail);


  if($mail ne '')
  {
      if($mail eq $user->getEmail() and $password eq $user->getPassword())
      {
          $session = new CGI::Session();
          $session->header(-location=>'index.exe');
      }
      else
      {
          print header(-type=>"text/html",-location=>"index.exe?p=login");
      }
  }
  elsif(param('action') eq 'logout')
  {
      $session = CGI::Session->load() or die CGI::Session->errstr;
      $session->delete();
      print $session->header(-location=>'index.exe');
  }

Файл login2.pl выполняется правильно, и предполагается создать новую сессию, когда почта и пароль верны. Однако я не знаю, правильно ли переменная $ session отправлена ​​в index.pl, потому что индекс всегда показывает только ссылки, которые не требуют активного сеанса. Еще одна проблема, с которой я столкнулся, заключается в том, что я не могу удалить сеанс. Я попытался создать переменную $ session в файле index.pl, чтобы посмотреть, работает ли условие, а затем я предположительно удалил его с помощью следующих команд: $ сессия-> удалить (); $ session-> flush (); но сеанс, кажется, продолжает существовать.

5
задан brian d foy 6 October 2010 в 22:03
поделиться