cakephp数据检索

时间:2012-05-24 04:06:16

标签: function cakephp information-retrieval

我正在尝试创建一个会吐出用户发票的页面。我在检索特定用户发票时遇到问题。问题在于控制器中的功能并设置$ id。我不确定如何将其设置为当前用户。

以下是我的功能中的相关代码

public function payInvoice(){

    $this->set('title_for_layout', 'Pay Invoice');
    $this->set('stylesheet_used', 'homestyle');
    $this->set('image_used', 'eBOXLogoHome.jpg');   
    $this->layout='home_layout';
    $userid = $this->Auth->user('id');
    $this->set('Invoices', $this->Invoice->findByBiller($userid));
}

这就是答案 包括我的观点:

<table width="100%" border="1">
                <tr>
                    <th>Biller</th>
                    <th>Subject</th>
                    <th>Date</th>
                    <th>Action</th>
                </tr>

                <?php foreach($Invoices as $invoice):?>
                    <tr> 
                        <td align='center'><?php echo $this->Html->link($Invoices['Invoice']['to'], 
                        array('action' => 'viewInvoice', $Invoices['Invoice']['to'])); ;?> </td>
                        <td align='center'><?php echo $Invoices['Invoice']['subject']; ?></td>
                        <td align='center'><?php echo $Invoices['Invoice']['datecreated']; ?></td>
                        <td align='center'><a href="viewinvoice"><button>View Invoice</button></a><a href="disputeinvoice"><button>Dispute Invoice</button></a></td>
                    </tr>
                <?php endforeach; ?>

            </table>

在代码中我对其进行了硬编码,因此用户15可以查看他的所有发票,但我不希望我的系统硬编码。我希望它设置为$id='currentuser'但不确定如何编码它。

用户登录功能

 public function login() {


    $this->set('title_for_layout', 'Individual Registration');
    $this->set('stylesheet_used', 'style');
    $this->set('image_used', 'eBOXLogo.jpg');

    if ($this->request->is('post')){
    $this->request->data['User']['password'] = 'qazwsx';
   if ($this->Auth->login()) {

       $this->redirect($this->Auth->redirect('eboxs/home'));
       $this->Session->write('Myid',$myid);
    } 
    else {
        $this->Session->setFlash('Username or password is incorrect');
    }
    }else{
    $this->Session->setFlash('Welcome, please login');
    }


}

任何帮助将不胜感激

3 个答案:

答案 0 :(得分:0)

为什么不将会话ID及其值分配为user_id?

答案 1 :(得分:0)

对于当前用户,您需要进行会话,我假设会话包含user_id。 试试这个

public function payInvoice(){
        $id=$this->Session->read('user_id');
        $this->set('title_for_layout', 'Pay Invoice');
        $this->set('stylesheet_used', 'homestyle');
        $this->set('image_used', 'eBOXLogoHome.jpg');   
        $this->layout='home_layout';
        $this->set('Invoices', $this->Invoice->findByBiller($id));
}

答案 2 :(得分:0)

当用户成功登录时,你在会话中设置他的id 等,

   $this->Session->write('Myid',$myid);
当用户名和密码正确时,

$myid从数据库中获取

并在控制器中的任意位置获取,例如

   $id = $this->Session->read('Myid');

并且您不需要添加到app_controller文件