网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Sybase教程
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.讲解Sybase在unix系统环境下的安.
.四大数据库的比较(SQL Server、.
.高性能海量级数据仓库引擎Sybase.
.教你快速掌握Sybase整库复制的具.
.使用SQL不当将会严重影响Sybase .
.Sybase及SQL Anywhere SQL语句小.
.通过sp_sysmon对Sybase进行性能诊.
.实例讲解如何将现有的Sybase逻辑.
.个人经验总结:Sybase数据库性能.
.安装Sybase后新建server时遇到的.
.Sybase和Oracle的互相导入.
.带你轻松接触Sybase ASE15.0.2性.
.Sybase与英国大东电报公司正式签.
.实例讲解Sybase远程磁带备份的具.
.Sybase与Sun共同打造世界上最大的.
.Sybase与Oracle数据库文件的互相.
.经验总结:Sybase ASA9/ASA10的使.
.Sybase程序设计中极易造成误解的.
.个人经验总结:Sybase数据库的全.
.Sybase发布下一代金融业分析平台.

个人经验总结:如何限制sa登录Sybase ASE

发表日期:2008-7-31


需求:必须限制 sa 登录sybase ASE


解决思路如下:

利用sybase ASE的特性提供的存储过程 sp_modifylogin,对登录的合法性进行验证。


-- 先新创建一个权限足够高的用户,将来当服务器有问题时,好用来恢复sa


-- 接下来将sa的login script绑定

use master

go


drop procedure sp_bindlogin

go


-- 存储过程名字弄个像系统的一样

create procedure sp_bindlogin

as

begin

declare @hostname varchar(100)

declare @program_name varchar(100)

declare @ipaddr varchar(100)

declare @new datetime


select @hostname = hostname,

@program_name = program_name,

@ipaddr = ipaddr

from master..sysprocesses

where spid = @@spid


-- 登录机器限定

if @hostname != '机器名'

begin

shutdown with nowait

end


-- 登录机器IP限定

if @ipaddr != '机器IP'

begin

shutdown with nowait

end


-- 登录应用程序限定

if @program_name in ('SQL_Advantage', 'isql')

begin

shutdown with nowait

end


select @new = getdate()


-- 登录时间限定

if @new >= '20080808'

begin

shutdown with nowait

end

end

go


sp_hidetext sp_bindlogin

go


sp_modifylogin sa, 'login script', sp_bindlogin

go


经过以上处理,sa只能在本机,并且不能使用 isql 、sqladv ,在 20080808 之前 登录数据库。

这里的逻辑是可以自由编写的。


这里的合法性验证不通过的处理方法是 shutdown 。

可以把 shutdown 换成以下存储过程。 这样就杀掉了自己。不会影响服务,只是需要做一些额外的配置。


drop procedure sp_killme

go


create procedure sp_killme

as

begin

declare @cmd varchar(100)

select @cmd = 'kill ' + convert(varchar(20), @@spid)


exec sp_remotesql 'local', @cmd

end

go


sp_hidetext sp_killme

go

上一篇:讲解Sybase在unix系统环境下的安装步骤 人气:822
下一篇:启动数据库管理工具Sybase Central的方法 人气:1677
浏览全部Sybase的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐