Ich benutze CakePHP und ich möchte eine erste und Nachname Spalte der Tabelle Benutzer hinzufügen, aber wenn ich die Feldwerte firstname
& lastname
übergeben die Spalten sind immer Null, während die Standardfelder sind fein ausgefüllt.Kann ich zusätzliche Felder in der Benutzertabelle in CakePHP haben und trotzdem die integrierten Authentifizierungsmethoden verwenden?
Ist es möglich, dies zu tun oder brauche ich eine zweite Tabelle, um diese Werte zu speichern?
Code Update:
Anmeldeformular
<?php
$session->flash('register');
echo $form->create('User', array('action' => 'register/'));
echo '<h3>Register</h3>';
echo $form->input('firstname', array('label'=>'First Name'));
echo $form->input('lastname', array('label'=>'Last Name'));
echo $form->input('username');
echo $form->input('email');
echo '<input class="submitimg" type="image" src="' . $basepath . 'img/btn_submit.gif" alt="Submit" />';
echo $form->end();
?>
Aktion Register in user_controller.php
function register() {
if (!empty($this->data)) {
$password = $this->str_makerand(8,10);
$this->data['User']['password'] = $this->Auth->password($password);
$this->User->create();
$result = $this->User->save($this->data);
if ($result) {
$this->Session->setFlash('Registration complete, an email will be sent with your password', 'default', array(), 'register');
$this->sendNewUserMail($this->data['User']['username'], $this->data['User']['email'], $password);
} else {
$this->Session->setFlash('That username or email address is already taken, please try again', 'default', array(), 'register');
}
}
$this->redirect(array('controller' => 'properties', 'action' => 'index'));
}
MySQL Benutzertabelle:
CREATE TABLE users (
id int(11) NOT NULL AUTO_INCREMENT,
username char(50) DEFAULT NULL,
firstname varchar(100) NOT NULL,
lastname varchar(100) NOT NULL,
password char(50) DEFAULT NULL,
email varchar(100) NOT NULL,
created datetime NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY email (email),
UNIQUE KEY username (username)
)
Dank für Ihre Hilfe