• 了解mssql数据库


    0x00   前言

    介于这段时间比较忙,所以博客的更新也比较慢。本来想前几天就发这个mssql数据库的,但是因为mssql的结构比较复杂,利用方式也比较多,所以又去深入研究了一下mssql的数据库结构和各类的利用方式,以前都是工具一顿唆没有深入去研究过一些手工注入。

    0x01  了解mssql数据库

    这里说的mssql也就是我们的sqlserver数据库

    美国Microsoft公司推出的一种关系型数据库系统。SQL Server是一个可扩展的、高性能的、为分布式客户机/服务器计算所设计的数据库管理系统,实现了与WindowsNT的有机结合,提供了基于事务的企业级信息管理系统方案。
    (1)高性能设计,可充分利用WindowsNT的优势。
    (2)系统管理先进,支持Windows图形化管理工具,支持本地和远程的系统管理和配置。
    (3)强壮的事务处理功能,采用各种方法保证数据的完整性。
    (4)支持对称多处理器结构、存储过程、ODBC,并具有自主的SQL语言。 SQLServer以其内置的数据复制功能、强大的管理工具、与Internet的紧密集成和开放的系统结构为广大的用户、开发人员和系统集成商提供了一个出众的数据库平台。

    上面是百度百科的资料。

    mssql和sqlserver有着很大的不同,sqlserver的结构比较复杂,注入语句也比较复杂。但是如果在注入当中数据库是采用sa用户来运行的,那么我们就可以很轻松的拿下webshell。mssql可以直接启用存储过程来执行命令。

    我们来看一下mssql的系统自带数据库的作用。

    master 数据库存放着一切对象的信息,sa或者其他用户的密码 以密文存储
    model: 存在创建用户数据库的模板
    msdb:用户数据库,存放所有的任务调度
    tmpdb:临时数据库,在注入时候如果受限制显示位,存在在某表里面,然后再爆数据。重启会清空tempdb的数据

    数据库自带用户介绍:

    前面带#号的是mssql 内部用户数据库仅用数据库内部使用
    nt开头的是数据库安装的时候创建的

    如果msql 执行命令是使用nt serivicemssqlserver 这个 服务来执行命令 。

    下面我们来查询个看看,来查看与mysql 不同的地方。

    select * from master.dbo.sysobjects where xtype = 'u';

    matster是指定数据库名点号后面跟上的是他的架构 再加上表名。

    那么我们发现其实这个数据库里面根本没有这张表是怎么回事?

    其实这个只是我们的视图,而不是我们真正的表。

    sysobjects 是系统的视图,用于存放改数据库内创建的所有对象、如约束、默认值、日志、规则、存储过程,

    xtype是代表对象类型:
    U:表(用户自定义的表)
    V:视图
    P :存储过程
    X :扩展存储过程

    我们可以来查询我们所有的数据库名字

    select * from master..sysdatabases;

    这个查询的也是我们的视图 在mssql里面information这个数据库也都是以视图的形式存在的

    查看是否站库分离

     and (select host_name()) = (select @@servername)) 

    查询数据库的名字,这个函数可以遍历 在括号里面输入数字可以查询对应的数据库名字

    SELECT DB_NAME();

    这里再来说到mssql的权限划分,

    sa:sysadmin      超级管理员权限
    dbo : db_owner   数据库管理员权限
    public :访问用户权限

    0x02  存储过程

    存储过程(Stored Procedure)是在大型数据库系统中,
    一组为了完成特定功能的SQL 语句集,它存储在数据库中,一次编译后永久有效
    ,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
    存储过程是数据库中的一个重要对象。
    在数据量特别庞大的情况下利用存储过程能达到倍速的效率提升

    那么我们在实战当中就可以利用到存储过程来直接执行cmd命令

    常用的存储过程有xp_cmdshell,sp_oacreate  sp_oacreate这个存储过程执行命令无回显,需要输出到txt文件然后进行查看。

    在00版本是默认开启xp_cmdshell的 05版本后需要手工开启。

    0x03  结尾

    本次文章耗时3小时,记录一下时间点。下篇文章写mssql各类注入语法与bypass手法

  • 相关阅读:
    逆向工程工具介绍2-IDA
    汇编语言基础-1 基本语言元素
    Python常用标准库1-Turtle,Random,Time和Datetime
    Python的模块、包和库的概念
    Go语言的函数修饰符
    物理层2-物理层下面的传输媒体
    数据分析之两种用户分群方法(RFM和聚类)
    区间估计与假设检验公式
    源码分析过滤器与拦截器的区别
    Springboot拦截器使用及其底层源码剖析
  • 原文地址:https://www.cnblogs.com/nice0e3/p/12702771.html
Copyright © 2020-2023  润新知