我在html模板中有一个Login表单,想在表单提交时调用codeigniter控制器函数。在html页面位于CI文件夹之外且CI文件夹名称为二进制的地方,Ctrl_signin是我的控制器,chkvalidatelogin是我的函数,可以吗?
<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>
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);
}
}
}
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上显示空白页面
答案 0 :(得分:1)
这很有可能。只需将表单操作指向完整的URL,包括控制器和方法,例如example.com/controller/method
但是请注意,如果启用了CSRF保护,则可能会遇到控制器拒绝处理表单的情况。您需要在特定的控制器/方法上禁用CSRF(不建议),完全禁用CSRF(绝对不建议),或者找出一种方法来从Codeigniter外部遵循CI的CSRF验证