是否可以从html表单操作中调用codeigniter控制器函数

时间:2019-01-24 06:40:06

标签: php html codeigniter

我在html模板中有一个Login表单,想在表单提交时调用codeigniter控制器函数。在html页面位于CI文件夹之外且CI文件夹名称为二进制的地方,Ctrl_signin是我的控制器,chkvalidatelogin是我的函数,可以吗?

HTML表单代码:

<form action="binary/Ctrl_signin/chkvalidatelogin" method="post">
  <input type="email" name="username" class="email" placeholder="Username" required="" />
   <input type="password" name="Password" class="password" placeholder="Password" required="" />
    <input type="submit" value="Submit">
  </form>

Ctrl_signin控制器代码:

function chkvalidatelogin(){

  if(isset($_POST['login']) && $_POST['login']=='login')
  {
    $username=$_POST['username'];
    $password = $_POST['password'];
    $data = $this->Mdl_signin->validatelogin('member',$username,$password);
    if($data>0)
    {
      $userdata=$this->Mdl_signin->fetchmemid($username);
      $mid=$userdata->mem_lid;
      $mid1=$userdata->username;
      $_SESSION['user'] = $mid1;
      $_SESSION['mlid'] = $mid;
      $_SESSION['username'] = $mid;
      $this->session->set_userdata('login','true');
      $msg['message']="successfully login";
      redirect(base_url().'Ctrl_signin/Dashboard',$msg);
    }
    else
    {
      $msg="login failed!!";
      redirect(base_url().'Ctrl_signin/signin?mesg='.$msg);
    }
  }
 }

Mdl_signin型号代码:

  function validatelogin($table,$mid,$password)
    {   
    $query=$this->db->query('select * from '.$table.' where username="'.$mid.'" and decrepted_password="'.$password.'"');
    return $query->num_rows();
    }
  function fetchmemid($username)
    {   
     $sql='select mem_lid,username from member where username="'.$username.'"';
     $query=$this->db->query($sql);
    return $query->row();
    }

我尝试了上面的代码,但它在函数url上显示空白页面

1 个答案:

答案 0 :(得分:1)

这很有可能。只需将表单操作指向完整的URL,包括控制器和方法,例如example.com/controller/method

但是请注意,如果启用了CSRF保护,则可能会遇到控制器拒绝处理表单的情况。您需要在特定的控制器/方法上禁用CSRF(不建议),完全禁用CSRF(绝对不建议),或者找出一种方法来从Codeigniter外部遵循CI的CSRF验证