Follow Us

Soluții pentru problemele tale IT

Home /Servicii baze de date/SQL Server/Scriptarea unui login de pe un server pe altul, pastrand credentialele originale
Home /Servicii baze de date /Scriptarea unui login de pe un server pe altul, pastrand credentialele originale

Scriptarea unui login de pe un server pe altul, pastrand credentialele originale

  • Data 06/11/2017
  • Autor Bogdan Dumitru
  • Categorie Servicii baze de date, SQL Server
  • 0
  • 2374
Rezolvare problema (Fix IT)

Situatie

Avem uneori situatia in care suntem nevoiti sa copiem un login de pe un SQL Server pe un alt SQL Server.

Simptome

De cele mai multe ori nu stim parola acestui login si nu vrem ca pe noul server login-ul sa aiba o alta parola pt ca si asa userii uita usor parolele, daca mai au si parole diferite la acelasi login probabilitatea sa incurce parolele sau sa le uite este si mai mare.

 

 

Solutie

Pasi de urmat

Pt a rezolva aceasta problema exista o procedura sql care scripteaza login-ul impreuna cu credentialele (criptate) originale.

Aceasta procedura se numeste sp_help_revlogin.

USE [master]
GO

/****** Object: StoredProcedure [dbo].[sp_help_revlogin] Script Date: 06-Nov-17 10:23:13 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

 

— exec [sp_help_revlogin] ”

create PROCEDURE [dbo].[sp_help_revlogin] @login_name sysname = NULL AS
DECLARE @name sysname
DECLARE @type varchar (1)
DECLARE @hasaccess int
DECLARE @denylogin int
DECLARE @is_disabled int
DECLARE @PWD_varbinary varbinary (256)
DECLARE @PWD_string varchar (514)
DECLARE @SID_varbinary varbinary (85)
DECLARE @SID_string varchar (514)
DECLARE @tmpstr varchar (1024)
DECLARE @is_policy_checked varchar (3)
DECLARE @is_expiration_checked varchar (3)

DECLARE @defaultdb sysname

IF (@login_name IS NULL)
DECLARE login_curs CURSOR FOR

SELECT p.sid, p.name, p.type, p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM
sys.server_principals p LEFT JOIN sys.syslogins l
ON ( l.name = p.name ) WHERE p.type IN ( ‘S’, ‘G’, ‘U’ ) AND p.name <> ‘sa’
ELSE
DECLARE login_curs CURSOR FOR

 

SELECT p.sid, p.name, p.type, p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM
sys.server_principals p LEFT JOIN sys.syslogins l
ON ( l.name = p.name ) WHERE p.type IN ( ‘S’, ‘G’, ‘U’ ) AND p.name = @login_name
OPEN login_curs

FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin
IF (@@fetch_status = -1)
BEGIN
PRINT ‘No login(s) found.’
CLOSE login_curs
DEALLOCATE login_curs
RETURN -1
END
SET @tmpstr = ‘/* sp_help_revlogin script ‘
PRINT @tmpstr
SET @tmpstr = ‘** Generated ‘ + CONVERT (varchar, GETDATE()) + ‘ on ‘ + @@SERVERNAME + ‘ */’
PRINT @tmpstr
PRINT ”
WHILE (@@fetch_status <> -1)
BEGIN
IF (@@fetch_status <> -2)
BEGIN
PRINT ”
SET @tmpstr = ‘– Login: ‘ + @name
PRINT @tmpstr
IF (@type IN ( ‘G’, ‘U’))
BEGIN — NT authenticated account/group

SET @tmpstr = ‘CREATE LOGIN ‘ + QUOTENAME( @name ) + ‘ FROM WINDOWS WITH DEFAULT_DATABASE = [‘ + @defaultdb + ‘]’
END
ELSE BEGIN — SQL Server authentication
— obtain password and sid
SET @PWD_varbinary = CAST( LOGINPROPERTY( @name, ‘PasswordHash’ ) AS varbinary (256) )
EXEC sp_hexadecimal @PWD_varbinary, @PWD_string OUT
EXEC sp_hexadecimal @SID_varbinary,@SID_string OUT

— obtain password policy state
SELECT @is_policy_checked = CASE is_policy_checked WHEN 1 THEN ‘ON’ WHEN 0 THEN ‘OFF’ ELSE NULL END FROM sys.sql_logins WHERE name = @name
SELECT @is_expiration_checked = CASE is_expiration_checked WHEN 1 THEN ‘ON’ WHEN 0 THEN ‘OFF’ ELSE NULL END FROM sys.sql_logins WHERE name = @name

SET @tmpstr = ‘CREATE LOGIN ‘ + QUOTENAME( @name ) + ‘ WITH PASSWORD = ‘ + @PWD_string + ‘ HASHED, SID = ‘ + @SID_string + ‘, DEFAULT_DATABASE = [‘ + @defaultdb + ‘]’

IF ( @is_policy_checked IS NOT NULL )
BEGIN
SET @tmpstr = @tmpstr + ‘, CHECK_POLICY = ‘ + @is_policy_checked
END
IF ( @is_expiration_checked IS NOT NULL )
BEGIN
SET @tmpstr = @tmpstr + ‘, CHECK_EXPIRATION = ‘ + @is_expiration_checked
END
END
IF (@denylogin = 1)
BEGIN — login is denied access
SET @tmpstr = @tmpstr + ‘; DENY CONNECT SQL TO ‘ + QUOTENAME( @name )
END
ELSE IF (@hasaccess = 0)
BEGIN — login exists but does not have access
SET @tmpstr = @tmpstr + ‘; REVOKE CONNECT SQL TO ‘ + QUOTENAME( @name )
END
IF (@is_disabled = 1)
BEGIN — login is disabled
SET @tmpstr = @tmpstr + ‘; ALTER LOGIN ‘ + QUOTENAME( @name ) + ‘ DISABLE’
END
PRINT @tmpstr
END

FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin
END
CLOSE login_curs
DEALLOCATE login_curs
RETURN 0

GO

Aceasta procedura apeleaza o alta care se numeste sp_hexadecimal.

USE [master]
GO

/****** Object: StoredProcedure [dbo].[sp_hexadecimal] Script Date: 06-Nov-17 10:23:07 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

 

CREATE PROCEDURE [dbo].[sp_hexadecimal]
@binvalue varbinary(256),
@hexvalue varchar (514) OUTPUT
AS
DECLARE @charvalue varchar (514)
DECLARE @i int
DECLARE @length int
DECLARE @hexstring char(16)
SELECT @charvalue = ‘0x’
SELECT @i = 1
SELECT @length = DATALENGTH (@binvalue)
SELECT @hexstring = ‘0123456789ABCDEF’
WHILE (@i <= @length)
BEGIN
DECLARE @tempint int
DECLARE @firstint int
DECLARE @secondint int
SELECT @tempint = CONVERT(int, SUBSTRING(@binvalue,@i,1))
SELECT @firstint = FLOOR(@tempint/16)
SELECT @secondint = @tempint – (@firstint*16)
SELECT @charvalue = @charvalue +
SUBSTRING(@hexstring, @firstint+1, 1) +
SUBSTRING(@hexstring, @secondint+1, 1)
SELECT @i = @i + 1
END

SELECT @hexvalue = @charvalue

GO

Se ruleaza aceste doua proceduri pe serverul pe care avem login-ul pe care dorim sa il copiem cu aceleasi credentiale pe alt server.

In exemplul meu, am un login login_test pe care vreau sa il copiez cu aceleasi credentiale de pe serverul SQLTEST pe serverul SQLPI.

Se poate observa in fereastra de mai jos ca pe serverul SQLPI nu am acest login.

Pe primul server (pe cel pe care am login-ul) execut procedura sp_help_revlogin avand ca parametru numele login-ului, ca in imaginea de mai jos:

Dupa care iau cu copy scriptul din partea de jos a ferestrei si ma duc pe serverul pe care vreau sa pun acest login si rulez scriptul.

In partea de jos apare textul Command completed successfully, ca atare login-ul a fost creat cu succes impreuna cu credentialele originale de pe vechiul server.

Acum, in exemplul meu, se poate vedea ca pe serverul SQLPI a aprut noul login.

Ca atare acum persoana respectiva se poate loga cu acelasi login si aceeasi parola pe ambele servere.

Tip solutie

Permanent
Etichetare: askitaskit.rocredentialecredentialele originaleloginlogin de pe un serverpastrand credentialele originaleScriptarea unui login de pe un server pe altulSQL ServerSQLTEST pe serverul SQLPI

Voteaza

Up Down
(30 din 60 persoane apreciaza acest articol)
Share
Tweet
Share

Despre Autor

Bogdan Dumitru

Solutii Asemanatoare

  • List tables and rows 0
  • Listare tabele fara clustered index -2
  • Listare rapoarte publicate in Reporting Services -1
  • List wide tables 4
  • Lista joburi pe un server MSSQL Server -2
  • Verificare/schimbare mod autentificare MSSQL Server 3

Leave A Comment? × Cancel Reply

29682

Soluții Disponibile

0 Articole

In ultima saptamana

Cele mai recente soluții

  • Cum obtinem mai multe rezultate Google search pe pagina
    • 34
    • 3 days ago
  • Cum activam sau dezactivam modul imbunatatit pentru Windows Search
    • 23
    • 13/05/2025
  • Investiții simple pentru începători prin aplicații
    • 60
    • 13/05/2025
  • Cum să-ți organizezi munca cu Notion și Trello
    • 57
    • 13/05/2025
  • Realitatea Augmentată și Virtuală: aplicații IT in educație și medicină
    • 57
    • 13/05/2025
© Askit.ro, 2014 - 2025. All rights reserved. Done by Class IT
Share
Tweet
Share