এসকিউএল সার্ভারে সংযোগের অধিকার সীমাবদ্ধ করুন


17

আমার কাছে এমন একটি অ্যাপ্লিকেশন রয়েছে যাতে উত্পাদন করতে লাগানো হয় যা 'সম্মান সিস্টেম' সুরক্ষা ব্যবহার করে। অর্থাৎ, সমস্ত ব্যবহারকারী একটি এসকিউএল ব্যবহারকারী / পাসডাব্লু শংসাপত্র ব্যবহার করে ডিবিতে সংযুক্ত হন এবং অ্যাপটি নিজেই অনুমতিগুলি পরিচালনা করে। পরবর্তী অংশটি আমাকে ততটা উদ্বিগ্ন করে না যে সংযোগ বস্তুটিতে এম্বেড করা শংসাপত্র রয়েছে এবং অবাধে অনুলিপি করা যেতে পারে। আমি ক্লায়েন্টদের আরও সীমাবদ্ধ সংস্থায় সংযোগ সীমাবদ্ধ করার জন্য কিছু উপায় খুঁজতে চেষ্টা করছি। আমি অবশ্যই আইপি দ্বারা সীমাবদ্ধ করতে ফায়ারওয়াল বিধি তৈরি করতে পারি। মেশিন অ্যাকাউন্ট বা ডোমেন সদস্যতার মাধ্যমে এসকিউএল লগইনগুলিকে 'প্রিক্যালিফাইফাই' করার কোনও উপায় আছে কি?


এসকিউএল সার্ভারের কোন সংস্করণ?
mrdenny

২০১২, তবে প্রয়োজনে আমার ডাউনগ্রেড অধিকার রয়েছে। এই অ্যাপ্লিকেশনটি অবশ্যই এটির নিজস্ব উদাহরণ পাচ্ছে।
জেফ স্যাকস্টেডার

তারপরে উত্তরে উল্লিখিত লগইন ট্রিগারগুলিই যাওয়ার উপায় হবে। অ্যাপ্লিকেশন নামের সাথে কেবল ব্যবহারকারীর নামটি বেঁধে রাখুন। যদি তারা রোলব্যাকের সাথে মেলে না। এখন এটি নিখুঁত হবে না কারণ আবেদনের নাম জাল করার উপায় রয়েছে তবে এটি যথেষ্ট ভাল হবে।
mrdenny

উত্তর:


8

আপনি লগন ট্রিগারটির মাধ্যমে এটি অর্জন করতে পারেন । আপনার লগন ট্রিগারটিতে আপনি যে প্রয়োজনীয় চেকগুলি সন্ধান করছেন (যেমন মেশিনের নাম) তা করার যুক্তি থাকতে পারে। দুর্ভাগ্যক্রমে, আমি বিশ্বাস করি না যে আপনি যদি এসকিউএল সার্ভার প্রমাণীকরণ ব্যবহার করেন তবে ব্যবহারকারীর ডোমেন সদস্যতা দখল করার কোনও উপায় আছে।

সংযোগের অনুমতি দেওয়া উচিত কিনা তা নির্ধারণের জন্য আপনি অন্যান্য তথ্য আহরণ করতে পারেন কিনা তা দেখতে আপনি ইভিএনটিটা ফাংশনটি ব্যবহার করতে পারেন। আপনি যদি সেই নির্দিষ্ট লগনটিকে সফল হতে না চান তবে আপনি শর্তসাপেক্ষে সহজ পরীক্ষা করতে পারেন এবং একটি ROLLBACK


আমাকে যাচাই করতে একটি মিশ্র-মোড উদাহরণ ইনস্টল করতে হবে, তবে লগন ট্রিগারটিতে কোনও অতিরিক্ত তথ্য উপলব্ধ রয়েছে বলে মনে হয় না। তবে জেনে রাখা ভাল। আমি এই বৈশিষ্ট্য সম্পর্কে সচেতন ছিলাম না।
জেফ স্যাকস্টেডার

12

থমাস যেমন উল্লেখ করেছেন যে এটি লোগন ট্রিগার ব্যবহার করে করা যেতে পারে। নীচে স্ক্রিপ্ট যা আপনাকে সাহায্য করবে

/*

http://www.sqlservercentral.com/scripts/Security/69558/
Credit: Gregory A. Ferdinandsen
--greg@ferdinandsen.com
--Revision 1.0, 8 Feb 10
--Requires SQL 2005 SP2 or higher
*/
if not exists (select 1 from master..sysdatabases where name = 'SQL_Audit')
 begin
 create database SQL_Audit
  end
USE [SQL_Audit]
GO

SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

SET ANSI_PADDING ON
GO

CREATE TABLE [dbo].[BlackList](
[SRV_Rule] [int] IDENTITY(1,1) NOT NULL,
[HostName] [varchar](64) NULL,
[IP_Address] [varchar](15) NULL,
[LoginName] [varchar](128) NULL,
[AppName] [varchar](256) NULL,
[RestrictionEnabled] [bit] NULL,
[Description] [varchar](2048) NULL,
CONSTRAINT [PK_BlackList] PRIMARY KEY CLUSTERED 
(
[SRV_Rule] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, FILLFACTOR = 90) ON [PRIMARY]
) ON [PRIMARY]

GO

SET ANSI_PADDING OFF
GO

ALTER TABLE [dbo].[BlackList] ADD CONSTRAINT [DF_BlackList_RestrictionEnabled] DEFAULT ((0)) FOR [RestrictionEnabled]
GO

---------------------------------------------------------------------
---------------------------------------------------------------------
USE [SQL_Audit]
GO


SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

SET ANSI_PADDING ON
GO

CREATE TABLE [dbo].[Violations](
[ViolationNum] [int] IDENTITY(1,1) NOT NULL,
[PostDate] [datetime] NOT NULL,
[LoginName] [varchar](128) NULL,
[IPAddress] [varchar](15) NULL,
[HostName] [nvarchar](64) NULL,
[ServerName] [varchar](96) NULL,
[AppName] [nvarchar](256) NULL,
[ViolationType] [varchar](512) NULL,
CONSTRAINT [PK_Violations] PRIMARY KEY CLUSTERED 
(
[ViolationNum] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

GO

SET ANSI_PADDING OFF
GO

ALTER TABLE [dbo].[Violations] ADD CONSTRAINT [DF_Violations_PostDate] DEFAULT (getdate()) FOR [PostDate]
GO
---------------------------------------------------------------------
---------------------------------------------------------------------
--(c) Gregory A. Ferdinandsen
--greg@ferdinandsen.com
--Revision 1.0, 8 Feb 10
--Requires SQL 2005 SP2 or higher

--
--Change with <<Execute as 'Domain\SQL'>> for a valid service account that has sa rights
--
--Information on Logon Triggers: http://msdn.microsoft.com/en-us/library/bb326598.aspx
--
USE Master
go

CREATE Trigger [trg_LoginBlackList]
 on all Server 

 as
begin

 declare @data XML
declare @User as varchar(128)
declare @HostName as varchar(64)
declare @IPAddress as varchar(15)
declare @AppName as nvarchar(256)
declare @SPID as int
declare @SrvName as nvarchar(96)
declare @PostTime as datetime
declare @LogMsg as varchar(1024)

set @data = EVENTDATA()
set @User = @data.value('(/EVENT_INSTANCE/LoginName)[1]', 'nvarchar(128)')
set @IPAddress = @data.value('(/EVENT_INSTANCE/ClientHost)[1]', 'nvarchar(15)')
set @SPID = @data.value('(/EVENT_INSTANCE/SPID)[1]', 'int')
set @SrvName = @data.value('(/EVENT_INSTANCE/ServerName)[1]', 'nvarchar(96)')
set @PostTime = @data.value('(/EVENT_INSTANCE/PostTime)[1]', 'datetime')
set @HostName = Cast(Host_Name() as nvarchar(64))
set @AppName = Cast(App_Name() as nvarchar(256))

--Check to see if the blacklist table exists, if the table does not exist, exit the Trigger, as otherwise all user would be locked out.

if Not Exists (select * from SQL_Audit.INFORMATION_SCHEMA.TABLES where TABLE_NAME = 'BlackList')
begin
return;
end


--#1
--If a user connects from a given work station and with a given UserName, they will be dissconected
--This user need to be set up in SQL_Audit..Blacklist with a user name and a host name, no IP Address is necesary
--This is the prefered method of blacklisting, as DHCP could reak havoc on any IP restrictions
If(Exists(Select * from SQL_Audit.dbo.BlackList where LoginName = @User and HostName = @HostName and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'LoginName, HostName')

--Exit trigger without evaluating any further conditions
return;
end

--#2
--If a user connects from a given IP Address and with a given UserName, they will be dissconected
--This user need to be set up in SQL_Audit..Blacklist with a user name and a IP Address, no HostName is necesary
If(Exists(Select * from SQL_Audit.dbo.BlackList where LoginName = @User and IP_Address = @IPAddress and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'LoginName, IP Address')

--Exit trigger without evaluating any further conditions
return;
end

--#3
--If a user connects from a given Blacklisted IP Address, regardless of the host name or SQL Server User
--This IPAddress need to be set up in SQL_Audit..Blacklist with only an IP Address, no other information is needed
--This will block all connections from the designated IP Address
If(Exists(Select * from SQL_Audit.dbo.BlackList where IP_Address = @IPAddress and LoginName is NULL and HostName is NULL and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'IP Address')

--Exit trigger without evaluating any further conditions
return;
end

--#4
--If a user connects from a given Blacklisted Workstation, regardless of the IP Address or SQL Server User
--This Client need to be set up in SQL_Audit..Blacklist with only a value for HostName, no other information is needed
--This will block all connections from the designated Host
If(Exists(Select * from SQL_Audit.dbo.BlackList where HostName = @HostName and LoginName is NULL and IP_Address is NULL and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'HostName')

--Exit trigger without evaluating any further conditions
return;
end

--#5
--If a particular application connects to SQL Server, regardless of IP Address, UserName, or HostName, the session is terminated
If(Exists(Select * from SQL_Audit.dbo.BlackList where AppName = @AppName and HostName is NULL and LoginName is NULL and IP_Address is NULL and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'ApplicationName')

--Exit trigger without evaluating any further conditions
return;
end

--#6
--If a particular application connects to SQL Server, with a given UserName (i.e. service account cannot connect with SSMS)
If(Exists(Select * from SQL_Audit.dbo.BlackList where AppName = @AppName and LoginName = @User and RestrictionEnabled = 1))
begin
--Any data modifications made up to the point of ROLLBACK TRANSACTION are rolled back
--The current trigger continues to execute any remaining statements that appear after the ROLLBACK statement. 
--If any of these statements modify data, the modifications are not rolled back.
--http://technet.microsoft.com/en-us/library/bb153915.aspx
rollback

insert into SQL_Audit..Violations
(PostDate, LoginName, IPAddress, HostName, ServerName, AppName, ViolationType)
values (@PostTime, @User, @IPAddress, @HostName, @SrvName, @AppName, 'ApplicationName, UserName')

--Exit trigger without evaluating any further conditions
return;
end
end;

GO

SET ANSI_NULLS OFF
GO

SET QUOTED_IDENTIFIER OFF
GO

ENABLE TRIGGER [trg_LoginBlackList] ON ALL SERVER
GO

দুর্ভাগ্যবশত, Host_Name()হয় না নিরাপদ ও সহজে প্রায় যে কেউ প্রতারণামূলক করা যেতে পারে। এটি এক্সেল থেকে করা বিশেষত সহজ। তোমার @IPAddressএই কাজের জন্য আরো অনেক নির্ভরযোগ্য হবে।
আরবেরি ইয়ং

@ আরবেরি ইয়ং ভাল পয়েন্ট এবং এটির আইপি অ্যাড্রেস কেন রয়েছে তা জানায়। এছাড়াও, এটি বিদ্যমান সংযোগগুলির জন্য কাজ করবে না এবং এটি লগন ট্রিগারগুলির একটি সীমাবদ্ধতা। সমস্ত নতুন সংযোগগুলি লগন ট্রিগার হয়ে যাবে। আপনার মন্তব্যের জন্য ধন্যবাদ.
কিন শাহ
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.