BeanLocator не был установлен для контекста сервлета My_portlet при использовании построителя служб (Liferay)

Работа над портлетом MVC Spring Liferay 6.2. Я создал XML-файл службы и построил проект. Он управляет сущностью (скажем, MyEntity). Когда я вызываю метод addMyEntity(long id) из своего контроллера, возникает исключение: 15:53:04,135 ERROR [http-bio-8080-exec-60][PortletBeanLocatorUtil:42] BeanLocator имеет значение null для контекста сервлета My_portlet com .liferay.portal.kernel.bean.BeanLocatorException: BeanLocator не был установлен для контекста сервлета My_portlet

Похоже, портал не может получить доступ к некоторым ресурсам bean-компонентов. Мой файл web.xml включает в себя следующее:

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/spring-context/portlet-application-context.xml</param-value>
</context-param>
<servlet>
    <servlet-name>ViewRendererServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.ViewRendererServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>ViewRendererServlet</servlet-name>
    <url-pattern>/WEB-INF/servlet/view</url-pattern>
</servlet-mapping>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

portlet-application-context.xml включает только следующие bean-компоненты:

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="contentType" value="text/html;charset=UTF-8" />
        <property name="prefix" value="/WEB-INF/jsp/" />
        <property name="suffix" value=".jsp" />
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
    </bean>

Я думаю, что сервер ищет эти bean-компоненты, которые хранятся в файле portlet-spring.xml:

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" default-destroy-method="destroy" default-init-method="afterPropertiesSet" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
    <bean id="com.company.project.servicebuilder.dao.service.MyEntityLocalService" class="com.company.project.servicebuilder.dao.service.impl.MyEntityLocalServiceImpl" />
    <bean id="com.company.project.servicebuilder.dao.service.MyEntityService" class="com.company.project.servicebuilder.dao.service.impl.MyEntityServiceImpl" />
    <bean id="com.company.project.servicebuilder.dao.service.persistence.MyEntityPersistence" class="com.company.project.servicebuilder.dao.service.persistence.MyEntityPersistenceImpl" parent="basePersistence" />
</beans>

Однако я не вижу ссылок на portlet-spring.xml в других файлах, поэтому я боюсь, что эти bean-компоненты никогда не объявляются при развертывании портлета. Должна ли она быть где-то указана?

Любое другое предложение, кроме моей гипотезы?

Спасибо заранее.


person A.D.    schedule 14.10.2015    source источник


Ответы (4)


Благодаря пользователю «So Te» и некоторым обширным исследованиям, я решил эту проблему, указав pluginName в pom.xml в теге конфигурации и снова запустив сервис-построитель.

<configuration>
  <autoDeployDir>${liferay.auto.deploy.dir}</autoDeployDir>
  <appServerDeployDir>${liferay.app.server.deploy.dir}</appServerDeployDir>
  <appServerLibGlobalDir>${liferay.app.server.lib.global.dir}</appServerLibGlobalDir>
  <appServerPortalDir>${liferay.app.server.portal.dir}</appServerPortalDir>
  <liferayVersion>${liferay.version}</liferayVersion>
  <pluginType>portlet</pluginType>
  <pluginName>${project.artifactId}-${project.version}</pluginName>
</configuration>
person Davide Pedron    schedule 18.01.2018

Сообщение в файле журнала может немного ввести в заблуждение.

Одно из возможных условий появления этого сообщения: если при использовании ServiceBuilder и подключаемого модуля портлета Liferay имя проекта не соответствует сконфигурированному корневому контексту. Если вы проследите логику шаблона ServiceBuilder для создания класса ClpSerializer.java и стека выполнения во время выполнения, вы сможете установить соединение. Это мой опыт в LR6.2 CE.

Попробуйте сопоставить корень вашего контекста (в Eclipse — щелкните правой кнопкой мыши имя проекта/Свойства/Настройки веб-проекта) и сделайте его таким же, как имя вашего проекта портлета Liferay — например, "тест-портлет". Перестройте свой сервис и разверните его.

Опубликуйте свою степень успеха.

Это было моим решением вышеуказанной проблемы, так как я импортировал существующие проекты и не обращал внимания на настройки проекта. После сопоставления двух значений я смог успешно развернуть и выполнить логику портлета.

Ваше здоровье!

person So Te    schedule 24.11.2015

Попробуйте удалить портлет и развернуть его снова, обычно это ошибки при развертывании.

person André Caetano    schedule 14.10.2015
comment
Не повезло с этим и перезагрузка сервера тоже не помогла. - person A.D.; 15.10.2015
comment
Я действительно вижу ссылку на portlet-spring.xml в service.properties: ... spring.configs=\... WEB-INF/classes/META-INF/portlet-spring.xml,\... Это должно работать, учитывая, что мой путь к портлету-spring.xml — ‹имя-проекта›/source/main/resources//META-INF/portlet-spring.xml. У меня нет каталога WEB-INF/classes. - person A.D.; 15.10.2015

У меня была эта ошибка при создании тестов JUnit. У меня была эта ошибка, потому что автономный Mockito не поддерживает статические вызовы. Чтобы решить эту проблему, мне пришлось использовать Mockito с PowerMock, чтобы разрешить статические вызовы.

person Michael Fayad    schedule 19.06.2019