执行登录触发器后,登录sql server报错: 由于执行触发器,登录'xxx \ Administrator'登录失败。已将数据库上下文更改为master

技术知识
0 1781
小师傅 小师傅2021-11-26
积分:2397

背景:


在cmd中执行sqlcmd命令:

sqlcmd -S WIN-FI7RNDQ5SB4\MYSQLINSTANCE -i mysql.sql


其中mysql.sql内容如下:

CREATE LOGIN test WITH PASSWORD = '输入密码'
GO

ALTER TRIGGER tr_connection_limit

ON ALL SERVER
FOR LOGON
AS
BEGIN


IF ORIGINAL_LOGIN()= 'test'

AND
(SELECT EVENTDATA().value('(/EVENT_INSTANCE/ClientHost)[1]', 'NVARCHAR(15)'))
NOT IN('<local machine>','192.168.191.22')
     ROLLBACK;
END;


执行结果是:

C:\Users\Administrator>sqlcmd -S WIN-FI7RNDQ5SB4\MYSQLINSTANCE -i C:\Temp\sqltest\SQLQuery.sql
Sqlcmd:错误:用于SQL Server的Microsoft ODBC驱动程序13:由于执行触发器,登录'WIN-FI7RNDQ5SB4 \ Administrator'登录失败
结果使用SSMS登录Sql Server时失败,无论是用windows验证方式登录还是sql server账号登录都会报错:
由于执行触发器,登录'WIN-FI7RNDQ5SB4 \ Administrator'登录失败


我的解决方法是:


步骤一:用sqlcmd删除登录触发器:

C:\Users\Administrator>sqlcmd -A -S WIN-FI7RNDQ5SB4\MYSQLINSTANCE[服务器名]
1> select * from sys.server_trigger_events
2> go

object_id   type      type_desc                 
   is_trigger_event is_first is_last event_group_type event_group_type_desc  
-------------------------------- ---------------- -------- --
-------------------------------------------------------------------
 2107154552         147 LOGON   
  1        0       0             NULL NULL 
(1 行処理されました)

1> select * from sys.server_triggers
2> go

name     
    object_id   parent_class parent_class_desc      parent_id   type type_desc  
 create_date      modify_date       is_ms_shipped is_disabled
---------------------------------------------------------------------------------------------------
tr_connection_limit     2107154552          100 SERVER   
  0 TR   SQL_TRIGGER      
2018-10-23 17:40:04.367 2018-10-24 11:29:30.647     0     0

(1 行処理されました)
(1 行処理されました)

1> drop trigger tr_connection_limit[登录触发器名] on all server;
2> go
1> select * from sys.server_triggers
2> go

name    
 object_id   parent_class parent_class_desc  parent_id   type type_desc  
create_date             modify_date       is_ms_shipped is_disabled
--------------------------------------------------------------------------

(0 行処理されました)
1>


接下来登录Sql Server就成功了,无论是用什么账户登录。


步骤二:修改mysql.sql内容如下:

USE [master]
GO


SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO
 

CREATE LOGIN test WITH PASSWORD = '输入密码'
GO

ALTER TRIGGER tr_connection_limit

ON ALL SERVER
FOR LOGON
AS
BEGIN


IF ORIGINAL_LOGIN()= 'test'

AND
(SELECT EVENTDATA().value('(/EVENT_INSTANCE/ClientHost)[1]', 'NVARCHAR(15)'))
NOT IN('<local machine>','192.168.191.22')
     ROLLBACK;
END;


这次再运行就不会出现登录失败的问题了。


精选帖子
Android 可可影视 v3.3.6无广告纯净版 2599
Android QQ音乐 v11.3.7 定制版解锁免费听歌无广告版 3081
Android 草图大师SKP v1.5 解锁会员版 8509
Android OmoFun追漫神器 v4.2.1 无广告绿色版 5495
AdobeGenP Adobe全家桶系列激活工具 v3.5.0/3.4.14.1 绿色版 6087
Android 七猫免费听书 v1.4 解锁高级版 4532
超良心的抢票神器——Bypass1.16 4164
Android 玲珑加速器 v6.10.9.40 解锁无限时间 2894
Android 大师兄影视 v3.3.8 去广告会员版 2023
热门帖子
2026AI漫剧全流程变现实战:快手百万博主亲授,吃透90%分账红利,单人居家轻松月入过万 248
即梦豆包AI绘画指令大全:海量关键词库一键复制,出图效率提升10倍,轻松日更百图 245
AI业务自动化实战课,20款AI机器人搭建,覆盖文案、播客、销售与数据分析,打造自动化业务 238
【公众号流量主】红利回归!AI四步法每天3分钟,实测稳定日入2000+ 233
不用拍视频,不用露脸,只需手机ai,即可实现单日收益3000+ 203
抖音全新热门玩法,一部手机操作,小白轻松2000+ 203
Android 花小猪影视 v2.3.1 去广告纯净版 201
小修系统镜像 Windows 10 LTSC_2021 19044.3208 极限精简版 4合一 /2合一 199
26年只做这一个项目,一部手机,每天十几分钟,轻松日入500+ 190