Erstellen Sie programmgesteuert einen Administrator in Magento 2.0

8

Es ist einfach, einen neuen Administrator in Magento 1.9 hinzuzufügen

<?php
require_once('app/Mage.php');
umask(0);
Mage::app();

$user = Mage::getModel('admin/user')
    ->setData(array(
        'username'  => 'admin',
        'firstname' => 'admin',
        'lastname'  => 'admin',
        'email'     => '[email protected]',
        'password'  => 'hacker@123',
        'is_active' => 1
    ))
    ->save();

$user->setRoleIds(array(1))
    ->setRoleUserId($user->getUserId())
    ->saveRelations();

echo "User has been created successfully!";

?>

Aber wie kann ich Administratorbenutzer in Magento 2.0 hinzufügen?

Prahlad
quelle
1
Sie haben dies mit Magento-2.1 markiert, aber Magento 2.0 im Text erwähnt. Welches ist es? Es gibt ein generisches magento2- Tag, das Sie möglicherweise verwenden möchten.

Antworten:

8

Sie können Benutzer mit userFactory erstellen

/**
 * User model factory
 *
 * @var \Magento\User\Model\UserFactory
 */    
protected $_userFactory;

public function __construct(
    \Magento\User\Model\UserFactory $userFactory,
) {
    $this->_userFactory = $userFactory;
}

public function execute(){

    $adminInfo = [
        'username'  => 'killer',
        'firstname' => 'admin',
        'lastname'    => 'admin',
        'email'     => '[email protected]',
        'password'  =>'hello@123',       
        'interface_locale' => 'en_US',
        'is_active' => 1
    ];

    $userModel = $this->_userFactory->create();
    $userModel->setData($adminInfo);
    $userModel->setRoleId(1);
    try{
       $userModel->save(); 
    } catch (\Exception $ex) {
        $ex->getMessage();
    }
}

Sie können auch angeben, wie Magento eine Benutzer- Git-Quelle erstellt

Priyank
quelle
Die geteilte Git-URL ist 404
Gagan
Die URL wurde
geändert
7

Sie können den Administrator erstellen, indem Sie den folgenden Befehl über SSH auf der Ebene des Stammverzeichnisses ausführen.

php bin/magento admin:user:create --admin-user="admin" --admin-firstname="Admin" --admin-lastname="A" --admin-email="[email protected]" --admin-password="admin@5252"
Sandip
quelle
Wie können Sie auf diese Weise die Rolle festlegen?
Slayerbleast
Ich bin mir nicht sicher, ob ich
auschecken
1
perfekt machte meinen Tag !!! +1 :)
SagarPPanchal
2

Erstellen Sie eine Datei im Stammverzeichnis. zum Beispiel. admin.php

<?php 
use Magento\Framework\App\Bootstrap;
require 'app/bootstrap.php';
$bootstrap = Bootstrap::create(BP, $_SERVER);
$objectManager = $bootstrap->getObjectManager();
$UserFactory = $objectManager->get('\Magento\User\Model\UserFactory');

    try{
        $adminInfo = [
        'username'  => 'magento',
        'firstname' => 'magento',
        'lastname'    => 'magento',
        'email'     => '[email protected]',
        'password'  =>'magento@123',       
        'interface_locale' => 'en_US',
        'is_active' => 1
    ];

    $userModel = $UserFactory->create();
    $userModel->setData($adminInfo);
    $userModel->setRoleId(1);
    $userModel->save(); 

    } catch (\Exception $ex) {
        echo $ex->getMessage();
         exit;
    }
    echo "User is sucessfully created!"
?>
Ishvar Patel
quelle
1

Wenn es sich um eine einmalige Verwendung handelt oder wenn Sie sie während der Entwicklung benötigen, können Sie alternativ die folgenden mysql-Befehle in der Befehlszeile phpMyAdmin oder mysql ausführen, um einen Administratorbenutzer zu erstellen.

LOCK TABLES `admin_role` WRITE , `admin_user` WRITE;
SET @SALT = "rp";
SET @PASS = CONCAT(MD5(CONCAT( @SALT , "password") ), CONCAT(":", @SALT ));
SELECT @EXTRA := MAX(extra) FROM admin_user WHERE extra IS NOT NULL;
INSERT INTO `admin_user` (firstname,lastname,email,username,password,created,lognum,reload_acl_flag,is_active,extra,rp_token_created_at) 
VALUES ('Firstname','Lastname','[email protected]','adminuser',@PASS,NOW(),0,0,1,@EXTRA,NOW());
INSERT INTO `admin_role` (parent_id,tree_level,sort_order,role_type,user_id,role_name) 
VALUES (1,2,0,'U',(SELECT user_id FROM admin_user WHERE username = 'adminuser'),'Firstname');
UNLOCK TABLES;

Finden Erklärung und weitere Informationen hier

Hoffe, dies hilft Menschen, die nach ähnlichen Problemen / Lösungen suchen.

Nikin
quelle