我需要将我的Pentaho社区仪表板报告集成到DotNet应用程序中。现在我遇到了一个问题。 我想在没有Pentaho服务器要求身份验证或登录的情况下单击打开报告。我试图找到解决方案并发现如果我在URL中使用用户ID和密码,它将起作用。所以我做了这个
但这对我不起作用,浏览器仍然要求登录凭据。我不明白出了什么问题。 对此有任何帮助将非常感激。
提前致谢。 问候, 仅限Ritesh。
答案 0 :(得分:12)
您需要在“管理用户”和“管理用户”下创建以下用户。角色透视:
anonymousUser (notice the uppercase U)
您可以为此用户提供任何密码;这只是为了确保此用户映射pentaho-solutions / system
中配置文件中使用的用户确保匿名角色至少具有读取权限。
匿名角色应该已经存在于BA服务器中(默认情况下,这是管理用户和角色视角中的系统角色)
在Public下创建一个文件夹:在我的情况下" OpenReports"
选择" OpenReports"文件夹点击属性>点击分享>取消选中>继承文件夹权限
确保匿名添加匿名用户和角色,并且至少是读取权限
单击“确定”
将分析器报告复制到新的OpenReports文件夹
验证anonymousUser和Anonymous角色的权限是否已继承;如果不相应添加它们。
停止BA服务器
找到以下文件:
\pentaho\server\biserver-ee\pentaho-solutions\system\applicationContext-spring-security.xml
添加以下行:
\A/i18n.*\Z=Anonymous,Authenticated
\A/js/utils.js\Z=Anonymous,Authenticated
\A/api/.*require-js-cfg.js\Z=Anonymous,Authenticated
\A/api/.*\Z=Anonymous,Authenticated
\A/api/repos.*\Z=Anonymous,Authenticated
\A/api/common-ui/resources/.*\Z=Anonymous,Authenticated
\A/api/common-ui/util/.*\Z=Anonymous,Authenticated
以下行打开对OpenReports文件夹及其内容的匿名访问
\A/api/repos.*public.*openreports.*\Z=Anonymous,Authenticated
\A/api/repos.*public.*openreports.*/viewer/.*\Z=Anonymous,Authenticated
\A/api/repos.*public.*openreports.*/common-ui/.*\Z=Anonymous,Authenticated
\A/api/repos.*public.*openreports.*/common-ui/util/.*\Z=Anonymous,Authenticated
after:
\A/js/require-cfg.js\Z=Anonymous,Authenticated
and before:
\A/content/data-access/resources/gwt/.*css\Z=Anonymous,Authenticated
添加以下行:(这些打开了对Analyzer插件的URL访问权限)
\A/content/pentaho-cdf/.*\Z=Anonymous,Authenticated
\A/content/common-ui/.*\Z=Anonymous,Authenticated
\A/content/analyzer/.*\Z=Anonymous,Authenticated
\A/content/analyzer/scripts/.*\Z=Anonymous,Authenticated
确保添加以下行:
After:
\A/content/data-access/resources/gwt/.*css\Z=Anonymous,Authenticated
and before:
\A/webcontext.js.*\Z=Anonymous,Authenticated
找到以下内容
Change the following lines from:
\A/api/.*\Z=Authenticated
\A/plugin/.*\Z=Authenticated
to:
\A/api/.*\Z=Anonymous,Authenticated
\A/plugin/.*\Z=Anonymous,Authenticated
保存文件
重新启动您的BA服务器
您应该能够通过URL成功调用报告,而无需通过登录页面进行身份验证;这是一个示例网址:
答案 1 :(得分:3)
这是绕过登录的最简单方法:
http://pedroalves-bi.blogspot.pt/2015/02/useful-tips-easy-authentication-in.html
这对我有用,我正在使用pentaho 5.4
不要忘记创建anonymousUser,并在“系统角色”中仅选中“阅读内容”。
如果您使用管理员用户,然后尝试访问http://localhost:8080/pentaho/Home 它会自动登录,因为浏览器仍然有会话登录。
抱歉我的英语不好,