Heim > Datenbank > MySQL-Tutorial > Wie kann ich SQL-Anmeldungen mithilfe von Parametern in gespeicherten Prozeduren sicher erstellen?

Wie kann ich SQL-Anmeldungen mithilfe von Parametern in gespeicherten Prozeduren sicher erstellen?

Linda Hamilton
Freigeben: 2024-12-18 10:36:20
Original
166 Leute haben es durchsucht

How Can I Securely Create SQL Logins Using Parameters in Stored Procedures?

Erstellen einer SQL-Anmeldung mit Parametern in gespeicherten Prozeduren

Um die Mandantenerstellung innerhalb einer SaaS-Datenbank zu automatisieren, versuchte ein Entwickler, a Gespeicherte Prozedur mit parametrisierten Eingaben für Benutzername und Passwort in der CREATE LOGIN-Anweisung. Allerdings stießen sie auf kryptische Fehlermeldungen im Zusammenhang mit falscher Syntax.

Die Hauptursache des Problems liegt in der CREATE LOGIN-Syntax, die Literalwerte anstelle von Parametern erfordert. Um dieses Problem zu beheben, gibt es eine Problemumgehung:

  1. Verbinden Sie den CREATE LOGIN-Befehl mit einer EXEC-Anweisung.
  2. Konstruieren Sie den CREATE LOGIN-Befehl dynamisch als Zeichenfolgenvariable.
  3. Nutzen Sie QUOTENAME(), um sich vor potenziellen SQL-Injection-Angriffen zu schützen.

Hier ist eine überarbeitete Version der gespeicherten Prozedur, die diese Änderungen beinhaltet:

CREATE PROCEDURE [MyScheme].[Tenants_InsertTenant]
    @username nvarchar(2048),
    @password nvarchar(2048)
AS
BEGIN
    -- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    SET NOCOUNT ON;

    DECLARE @sql nvarchar(max) = 'CREATE LOGIN ' + QUOTENAME(@username) + ' WITH PASSWORD = ' + QUOTENAME(@password, '''');
    EXEC(@sql)
END
Nach dem Login kopieren

Durch die Implementierung dieser Problemumgehung kann die gespeicherte Prozedur nun dynamisch SQL-Anmeldungen basierend auf bereitgestellten Parametern erstellen, wodurch der Mandantenerstellungsprozess vollständig automatisiert werden kann.

Das obige ist der detaillierte Inhalt vonWie kann ich SQL-Anmeldungen mithilfe von Parametern in gespeicherten Prozeduren sicher erstellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage