So habe ich dieses OOP Login & Registersystem, das einem Benutzer die Möglichkeit gibt, seinen/ihren Namen zu ändern.versuchen und fangen zur gleichen Zeit ausgeführt
Wenn ein Benutzer die Schaltfläche "Update" drückt, wird sein Name in der DB geändert. Das Problem ist, dass er den Namen in der DB ändert, anstatt den Benutzer dorthin umzuleiten, wo ich ihn umleiten soll Fehler, der nur angezeigt werden sollte, wenn dieser Name nicht geändert werden konnte.
User.php
<?php
class User{
private $_db,
$_data,
$_sessionName,
$_cookieName,
$_isLoggedIn;
public function __construct($user = null){
$this->_db = DB::getInstance();
$this->_sessionName = Config::get('session/session_name');
$this->_cookieName = Config::get('remember/cookie_name');
if(!$user){
if(Session::exists($this->_sessionName)){
$user = Session::get($this->_sessionName);
if($this->find($user)){
$this->_isLoggedIn = true;
} else{
//process logout
}
}
} else{
$this->find($user);
}
}
public function update($fields = array(), $id = null){
if(!$id && $this->isLoggedIn()){
$id = $this->data()->id;
}
if(!$this->_db->update('users', $id, $fields)){
throw new Exception('There was a problem updating your profile.');
}
}
public function create($fields = array()){
if(!$this->_db->insert('users', $fields)){
throw new Exception('There was a problem creating an account');
}
}
public function find($user = null){
if($user){
$field = (is_numeric($user)) ? 'id' : 'username';
$data = $this->_db->get('users', array($field, '=', $user));
if($data->count()){
$this->_data = $data->first();
return true;
}
}
return false;
}
public function login($username = null, $password = null, $remember = false){
if(!$username && !$password && $this->exists()){
Session::put($this->_sessionName, $this->data()->id);
} else{
$user = $this->find($username);
if($user){
if($this->data()->password === Hash::make($password, $this->data()->salt)){
Session::put($this->_sessionName, $this->data()->id);
if($remember){
$hash = Hash::unique();
$hashCheck = $this->_db->get('users_session', array('user_id', '=', $this->data()->id));
if(!$hashCheck->count()){
$this->_db->insert('users_session',array(
'user_id' => $this->data()->id,
'hash' => $hash
));
} else{
$hash = $hashCheck->first()->hash;
}
Cookie::put($this->_cookieName, $hash, Config::get('remember/cookie_expiry'));
}
return true;
}
}
}
return false;
}
public function exists(){
return(!empty($this->_data)) ? true : false;
}
public function logout(){
$this->_db->delete('users_session', array('user_id', '=', $this->data()->id));
Session::delete($this->_sessionName);
Cookie::delete(Config::get('remember/cookie_name'));
}
public function data(){
return $this->_data;
}
public function isLoggedIn(){
return $this->_isLoggedIn;
}
}
edit-profile.php
<?php
$user = new User();
if(!$user->isLoggedIn()){
Redirect::to('login');
}
if(Input::exists()){
if(Token::check(Input::get('token'))){
$validate = new Validate();
$validation = $validate->check($_POST, array(
'name' => array(
'required' => true,
'min' => 2,
'max' => 50
)
));
if($validation->passed()){
try{
$user->update(array(
'name' => Input::get('name')
));
Session::flash('flash', 'Your profile has been edited with success!');
Redirect::to('flash');
} catch(Exception $e){
die($e->getMessage());
}
} else{
foreach($validation->errors() as $error){
echo $error . '<br />';
}
}
}
}
?>
<form action="" method="post">
<div class="field">
<input type="text" name="name" value="<?php echo escape($user->data()->name); ?>">
</div>
<input type="submit" value="Update">
<input type="hidden" name="token" value="<?php echo Token::generate(); ?>">
</form>
Ich habe keine Ahnung, warum das
Dies ist die update() -Methode geschieht in meine DB.class
public function update($table, $id, $fields){
$set = '';
$x = 1;
foreach ($fields as $name => $value) {
$set .= "{$name} = ?";
if($x < count($fields)){
$set .= ', ';
}
$x++;
}
$sql = "UPDATE {$table} SET {$set} WHERE id = {$id}";
if($this->query($sql, $fields)->error()){
return true;
}
return false;
}
was ist das? 'DB :: getInstance()' Ich meine ich weiß, was es ist (Singleton), aber ist es eine Bibliothek oder etwas, im Grunde ist das die Rückkehr für das Update. Das ist eine Menge statischer Anrufe drin .... – ArtisticPhoenix
Ich meine auf der Oberfläche sieht es ok aus, nicht sicher, ich würde es so machen, aber ... – ArtisticPhoenix
DB.php ist meine DB-Klasse. ich kann es nicht als ein Kommentar anscheinend hinzufügen ... Update-Methode ist im Grunde das: öffentliche Funktion Update ($ Tabelle, $ ID, $ Felder) { \t \t $ set = ''; \t \t $ x = 1; \t \t foreach ($ Felder wie Name $ => $ value) { \t \t \t $ set = "{$ name} =?". \t \t \t if (x $ query ($ sql, $ Felder) -> Fehler()) { \t \t \t return true; \t \t} \t \t Rückgabe false; \t} –
emma