Rumah > pembangunan bahagian belakang > C++ > Bagaimanakah Suntikan Ketergantungan Perpaduan Boleh Mengendalikan Resolusi Bersyarat untuk Pembekal Pengesahan Berbilang?

Bagaimanakah Suntikan Ketergantungan Perpaduan Boleh Mengendalikan Resolusi Bersyarat untuk Pembekal Pengesahan Berbilang?

Linda Hamilton
Lepaskan: 2024-12-31 18:00:27
asal
410 orang telah melayarinya

How Can Unity Dependency Injection Handle Conditional Resolution for Multiple Authentication Providers?

Penyelesaian Bersyarat dalam Perpaduan Suntikan Ketergantungan

Suntikan Ketergantungan (DI) membolehkan suntikan kebergantungan automatik ke dalam objek, mengurangkan keperluan untuk manual instantiasi dan konfigurasi. Penyelesaian bersyarat merujuk kepada keupayaan untuk menyelesaikan secara dinamik pelaksanaan berbeza antara muka berdasarkan keadaan tertentu.

Masalah:

Pertimbangkan senario berikut dengan dua penyedia pengesahan, TwitterAuth dan FacebookAuth, melaksanakan IAuthenticate antara muka:

public interface IAuthenticate
{
    bool Login(string user, string pass);
}

public class TwitterAuth : IAuthenticate
{
    bool Login(string user, string pass) { /* connect to twitter api */ }
}

public class FacebookAuth : IAuthenticate
{
    bool Login(string user, string pass) { /* connect to fb api */ }
}
Salin selepas log masuk

Dalam pengawal, anda ingin menyuntik pelaksanaan IAuthenticate berdasarkan penyedia pengesahan, yang dalam kes ini ditentukan oleh kaedah tindakan (cth., Twitter atau Facebook).

Corak Kilang sebagai Penyelesaian:

Satu pendekatan ialah menggunakan corak kilang, seperti yang dicadangkan oleh kawan awak. Walau bagaimanapun, ini melibatkan penciptaan kelas kilang untuk setiap penyedia pengesahan, yang membawa kepada masalah penduaan dan penyelenggaraan kod yang berpotensi.

Corak Strategi dengan Penyelesaian Bersyarat:

Penyelesaian yang lebih fleksibel adalah menggunakan corak strategi bersama-sama dengan bersyarat menyelesaikan:

Antaramuka:

public interface IAuthenticate
{
    bool Login(string user, string pass);
    bool AppliesTo(string providerName);
}

public interface IAuthenticateStrategy
{
    bool Login(string providerName, string user, string pass);
}
Salin selepas log masuk

Authenticate Provider:

public class TwitterAuth : IAuthenticate
{
    bool Login(string user, string pass) { /* connect to twitter api */ }

    bool AppliesTo(string providerName)
    {
        return this.GetType().Name.Equals(providerName);
    }
}

public class FacebookAuth : IAuthenticate
{
    bool Login(string user, string pass) { /* connect to fb api */ }

    bool AppliesTo(string providerName)
    {
        return this.GetType().Name.Equals(providerName);
    }
}
Salin selepas log masuk

Setiap pembekal melaksanakan IAuthenticate dan menyediakan kaedah untuk menentukan sama ada ia terpakai kepada pembekal tertentu nama.

Strategi:

public class AuthenticateStrategy : IAuthenticateStrategy
{
    private readonly IAuthenticate[] authenticateProviders;

    public AuthenticateStrategy(IAuthenticate[] authenticateProviders)
    {
        this.authenticateProviders = authenticateProviders;
    }

    public bool Login(string providerName, string user, string pass)
    {
        var provider = authenticateProviders.FirstOrDefault(x => x.AppliesTo(providerName));
        if (provider == null) throw new Exception("Login provider not registered");
        return provider.Login(user, pass);
    }
}
Salin selepas log masuk

Strategi mengambil pelbagai penyedia IAuthenticate dan mengendalikan penyelesaian bersyarat. Ia berulang melalui penyedia untuk mencari yang sepadan dengan nama pembekal dan mewakilkan operasi log masuk kepadanya.

Pendaftaran Perpaduan:

unityContainer.RegisterType<IAuthenticate, TwitterAuth>("twitterAuth");
unityContainer.RegisterType<IAuthenticate, FacebookAuth>("facebookAuth");
unityContainer.RegisterType<IAuthenticateStrategy, AuthenticateStrategy>(
    new InjectionConstructor(
        new ResolvedArrayParameter<IAuthenticate>(
            new ResolvedParameter<IAuthenticate>("twitterAuth"),
            new ResolvedParameter<IAuthenticate>("facebookAuth")
        )
    ));
Salin selepas log masuk

Pendaftaran ini mengkonfigurasi Perpaduan untuk menyelesaikan IAuthenticate pelaksanaan mengikut nama pembekal dan untuk menyuntik AuthenticateStrategy menggunakan penyelesaian ini contoh.

Penggunaan:

private readonly IAuthenticateStrategy _authenticateStrategy;

public AuthenticateController(IAuthenticateStrategy authenticateStrategy)
{
    _authenticateStrategy = authenticateStrategy;
}

// login with twitter
public virtual ActionResult Twitter(string user, string pass)
{
    bool success = _authenticateStrategy.Login("TwitterAuth", user, pass);
}

// login with fb
public virtual ActionResult Facebook(string user, string pass)
{
    bool success = _authenticateStrategy.Login("FacebookAuth", user, pass);
}
Salin selepas log masuk

AuthenticateStrategy disuntik ke dalam pengawal, yang kemudiannya mewakilkan operasi log masuk berdasarkan pembekal nama.

Kelebihan:

  • Reka Bentuk Fleksibel: Menambah atau mengalih keluar penyedia log masuk adalah mudah dengan hanya perubahan pada pendaftaran Unity.
  • Boleh diselenggara: Mengurangkan pertindihan dan menambah baik kod kebolehbacaan, kerana kod khusus pembekal terkandung dalam kelas berasingan.
  • Boleh diuji: Corak Strategi membolehkan ujian unit yang lebih mudah bagi penyedia pengesahan individu.

Atas ialah kandungan terperinci Bagaimanakah Suntikan Ketergantungan Perpaduan Boleh Mengendalikan Resolusi Bersyarat untuk Pembekal Pengesahan Berbilang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan