gpt4 book ai didi

c# - SSRS 检查用户是否在使用自定义程序集的组中

转载 作者:太空狗 更新时间:2023-10-29 19:41:26 26 4
gpt4 key购买 nike

我已经为我的 SSRS 项目创建了一个自定义程序集。

自定义程序集有两个函数,IsInGroupMyTest :

using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Principal;

namespace SSRS_Custom_Fuctions
{
public class Class1
{

public static bool IsInGroup(string user, string group)
{
using (var identity = new WindowsIdentity(user))
{
var principal = new WindowsPrincipal(identity);
return principal.IsInRole(group);
}
}

public static string MyTest()
{
return "Hello World";
}
}
}

1)基本功能MyTest使用表达式 =SSRS_Custom_Functions.Class1.MyTest() 从报告中返回一个字符串 'Hello World' 效果很好

2) 函数IsInGroup返回 bool 值不起作用。这是使用 System.Security.Principal namespace 检查传递给函数的用户名是否存在于传递给函数的组中。尝试使用表达式 =SSRS_Custom_Functions.Class1.IsInGroup(User.User1, "MyGroupName") 调用它时,报告正在退出并显示以下错误消息:

request for the permission of type System.Security failed

我修改了配置文件rssrvpolicy.config在 ReportingServices 文件路径和 RSPreviewPolicy.config在VisualStudio文件路径中根据Microsoft KB920769 .

我添加了一个 CodeGroup这给出了 FullTrust到我的自定义程序集。

以下内容已添加到策略级别元素:

<CodeGroup class="UnionCodeGroup"
version="1"
PermissionSetName="FullTrust"
Name="SSRS_Custom_Fuctions"
Description="Code group for my data processing extension">

<IMembershipCondition class="UrlMembershipCondition"
version="1"
Url="C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\PrivateAssemblies\SSRS_Custom_Fuctions.dll"/>
</CodeGroup>

我仍然收到与上述相同的错误消息。

最佳答案

在您的程序集中,您需要先声明 SecurityPermission 对象,然后再使用它。

using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Principal;

namespace SSRS_Custom_Fuctions
{
public class Class1
{

public static bool IsInGroup(string user, string group)
{

System.Security.Permissions.SecurityPermission sp = new System.Security.Permissions.SecurityPermission(System.Security.Permissions.PermissionState.Unrestricted);
sp.Assert();

using (var identity = new WindowsIdentity(user))
{
var principal = new WindowsPrincipal(identity);
return principal.IsInRole(group);
}
}

public static string MyTest()
{
return "Hello World";
}
}
}

关于c# - SSRS 检查用户是否在使用自定义程序集的组中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11740932/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com