Browsing articles tagged with " CRUD"
十月
7
2013

GroceryCRUD密碼欄位的處理

當我們使用GroceryCRUD的時候,最簡單的設定密碼欄位方式

$crud->field_type('user_pass', 'password');

只要使用field_type進行設定,這個欄位就會變成密碼的樣式,但是卻會發生一個問題,就是進入到編輯頁面的時候,密碼欄位都會重新送出寫進資料庫,除非你的密碼沒有加密,直接使用明碼存放在資料庫裡面,不然就會發生密碼一直被修改,使用者會無法登入的慘劇。對了,如果你的密碼是明碼直接存放於資料庫,歡迎在下面留言,讓大家都知道,然後讓大家觀摩朝聖一下 😀

為了避免上述的慘劇發生,我使用下面的方法來處理

1. 我使用另外一種方式來表達密碼欄位,不使用原本的field_type的方式

$crud->callback_add_field('user_pass',array($this,'setPasswordToEmpty'));
$crud->callback_edit_field('user_pass',array($this,'setPasswordToEmpty'));

2. setPasswordToEmpty的內容

function setPasswordToEmpty() {
	return "<input type='password' name='user_pass' value='' />";
}

3. 我建立下面兩個callback來處理密碼欄位

$crud->callback_before_insert(array($this, 'userPassProcess'));
$crud->callback_before_update(array($this, 'userPassProcess'));

4. 現在開始寫userPassProcess的內容

function userPassProcess($postArray, $primaryKey=null)
{
	// 如果密碼欄位不等於空白
	if(!empty($postArray['user_pass']))
	{
		$postArray['user_pass'] = $this->_encryptPass($postArray['user_pass']);
	}
	// 如果密碼欄位是空白
	else if(empty($postArray['user_pass']))
	{
		// 如果沒有把密碼欄位從要傳送的array中移除,會發生密碼欄位被更新為空值的情況
		unset($postArray['user_pass']);
	}
	return $postArray;
}

5. 最後把必填欄位也順手處理一下

if($crud->getState() == 'add')
{
	$crud->required_fields('user_acct','user_pass');
}
else
{
	$crud->required_fields('user_acct');
}
九月
27
2013

強化GroceryCRUD的join功能

grocerycrud是一個可以快速建立CRUD頁面和功能的一個好工具,但是他的join寫的實在有點死板板,不過好在我們還是可以有一些方法可以解決掉這個問題
首先建立一個model $codeigniterRoot/application/models/$modelName_model.php,下面是程式的內容

<?php
class Crud_classes_students_join extends grocery_CRUD_Model
{
	function get_list()
	{
		if($this->table_name === null)
			return false;

		$select = "{$this->table_name}.*";

		// 在這裡加入我們要額外select的欄位
		// $select .= ", user_log.created_date, user_log.update_date";

		if(!empty($this->relation))
			foreach($this->relation as $relation)
			{
				list($field_name , $related_table , $related_field_title) = $relation;
				$unique_join_name = $this->_unique_join_name($field_name);
				$unique_field_name = $this->_unique_field_name($field_name);

				if(strstr($related_field_title,'{'))
					$select .= ", CONCAT('".str_replace(array('{','}'),array("',COALESCE({$unique_join_name}.",", ''),'"),str_replace("'","\\'",$related_field_title))."') as $unique_field_name";
				else
					$select .= ", $unique_join_name.$related_field_title as $unique_field_name";

				if($this->field_exists($related_field_title))
					$select .= ", {$this->table_name}.$related_field_title as '{$this->table_name}.$related_field_title'";
			}

		$this->db->select($select, false);

		// 這裡寫上我們需要的join語法
		$teacherID = $this->session->userdata('userID');
		$this->db->join('teacher_student',"users.user_id=teacher_student.student_id and teacher_student.teacher_id=$teacherID");
		$obj = $this->db->get($this->table_name);
		$results = $obj->result();

		return $results;
	}
}

接下來在$codeigniterRoot/application/controllers/$controllerName

$crud = new grocery_CRUD();
$crud->set_model($modelName); // 這裡就是把我們剛剛建立的model載入進來
$crud->set_theme('datatables');
$crud->set_table('users');
$crud->set_subject('student');

這樣就可以讓GroceryCRUD根據我們特殊需求去做join,不會再受限於原本的架構了