Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 31 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
31
Dung lượng
286,65 KB
Nội dung
BảomậtSQL Tiểu luận Đề taì: BảomậttrongSQLServer Trần Kỳ Nam Page 1 6/27/2014 BảomậtSQL Lời nói đầu SQLServer 7.0 ra đời là 1 bước nhảy vọt công nghệ CSDL so với CSDL SQLServer 6.5, SQLServer 2000 ra đời không ngừng cung cấp cho người dùng những công cụ và những đặc điểm mới phiên bản 7.0 còn thiếu sót. Ngoài những đặc tính khắc phục thiếu sót của SQLServer 7.0, phiên bản SQLServer 2000 còn thay đổi 1 số cục diện khác trong các chức năng lập trình cũng giống như trong quan hệ và ràng buộc dữ liệu. Ngoài ra SQLServer 2000 còn cung cấp 1 số công cụ hỗ trợ khác như Phân tích xử lí trực tuyến (OLAP), chuyển tác trực tuyến (OLPT), English Query… Tìm hiểu về SQLServer là 1 mảng đềtài rộng, bao gồm kỹ năng lập trình, kỹ thuật ứng dụng SQL vào ứng dụng thực tiễn, các mô hình CSDL, kĩ thuật mới của SQLServer 2000, quản trị CSDL, bảo mật…. Trong phạm vi đềtài này chỉ tìm hiểu về bảomậttrongSQL Server. Trần Kỳ Nam Page 2 6/27/2014 BảomậtSQL Mục lục Lời nói đầu 1 Mục lục 2 1. Giới thiệu 3 1.1. Khái niêm cơ bản về bảomật 3 1.2. Giới thiệu chung về bảomậttrongSQLServer 4 2.Quản lí việc đăng nhập 4 2.1.Xác nhận việc đăng nhập 4 2.2.Sự xác nhận quyền 5 2.3.Tạo 1 đăng nhập 5 3.Quản lí người dùng 9 3.1Người dùng của SQLServer 9 3.2.Mối quan hệ giữa người dùng CSDL và tên đăng nhập 10 3.3.Quản lí tên người dùng và tên đăng nhập 10 4.Quyền người dùng (User Right) 10 4.1.Cấp phát quyền truy cập vào cơ sở dữ liệu 10 4.2.Cấp phát quyền thực thi trên cơ sở dữ liệu 13 5.Quyền tạo đối tượng trong CSDL 14 5.1.Sử dụng thủ tục 14 5.2.Sử dụng trình điều khiển EM 15 6.Quản lí vai trò 17 6.1.Vai trò trên CSDL 18 6.2.Vai trò trên server 19 6.3.Sử dụng các thủ tục khai báo 1 vai trò 19 6.4.Thêm 1 thành viên vào vai trò 20 7.Đối tượng CSDL và quyền với đối tượng 21 7.1.Đối tượng CSDL và chủ đối tượng 21 7.2.Quyền với đối tượng CSDL 22 7.3.Thừa nhận và loại bỏ quyền với 1 đối tượng 22 8. Một số bảomật khác 29 8.1. Tài khoản Guest (Guest Account) 29 8.2. Cấu hình cổng TCP/IP 29 8.3. Không nên sử dụng tài khoản sa 30 Trần Kỳ Nam Page 3 6/27/2014 BảomậtSQL 1.Giới thiệu: SQLServer là 1 hệ thống quản lí cơ sở dữ liệu (RDBMS) hay còn được gọi là relational database management system. RDBMS là 1 trong những mô hính cơ sở dữ liệu quan hệ thong dụng hiện nay. Sử dụng RDBMS System như là cách thức cơ bản để lưu trữ dữ liệu cho hầu hết các ứng dụng hiện nay. Tuy còn những mô hình khác ,nhưng trong phạm vi đềtài chỉ tập trung vao` RDBMS và đặc biệt chỉ xoay quanh vấn đềbảomật của SQL Server. Một cơ sở dữ liệu trong 1 tổ chức hay trong 1 doanh nghiệp có thể chúa đựng những dữ liệu hêt sức quan trọng mang tính sống còn. Chính vì thế mà bảomật dữ liệu trở thành 1 vấn đề rất quan trọng. Một hệ thống DBMS hay RDBMS cần phải hỗ trợ những kĩ thuật và phương tiện đểbảomật dữ liệu. Trongđềtài này sẽ tập trung vào các chính sách bảomật của SQLServer và thảo luận 1 cách chi tiết bảomật được cung cấp như thế nào trongSQL Server. 1.1.Khái niệm cơ bản về bảomậtBảomật có rất nhiều khái niệm, cho phép người quản trị CSDL tự ra quyết định cho phép hay không cho phép người dùng truy cập và thao tác trên CSDL sao cho có hiệu quả bảomật tốt nhất. Dưới 1 góc độ nào đó, người quản trị dựa trên nền tảng lí thuyết bảomật của hệ CSDL đa người dùng nhằm tìm ra những phương pháp bảomật theo đúng với nhu cầu của độ bảomật dữ liệu. Với mục đích tăng tính bảomật dữ liệu, SQLServer 2000 hỗ trợ các tính năng cho phép nhà quản trị thiết lập cợ chế bảo vệ CSDL trong môi trường đa người dùng, bao gồm các yếu tố chính sau: - Vai trò của người dùng trong hệ thống và CSDL - Quyền sử dụng các ứng dụng CSDL trongSQLServer - Quyền tạo và sửa đổi cấu trúc các đối tượng CSDL - Quyền truy cập, xử lí dữ liệu Khi đăng nhập vào 1 hệ thống CSDL đa người dùng, ngưới sử dụng cần phải cung cấp UserID và Password. Dựa trên UserID hệ thống có khả năng kiểm soát tát cả các hành vi của người sử dụng trên CSDL SQLServer 2000. Để làm được chức năng này, người quản trị CSDL cần phải thiết lập các quyền xử lý và truy cập vào CSDL khhi tạo ra UserID này, ngoài ra còn 1 số thuộc tính khác của SQLServer như quyền bakup dữ liệu, trao đổi dữ liệu với các ứng dụng CSDL khác… Khi nói đến bảo mật, ta cần quan tâm dến tên tài khoản, mật khảu, chiều dài, thời gian có hiệu lực… như sau: - Một người sử dụng chỉ có 1 UserID và 1 Password. - Thời gian có hiệu lực của mật khẩu. Trần Kỳ Nam Page 4 6/27/2014 BảomậtSQL - Chiều dài của mậ khẩu có giới hạn <= 36. - Giới hạn người sử dụng theo license hay mở rộng. - Thông tin về người sử dụng. Khi tạo người sử dụng, tên tài khoản cần rõ ràng, dễ hiểu dễ gợi nhớ, không cho phép các kí tự đặc biệt, không nên có khoảng trắng, điều này dễ gây khó khăn sau này. 1.2.Giới thiệu chung về bảomậttrongSQL Server: BảomậttrongSQLServer có thể được mô tả thông qua mô hình 3 tầng dưới đây: 1. Xác nhận( Authentication) 2.Khả năng là người dùng của 1 hay nhiều dữ liệu 3.Quyền đăc biệt được sử dụng những đối tượng CSDL được bảo vệ Tầng ngoài cùng đòi hỏi 1 tài khoản NT hoặc nhóm bảomậtđể có thể truy cập SQLServer thông qua việc dăng nhập vào server. Tầng kế tiếp là điều kiện để có thể sử dụng 1 hay nhiều CSDL. Tầng trong cùng là điều kiện để có thể thực hiện những phát biểu với những đối tượng CSDL được bảo vệ. 2.Quản lí việc đăng nhập: SQLServer xác nhận người dùng qua 2 cấp: - Xác nhận việc đăng nhập - Xác nhận quyền đối với CSDL SQLServer cần xác nhận 1 người dùng trước khi người đó có thể truy cập vào CSDL. TrongSQLServer mỗi người dùng được cấp cho 1 tài khoản riêng biệt được gọi là tài khoản đăng nhập ( Login Account). Mỗi người dùng tương tác với SQLServer sử dụng tài khoản này. Xác nhận(authentication) sẽ kiểm tra người dùng đang sử dụng tài khoản đăng nhập và cấp ra quyền kết nôi với SQL Server. Nếu sự xác nhận không thành công,người dùng không thể kết nối với SQLServer 2.1.Xác nhận việc đăng nhập: Một người dùng cần phải có tài khoản đăng nhập để kết nối với SQL Server. SQLServer có 3 cách để xác nhận, mỗi cách có 1 loại tài khoản đăng nhập khác nhau: - SQLServer Authentication: khi sử dụng SQLServer authentication, 1 người quản lí của SQLServer định nghĩa 1 tài khoản đăng nhập và mã cho 1 SQL Server. Những người dùng cần phải đưa ra cả tài khoản và mã dể kết nối với SQL Server. Trần Kỳ Nam Page 5 6/27/2014 BảomậtSQL - Windows NT Authentication : Khi 1 người dùng kết nối với SQLServer sử dụng Windows NT authentication, SQLServer kiểm lại với Windows NT xem tài khoản và mã đã đúng chưa.Nếu đúng thì người dùng có thể kết nôi với SQL Server. - Mixed Mode Authentication: Người dùng có thể sử dụng 1 trong 2 loại trên. 2.2.Sự xác nhận quyền: Trong mỗi CSDL, quyền được gán cho tài khoản của người dùng và các vai trò được tạo ra để thực hiện ( hoặc ngăn cấm) những hành động cụ thể. SQLServer chấp nhận các lệnh sau khi người dùng đã truy cập thành công tới CSDL. SQLServer thực hiện các bước sau trong khi xác nhận quyền: 1. Khi người dùng thực hiện 1 hành động, ví dụ như thực hiện 1 câu lệnh T-SQL,câu lệnh này được chuyển tới SQLServer 2. Khi SQLServer nhận được câu lệnh, nó kiểm tra em người dùng có quyền thực hiện câu lệnh hay không. 3. Sau đó, SQLServer thực hiện 1 trong 2 hành động sau: - Nếu người dùng có quyền, SQLServer thực hiện câu lệnh. - Nếu người dùng không có quyền, SQLServerbáo lỗi. Sử dụng Enterprise Manager, ta có thể chọn kiểu xác nhận như là Windows Authentication và Mixed mode authentication 2.3.Tạo 1 đăng nhập: Sử dụng Enterprise Manager ta có thể quản lí việc đăng nhập bằng việc sử dụng Create Login Wizard cung cấp bởi SQLServer Enterprise Manager. Quá trình(Wizard) này cung cấp 1 sự hướng dẫn từng bước hoàn chỉnh để tạo các đăng nhập 1 cách dễ dàng và hiệu quả. Bên cạnh đó ta cũng có thể sử dụng các thủ tục thường trú( stored procedures) để tạo hay xóa các đăng nhập. Để tạo 1 đăng nhập, ta có thể sử dụng câu lệnh sau: EXEC sp_addlogin [@login=]<’login’> [,@password=]<’password’>] [,[@defdb=]<’database’>] [,[@deflanguage=]<’language’>] [,[@sid=] ‘sid’ ] [,[@encriptopt=]<’encription_option’>] Diễn giải các tham số của thủ tục sp_addlogin như sau: @login: tên tài khoản sẽ tạo Trần Kỳ Nam Page 6 6/27/2014 BảomậtSQL @password: mật khẩu cho người dùng có tài khoản trên @defdb:CSDL mặc định khi người dùng đăng nhập vào SQLServer @deflanguage: ngôn ngữ mặc định cho người dùng @sid: Số nhận dạng hệ thống khi người dùng đăng nhập vào SQLServer @encriptopt: Khi tạo 1 tài khaỏn người dùng trong CSDL SQLServer 2000, các thông tin tài khỏan, mật khẩu lưu trữ trong bảng sysusers của CSDL Master, nếu ta cung cấp tham số skip_encription thì mật khẩu sẽ không mã hóa trước khi lưu vào bảng sysusers, nếu không cung cấp tham số hay để trống, SQLServer sẽ mã hóa â6tj khẩu trước khi lưu vào bảng sysusers. Ví dụ: EXEC sp_addlogin ‘Nam’,’123’ Nó sẽ tạo 1 đăng nhập với tên là “Nam”, mã là “123” Nếu sau khi tạo thành công tài khoản người dùng, cần thiết thay đổi mật khẩu, ta sử dụng thủ tục sp_ password như sau: EXEC sp_password [@old=]<’old password’> [,[@new=]<’new password’>] [,[@loginname=]<’’login’>] Để xóa 1 đăng nhập, ta có thể dùng câu lệnh sau : EXEC sp_droplogin ‘Nam’ Sử dụng trình điều khiển EM Để tạo ra 1 tài khoản đăng nhập (Login User), bắt đầu từ màn hình Enterprise Manager (EM), sau đó chọn ngăn Security/Login, right click chọn New Login hay chọn menu action New Login như trong hình sau: Trần Kỳ Nam Page 7 6/27/2014 BảomậtSQL Như đã trình bày ở trên, có 2 lựa chọn khi tạo một người dùng trongSQLServer 2000: - Tương tác với hệ điều hành Windows NT/2000 - Sử dụng riêng cho SQLServer 2000 Trong hình sau, dễ dàng nhận thấ khi chọn Windows NT authentication thì tham số tên miền của chúng yêu cầu, rõ ràng ta phải cung cấp tên miền hay địa chỉ TCP/IP của máy chủ, mặt khác tài khoản người dùng này phải tồn tại và có hiệu lực tên mạng. Trần Kỳ Nam Page 8 6/27/2014 BảomậtSQL Sau khi tạo, SQLServer 2000 kiểm tra. Tài khoản người dùng có hợp lệ hay không, có tồn tại trên hệ điều hành Windows NT/2000 hay không. Nếu tất cả thông tin hợp lệ, đăng ký thành công. Trong trường hợp ta muốn tài khoản đó có giá trị hiệu lực trongSQLServer 2000, chọn SQLServer authentication như hình sau: Trần Kỳ Nam Page 9 6/27/2014 BảomậtSQL Ghi chú: -Trong trường hợp sử dụng Tài khoản người dùng chung NT và SQL Server, nếu người dùng sử dụng tài khoản loại này họ có thể xóa dữ liệu trên mạng. -Tùy vào quan điểm quản lý, nhà quản trị tự thiết lập hệ thống người dùng sao cho phù hợp với chiến lược bảomật dữ liệu công ty. 3.Quản lí người dùng: SQLServer cho phép 2 loại tài khoản người dùng sau: - Người dùng hệ thống( system user) - Người dùng CSDL(database user) 3.1Người dùng của SQL Server: 1 mã người dùng có thể được dùng để xác nhận 1 người dùng trong 1 CSDL. Tất cả các quyền và sự sở hữu các đối tượng trong CSDL được kiểm soát bởi tài khoản người dùng. Các tài khoản người dùng là riêng biệt với mỗi CSDL; tài khoản abc trong CSDL books khác với tài khoản abc trong CSDL inventory,mặc dù chúng giống nhau. Trần Kỳ Nam Page 10 6/27/2014 [...]... 6/27/2014 Bảo mậtSQL 6.2.Vai trò trên server: Ta không chỉ gán vai trò cho người dùng trong CSDL, ta còn có thể gán vai trò trong phạm vi toàn bộ SQLServer 2000 Điều này có nghĩa ta có thể ngăn cản hoặc cho phép mọi người thực hiện các hoạt động Các vai trò này được gọi là vai trò trên server (server role) Các vai trò trên server trongSQLServer 2000: Sysadmin: vai trò này có khả năng kiểm soát toàn bộ SQL. .. 18 6/27/2014 Bảo mậtSQLSQLServer có các vai trò trên server và các vai trò trên CSDL Vai trò trên CSDL (database role) dùng để cấp các mức khác nhau khi truy cập CSDL Vai trò trên server (Server role) dùng để ngăn cản hoặc cho phép con người thực hiện các họat động 6.1.Vai trò trên CSDL: Có 1 vai trò trên CSDL rất đặc biệt : vai trò Public Mỗi người dùng được định nghĩa trong CSDL đều thuộc về vai... biết mật khẩu của guest 8.2 Cấu hình cổng TCP/IP SQLServer sử dụng nghi thức truyền dữ liệu TCP/IP và cổng 1433, tất nhiên khi cài đặt SQLServer thì giá trị mặc nhiên cho 2 thông số này được trình Setup thiết lập hoặc có thể thay đổi từ trình Client Network Utilities Trần Kỳ Nam Page 30 6/27/2014 BảomậtSQL Với tham số cổng 1433 mặc nhiên này, tất cả các máy trạm có thể truy cập vào CSDL SQL Server. .. SQL Trần Kỳ Nam Page 28 6/27/2014 BảomậtSQL Trần Kỳ Nam Page 29 6/27/2014 Bảo mậtSQL 8 Một số bảomật khác Phần này sẽ trình bày về 1 số bảomật đặc biệt có lien quan đến mạng và Internet 8.1 Tài khoản Guest (Guest Account) Guest Account là tài khoản người dùng mặc nhiên, khi ta cho phép tài khoản này có hiệu lực, có 1 số vấn đề phát sinh như sau: - Login với tài khỏan guest thì có thể truy cập bất... tạitrong cơ sở dữ liệu SQLServer 2000), phải thực hiện các bước sau: -Chọn tên cơ sở dữ liệu muốn cấp phát -Chọn ngăn User -R-Click (nhấp phải) / New Database User hay chọn menu Action / New Database User -Chọn tên tài khoản trong danh sách tài khoản (login user) đăng nhập SQLServer 2000 -Nếu cần thiết tạo tên bí danh (Alias) Màn hình trình EM cho phép cấp phát quyền 1 tài khoản đăng nhập SQL Server. .. Nam Page 14 6/27/2014 BảomậtSQL INSERT: Cho phép người dùng thêm dữ liệu, nếu người dùng có quỳen này, họ có thể thực hiện phát biểu Insert, đối với 1 hệ thống CSDL khác, muốn thực thi phát biểu Insert, người dùng phải có quyền Select, trong trường hợp SQLServer 2000, quyền Insert không liên quan đến quỳên truy vấn Select UPDATE: Quyền này cho phép người dùng chỉnh sử dữ liệu trong CSDL, với quyền... Server 2000: Sysadmin: vai trò này có khả năng kiểm soát toàn bộ SQLServer 2000 Tài khoản sa thuộc vai trò này Securityadmin: tạo và quản lí các dăng nhập cho server Serveradmin: cấu hình các tham số và tắt server Setupadmin: quản lí các thủ tục khỏi động và lien kết server Processadmin: quản lí các chuyển tác đang chạy trên SQLServer 2000 Điều này có nghĩa vai trò này có thể đưa ra câu lệnh KILL,... đối tượng trong CSDL Để thực hiện theo cách này, ta cần chọn một đối tượng, sau đó phân quyền tất cả đối tượng - Phân nhiều người sử dụng vào 1 đối tượng chỉ định của CSDL Để thực hiện theo cách này, ta cần chọn một đối tượng, sau đó phân quyền tất cả các tên người sử dụng Trường hợp thứ nhất cần theo các bước sau: Trần Kỳ Nam Page 27 6/27/2014 BảomậtSQL Trần Kỳ Nam Page 28 6/27/2014 BảomậtSQL Trần... là tài khoản của người sử dụng đăng nhập vào SQLServer 2000 Tham số @name_in_db cho phép ánh xạ hay còn gọi là bí dang tên của tài khoản người dùng thành 1 tên khác khi truy cập vào cơ sở dữ liệu chỉ định, trong trường hợp này SQLServer 2000 chỉ quản lý trên tên tài khoản đăng nhập Với cách này, khi sử dụng các ứng dụng khác truy cập vào cơ sở dữ liều SQLServer 2000, dĩ nhiên ứng dụng sẽ kết nối cơ... vai trò SQLServer có 2 loại vai trò: - Vai trò chuẩn (standard role): gần giống với các nhóm trong Windows NT Vai trò này có thể bao gồm người dùng, các quyền Khi 1 người dùng kêt nối với tư cách là thành viên của vai trò, họ hưởng các quyền của vai trò đó - Vai trò ứng dụng (application role): là những vai trò đặc biệt trong SQLServer 2000 bởi chúng không bao gồm bất kì thành viên nào Trong 1 chừng . Bảo mật SQL Tiểu luận Đề taì: Bảo mật trong SQL Server Trần Kỳ Nam Page 1 6/27/2014 Bảo mật SQL Lời nói đầu SQL Server 7.0 ra đời là 1 bước nhảy vọt công nghệ CSDL so với CSDL SQL Server. trung vào các chính sách bảo mật của SQL Server và thảo luận 1 cách chi tiết bảo mật được cung cấp như thế nào trong SQL Server. 1.1.Khái niệm cơ bản về bảo mật Bảo mật có rất nhiều khái niệm,. Trong phạm vi đề tài này chỉ tìm hiểu về bảo mật trong SQL Server. Trần Kỳ Nam Page 2 6/27/2014 Bảo mật SQL Mục lục Lời nói đầu 1 Mục lục 2 1. Giới thiệu 3 1.1. Khái niêm cơ bản về bảo mật 3 1.2.