承接 ayto/reset-password-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ayto/reset-password-bundle

Composer 安装命令:

composer require ayto/reset-password-bundle

包简介

Bundle Symfony pour la réinitialisation de mot de passe avec API Platform et JWT

README 文档

README

License PHP Version Symfony Version

Un bundle Symfony léger et autonome pour gérer la réinitialisation de mot de passe. Fournit une solution complète avec interface utilisateur intégrée, sans dépendances frontend supplémentaires.

✨ Caractéristiques

  • 🔒 Système sécurisé de réinitialisation de mot de passe
  • 📧 Envoi d'emails de réinitialisation personnalisables
  • 🎨 Interface utilisateur moderne intégrée
  • 🔄 Tokens de réinitialisation sécurisés avec expiration
  • 📱 Design responsive
  • 🚀 Installation simple sans configuration frontend

📋 Prérequis

  • PHP 8.1 ou supérieur
  • Symfony 6.0 ou supérieur
  • Composer

🚀 Installation

  1. Installer le bundle via Composer :
composer require ayto/reset-password-bundle
  1. Ajouter le bundle dans config/bundles.php :
return [
    // ...
    Ayto\ResetPasswordBundle\ResetPasswordBundle::class => ['all' => true],
];
  1. Configurer le bundle dans config/packages/reset_password.yaml :
reset_password:
    from_email: 'no-reply@example.com'  # Email utilisé pour envoyer les emails de réinitialisation
    token_lifetime: 3600                # Durée de validité du token en secondes (1 heure par défaut)
    user_class: App\Entity\User         # Votre classe User qui implémente ResetPasswordUserInterface
  1. Implémenter l'interface dans votre entité User :
use Ayto\ResetPasswordBundle\Model\ResetPasswordUserInterface;

class User implements ResetPasswordUserInterface
{
    private ?string $resetToken = null;
    private ?\DateTimeInterface $resetTokenExpiresAt = null;

    public function getResetPasswordToken(): ?string
    {
        return $this->resetToken;
    }

    public function setResetPasswordToken(?string $token): void
    {
        $this->resetToken = $token;
    }

    public function getResetPasswordTokenExpiresAt(): ?\DateTimeInterface
    {
        return $this->resetTokenExpiresAt;
    }

    public function setResetPasswordTokenExpiresAt(?\DateTimeInterface $expiresAt): void
    {
        $this->resetTokenExpiresAt = $expiresAt;
    }

    public function getEmail(): string
    {
        return $this->email;
    }
}
  1. Ajouter les routes dans config/routes.yaml :
reset_password:
    resource: '@ResetPasswordBundle/Resources/config/routes.yaml'

🎨 Personnalisation

Templates

Vous pouvez surcharger les templates en créant les fichiers suivants dans votre application :

  • templates/bundles/ResetPasswordBundle/reset_password/request.html.twig
  • templates/bundles/ResetPasswordBundle/reset_password/reset.html.twig
  • templates/bundles/ResetPasswordBundle/emails/reset_password.html.twig

Styles

Les styles CSS sont inclus directement dans les templates et peuvent être surchargés en modifiant les templates ou en ajoutant vos propres styles.

🔒 Sécurité

  • Génération sécurisée des tokens
  • Validation des mots de passe côté client et serveur
  • Protection contre les attaques par force brute
  • Expiration automatique des tokens
  • Invalidation des anciens tokens

🤝 Contribution

Les contributions sont les bienvenues ! Pour contribuer :

  1. Forker le projet
  2. Créer une branche pour votre fonctionnalité (git checkout -b feature/AmazingFeature)
  3. Commiter vos changements (git commit -m 'Add some AmazingFeature')
  4. Pusher sur la branche (git push origin feature/AmazingFeature)
  5. Ouvrir une Pull Request

📝 License

Distribué sous la licence MIT. Voir LICENSE pour plus d'informations.

统计信息

  • 总下载量: 3
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-12-07