फाल्कन - सुरक्षा सुविधाएँ
फाल्कन सुरक्षा घटक की सहायता से सुरक्षा सुविधाएँ प्रदान करता है, जो पासवर्ड हैशिंग और जैसे कुछ कार्यों को करने में मदद करता है Cross-Site Request Forgery (CSRF)।
पासवर्ड हैक करना
Hashingएक निश्चित लंबाई बिट स्ट्रिंग को इस तरह से निर्दिष्ट लंबाई में परिवर्तित करने की प्रक्रिया के रूप में परिभाषित किया जा सकता है कि इसे उलट नहीं किया जा सकता है। इनपुट स्ट्रिंग में कोई भी परिवर्तन हैशेड डेटा के मूल्य को बदल देगा।
हैशड डेटा का डिक्रिप्शन उपयोगकर्ता द्वारा दर्ज किए गए मूल्य को इनपुट के रूप में लेता है और उसी के हैश रूप की तुलना करता है। आमतौर पर किसी भी वेब-आधारित अनुप्रयोगों के लिए, पासवर्ड को सादे पाठ के रूप में संग्रहीत करना एक बुरा अभ्यास है। यह तीसरे पक्ष के हमलों के लिए प्रवण है क्योंकि डेटाबेस तक पहुंच रखने वाले किसी भी उपयोगकर्ता के लिए आसानी से पासवर्ड खरीद सकते हैं।
फाल्कन पासवर्ड को एन्क्रिप्टेड रूप में संग्रहीत करने का एक आसान तरीका प्रदान करता है जो एक एल्गोरिथ्म का अनुसरण करता है md5, base64 या sh1।
जैसा कि पिछले अध्यायों में देखा गया है, जहाँ हमने ब्लॉग के लिए एक प्रोजेक्ट बनाया है। लॉगिन स्क्रीन उपयोगकर्ता के लिए उपयोगकर्ता नाम और पासवर्ड के रूप में इनपुट स्वीकार करता है। उपयोगकर्ता से पासवर्ड प्राप्त करने और इसे एक विशेष रूप में डिक्रिप्ट करने के लिए, निम्नलिखित कोड स्निपेट का उपयोग किया जाता है।
तब डिक्रिप्ट किए गए पासवर्ड को उपयोगकर्ता से इनपुट के रूप में स्वीकृत पासवर्ड से मिलान किया जाता है। यदि मान मेल खाता है, तो उपयोगकर्ता सफलतापूर्वक वेब अनुप्रयोग में लॉग इन कर सकता है और एक त्रुटि संदेश प्रदर्शित होता है।
<?php
class UsersController extends Phalcon\Mvc\Controller {
public function indexAction() {
}
public function registerUser() {
$user = new Users();
$login = $this->request->getPost("login");
$password = $this->request->getPost("password");
$user->login = $login;
// Store the hashed pasword
$user->password = $this->security->sh1($password);
$user->save();
}
public function loginAction() {
if ($this->request->isPost()) {
$user = Users::findFirst(array(
'login = :login: and password = :password:',
'bind' => array(
'login' => $this->request->getPost("login"),
'password' => sha1($this->request->getPost("password"))
)
));
if ($user === false) {
$this->flash->error("Incorrect credentials");
return $this->dispatcher->forward(array(
'controller' => 'users',
'action' => 'index'
));
}
$this->session->set('auth', $user->id);
$this->flash->success("You've been successfully logged in");
}
return $this->dispatcher->forward(array(
'controller' => 'posts',
'action' => 'index'
));
}
public function logoutAction() {
$this->session->remove('auth');
return $this->dispatcher->forward(array(
'controller' => 'posts',
'action' => 'index'
));
}
}
डेटाबेस में संग्रहीत पासवर्ड एन्क्रिप्टेड प्रारूप में हैं sh1 कलन विधि।
एक बार जब उपयोगकर्ता एक उपयुक्त उपयोगकर्ता नाम और पासवर्ड दर्ज करता है, तो उपयोगकर्ता सिस्टम तक पहुंच सकता है, अन्यथा एक त्रुटि संदेश सत्यापन के रूप में प्रदर्शित होता है।
क्रॉस-साइट अनुरोध क्षमा (CSRF)
यह एक ऐसा हमला है जो वेब एप्लिकेशन के प्रमाणित उपयोगकर्ताओं को कुछ अवांछित कार्य करने के लिए मजबूर करता है। प्रपत्र जो उपयोगकर्ताओं से इनपुट स्वीकार करते हैं वे इस हमले के प्रति संवेदनशील हैं। फाल्कन आवेदन के बाहर रूपों के माध्यम से भेजे गए डेटा की रक्षा करके इस हमले को रोकने की कोशिश करता है।
प्रत्येक रूप में डेटा टोकन पीढ़ी की मदद से सुरक्षित किया जाता है। उत्पन्न टोकन यादृच्छिक है और यह उस टोकन से मेल खाता है, जिसे हम प्रपत्र डेटा भेज रहे हैं (ज्यादातर वेब एप्लिकेशन के बाहर POST विधि के माध्यम से)।
कोड:
<?php echo Tag::form('session/login') ?>
<!-- Login and password inputs ... -->
<input type = "hidden" name = "<?php echo $this->security->getTokenKey() ?>"
value = "<?php echo $this->security->getToken() ?>"/>
</form>
Note - फॉर्म के टोकन भेजते समय सत्र एडाप्टर का उपयोग करना महत्वपूर्ण है, क्योंकि सत्र में सभी डेटा बनाए रखा जाएगा।
में सत्र एडाप्टर शामिल करें services.php निम्नलिखित कोड का उपयोग कर।
/**
* Start the session the first time some component request the session service
*/
$di->setShared('session', function () {
$session = new SessionAdapter();
$session->start();
return $session;
});