c# - 防止 MDX 注入(inject)攻击

标签 c# mdx

使用 C# 防御 MDX 注入(inject)攻击的好方法是什么?我目前正在使用 ADOMDClient,我应该使用其他客户端吗?

最佳答案

我们可以创建参数化 MDX 查询,通过将用户指定的字符串传递到 MDX StrToSet、StrToTuple、StrToMember 和 StrToValue 函数来防止 MDX 注入(inject)攻击。

以下是来自 this MSDN page 的 MDX StrToSet 函数的几个示例.

The following example returns the set of members of the State-Province attribute hierarchy using the StrToSet function. The set specification provides a valid MDX set expression.

SELECT StrToSet ('[Geography].[State-Province].Members')  
ON 0  
FROM [Adventure Works]

The following example returns an error due to the CONSTRAINED flag. While the set specification provides a valid MDX set expression, the CONSTRAINED flag requires qualified or unqualified member names in the set specification.

SELECT StrToSet ('[Geography].[State-Province].Members', CONSTRAINED)  
ON 0  
FROM [Adventure Works]

以下代码示例演示了如何创建参数化查询,以及如何使用 AdomdConnection 对象执行它。

假设我们有以下通用 C# 方法执行参数化 MDX 查询并返回 CellSet。

public CellSet GetCellSet(string connectionString, string query, IDictionary<string, object> parms)
{
    using (var conn = new AdomdConnection(connectionString))
    {
        // Open the connection.
        conn.Open();

        // Create the command.
        using (var cmd = conn.CreateCommand())
        {
            // Set the command query.
            cmd.CommandText = query;

            // Add any query parameters.
            if (parms != null)
            {
                foreach (var kv in parms)
                {
                    var parameter = cmd.CreateParameter();
                    parameter.ParameterName = kv.Key;
                    parameter.Value = kv.Value;

                    cmd.Parameters.Add(parameter);
                }
            }

            // Execute the query and return the CellSet.
            return cmd.ExecuteCellSet();
        }
    }
}

假设我们有另一种方法允许客户端传入 MDX 集表达式的字符串表示形式。该方法将从立方体中选择集合并返回结果的 CellSet。

public CellSet GetMdxSetOnColumns(string setExpression)
{
    var connectionString = "replace with your connection string";

    // The query parameter @TheSet will be replaced with setExpression.
    var query = "SELECT StrToSet(@TheSet) ON 0 FROM [Adventure Works]";

    // Add the passed in string as a query parameter.
    var parms = new Dictionary<string, object>();

    // You can omit the "@" in front of the parameter name here.
    parms.Add("TheSet", setExpression);

    return GetCellSet(connectionString, query, parms);
}

客户端代码可以像这样调用这个方法。

var cellSet = GetMdxSetOnColumns("[Geography].[State-Province].Members");

关于c# - 防止 MDX 注入(inject)攻击,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44500720/

相关文章:

sql-server-2012 - 查找父级的百分比

c# - 如何从给定的 MDX 查询中获取多维数据集名称

sql - 使用 MDX 期间的最后一个非空子项

mysql - SSAS::MDX::Scope 函数::汇率

c# - 什么是 WPF,它与 WinForms 相比如何?

c# - “System.Data.DataRow.DataRow(System.Data.DataRowBuilder)”由于其保护级别而无法访问

c# - 在 C# 中生成运行时代码(结构、类)

filter - MDX 过滤器查询

c# - 在 HttpModule 中正确使用 ConcurrentQueue?

c# - 远程服务器返回错误: (500) Internal Server Error on website