WSO2标识 - XACML PIP扩展会抛出org.apache.axis2.AxisFault:发生异常

时间:2015-09-18 18:23:24

标签: authorization wso2is access-control xacml abac

通过Java程序添加Java PIP扩展时,打包为.jar文件并使用entitlement.properties配置行:

PIP.AttributeDesignators.Designator.2=com.ibm.carbon.pip.RedAttributeFinder

服务器重新启动后,服务器会抛出一条错误消息,并在Web Entitlement屏幕上显示:

Error while loading entitlement policies. Exception occurred while trying to invoke service method getAllPolicies
The following error details are available. Please refer logs for more details.
org.apache.axis2.AxisFault: Exception occurred while trying to invoke service method getAllPolicies
at org.wso2.carbon.identity.entitlement.ui.client.EntitlementPolicyAdminServiceClient.handleException(EntitlementPolicyAdminServiceClient.java:478)
at org.wso2.carbon.identity.entitlement.ui.client.EntitlementPolicyAdminServiceClient.getAllPolicies(EntitlementPolicyAdminServiceClient.java:81)
at org.apache.jsp.entitlement.index_jsp._jspService(org.apache.jsp.entitlement.index_jsp:183)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:111)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:403)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:492)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:378)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
at org.wso2.carbon.ui.JspServlet.service(JspServlet.java:155)
at org.wso2.carbon.ui.TilesJspServlet.service(TilesJspServlet.java:80)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
... 

我已经对示例和源代码进行了审核,尝试了几个,并使用了本文https://stackoverflow.com/questions/21521796/how-to-add-user-defined-attribute-in-pip-attribute-user-store中发布的最新示例代码。在所有测试条件下,无论扩展添加的代码如何,结果错误总是完全相同。

是否有一种技术可以在PIP引擎上调试内部错误消息,并找到阻止Axis服务的此问题的根错误?

状态更新:

然而,我在PIP扩展测试方面没有取得进展。定义的WSO2服务器无法获取和加载名为“RedAttributeFinder”的Java扩展类,该扩展类是根据http://xacmlinfo.org/2011/12/18/writing-jdbc-pip-module/处的指令注册的。我们也没有 在服务器启动和日志中看到任何类加载器错误消息,只是如上所述的“AxisFault”错误消息。包名称已修改为名称“com.red.carbon.pip”。

使用以下定义激活了类:

PIP.AttributeDesignators.Designator.2=com.red.carbon.pip.RedAttributeFinder 

我们的代码将使用默认的“subjectid”作为输入参数,并创建一个包含六个字段的列表作为输出。是否需要定义字段,添加的字段并在模式.xsd或.xml文件中定义它们,如果是,是否有可用的文档?在我们的测试中,我们没有使用XML定义的“数据源”,因为那时,不需要使用数据库服务。

问题:在WSO2服务器上激活配置并加载PIP扩展代码并使其对PDP Extension控制台显示可见,或更正“AxisFault”错误需要哪些定义?

1 个答案:

答案 0 :(得分:1)

我已经从svn源存储库(参见下面的链接)中用最新版本替换了KmarketPIPAttributeFinder程序模块并对其进行了编译。这解决了WSO2 Identity Server Version 5下的问题,并且例程开始注册PIP属性,现在在PDP扩展中可见。

从以下网址下载模块:https://svn.wso2.org/repos/wso2/carbon/platform/trunk/components/identity/org.wso2.carbon.identity.samples.entitlement.pip/src/main/java/org/wso2/carbon/identity/samples/entitlement/pip/KmarketPIPAttributeFinder.java