我有一个名为list.php的页面,它从数据库中检索并在列表中显示所有学生姓名及其各自的ID。在原始的PHP中,我就是这样做的 -
include("connect.php");
$query = "SELECT * FROM marks ";
$result = mysql_query($query);
$num = mysql_num_rows ($result);
mysql_close();
if ($num > 0 ) {
$i=0;
while ($i < $num) {
$studentname = mysql_result($result,$i,"studentname");
$studentid = mysql_result($result,$i,"studentid");
?>
And then---
<a href="studentprofile.php?studentid=<? echo $studentid?>"><? echo $studentname ?></a>
<?
++$i; } } else { echo "No Record Found"; }
?>
当用户点击任何学生姓名时,它会将用户带到该特定学生的页面,并且在该页面中我有一个如下代码 -
include("connect.php");
$number = $_GET['studentid'];
$qP = "SELECT * FROM student WHERE studentid = '$number' ";
$rsP = mysql_query($qP);
$row = mysql_fetch_array($rsP);
extract($row);
$studentid = trim($studentid);
$studentname = trim($studentname);
$studentgender = trim($studentgender);
上面的代码工作得很好。现在据我所知,$ _get在Codeigniter中是禁用的。但如果$ _get被禁用,如何在codeigniter中完成我上面提到的完全相同的事情?我浏览了一些关于使用$ _get的替代方法的教程,但我对这些并不了解。请你帮忙吗?在此先感谢:)
答案 0 :(得分:1)
CI中不鼓励使用$_GET
。
重写该文件的最简单方法是不使用$_GET
。只需将method='post'
添加到您的表单中,并告诉您的ajax请求使用post,如果有的话。在PHP中使用$_POST
而不是$_GET
。
如果您完全确定需要传递参数的请求,则必须启用query strings
。您可以在CI的配置文件中执行此操作:
$config['enable_query_strings'] = TRUE;
See section 'Enabling query strings'了解详情。但启用query strings
会导致生成网址的Url helper
和其他帮助程序出现故障。
所以我的建议是使用POST请求。
更新替换
<a href="studentprofile.php?studentid=<? echo $studentid?>"><? echo $studentname ?></a>
使用
<a href="studentprofile.php?studentid=<? echo site_url("yourcontroller/studentprofile/$studentid")?>"><? echo $studentname ?></a>
创建方法studentprofile
:
<?php
class Yourcontroller extends CI_Controller {
public function studentprofile($id)
{
include("connect.php");
$number = $id;
$qP = "SELECT * FROM student WHERE studentid = '$number' ";
$rsP = mysql_query($qP);
$row = mysql_fetch_array($rsP);
extract($row);
$studentid = trim($studentid);
$studentname = trim($studentname);
$studentgender = trim($studentgender);
// and so on...
}
}
?>