Добавьте зависимости jar, отличные от OSGI, в портлет MVC на основе maven в Liferay 7 CE.

Я создал портлет MVC для Liferay 7 CE с соответствующим архетипом maven (как описано здесь). Я добавил несколько дополнительных JAR-файлов, отличных от OSGI, в качестве зависимостей проекта в POM-файл проекта. Когда я развертываю проект на сервере портала liferay, контейнер OSGI не может разрешить зависимости созданного модуля, и пакет остается на этапе установки. Я хочу автоматически добавить JAR-файлы, отличные от OSGI, и их транзитивные зависимости в пакет. Что я должен делать? Содержимое модуля следующее:

структура проекта:

введите здесь описание изображения

пом.xml:

    <?xml version="1.0" encoding="UTF-8"?>

    <project
        xmlns="http://maven.apache.org/POM/4.0.0"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
    >
        <modelVersion>4.0.0</modelVersion>
        <groupId>org.ranginkaman</groupId>
        <artifactId>second-maven-portlet</artifactId>
        <version>1.0.0</version>
        <packaging>jar</packaging>
        <properties>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        </properties>
        <dependencies>
            <dependency>
                <groupId>com.liferay.portal</groupId>
                <artifactId>com.liferay.portal.kernel</artifactId>
                <version>2.0.0</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>com.liferay.portal</groupId>
                <artifactId>com.liferay.util.taglib</artifactId>
                <version>2.0.0</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>javax.portlet</groupId>
                <artifactId>portlet-api</artifactId>
                <version>2.0</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>3.0.1</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>jstl</groupId>
                <artifactId>jstl</artifactId>
                <version>1.2</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>org.osgi</groupId>
                <artifactId>org.osgi.compendium</artifactId>
                <version>5.0.0</version>
                <scope>provided</scope>
            </dependency>

            <!-- https://mvnrepository.com/artifact/com.vividsolutions/jts -->
            <dependency>
                <groupId>com.vividsolutions</groupId>
                <artifactId>jts</artifactId>
                <version>1.13</version>
            </dependency>
        </dependencies>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <version>3.1</version>
                    <configuration>
                        <source>1.8</source>
                        <target>1.8</target>
                    </configuration>
                </plugin>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-jar-plugin</artifactId>
                    <version>2.6</version>
                    <configuration>
                        <archive>
                            <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
                        </archive>
                        <excludes>
                            <exclude>**/META-INF/resources/**/.sass-cache/</exclude>
                        </excludes>
                    </configuration>
                </plugin>
                <plugin>
                    <groupId>biz.aQute.bnd</groupId>
                    <artifactId>bnd-maven-plugin</artifactId>
                    <version>3.2.0</version>
                    <executions>
                        <execution>
                            <id>default-bnd-process</id>
                            <goals>
                                <goal>bnd-process</goal>
                            </goals>
                        </execution>
                    </executions>
                    <dependencies>
                        <dependency>
                            <groupId>biz.aQute.bnd</groupId>
                            <artifactId>biz.aQute.bndlib</artifactId>
                            <version>3.2.0</version>
                        </dependency>
                        <dependency>
                            <groupId>com.liferay</groupId>
                            <artifactId>com.liferay.ant.bnd</artifactId>
                            <version>2.0.28</version>
                        </dependency>
                    </dependencies>
                </plugin>
                <plugin>
                    <groupId>com.liferay</groupId>
                    <artifactId>com.liferay.css.builder</artifactId>
                    <version>1.0.20</version>
                    <executions>
                        <execution>
                            <id>default-build-css</id>
                            <phase>generate-sources</phase>
                            <goals>
                                <goal>build-css</goal>
                            </goals>
                        </execution>
                    </executions>
                    <configuration>
                        <portalCommonPath>/</portalCommonPath>
                        <docrootDirName>src/main/resources</docrootDirName>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    </project>

бнд.бнд:

    Bundle-Name: second-maven-portlet
    Bundle-SymbolicName: org.ranginkaman
    Bundle-Version: 1.0.0
    -jsp: *.jsp,*.jspf
    -plugin.jsp: com.liferay.ant.bnd.jsp.JspAnalyzerPlugin
    -plugin.resourcebundle: com.liferay.ant.bnd.resource.bundle.ResourceBundleLoaderAnalyzerPlugin
    -plugin.sass: com.liferay.ant.bnd.sass.SassAnalyzerPlugin
    -sass: *

построить.градле:

    buildscript {
        dependencies {
            classpath group: "com.liferay", name: "com.liferay.gradle.plugins", version: "3.0.23"
        }

        repositories {
            mavenLocal()

            maven {
                url "https://cdn.lfrs.sl/repository.liferay.com/nexus/content/groups/public"
            }
        }
    }

    apply plugin: "com.liferay.plugin"

    dependencies {
        compileOnly group: "com.liferay.portal", name: "com.liferay.portal.kernel", version: "2.0.0"
        compileOnly group: "com.liferay.portal", name: "com.liferay.util.taglib", version: "2.0.0"
        compileOnly group: "javax.portlet", name: "portlet-api", version: "2.0"
        compileOnly group: "javax.servlet", name: "javax.servlet-api", version: "3.0.1"
        compileOnly group: "jstl", name: "jstl", version: "1.2"
        compileOnly group: "org.osgi", name: "org.osgi.compendium", version: "5.0.0"
    }

    repositories {
        mavenLocal()

        maven {
            url "https://cdn.lfrs.sl/repository.liferay.com/nexus/content/groups/public"
        }
    }

Секондмавенпортлетпортлет.java:

    package org.ranginkaman.portlet;

    import com.liferay.portal.kernel.portlet.bridges.mvc.MVCPortlet;
    import com.vividsolutions.jts.geom.Coordinate;
    import com.vividsolutions.jts.geom.GeometryFactory;
    import com.vividsolutions.jts.geom.Point;

    import java.io.IOException;

    import javax.portlet.Portlet;
    import javax.portlet.PortletException;
    import javax.portlet.RenderRequest;
    import javax.portlet.RenderResponse;

    import org.osgi.service.component.annotations.Component;

    @Component(
        immediate = true,
        property = {
            "com.liferay.portlet.display-category=category.sample",
            "com.liferay.portlet.instanceable=true",
            "javax.portlet.display-name=second-maven-portlet Portlet",
            "javax.portlet.init-param.template-path=/",
            "javax.portlet.init-param.view-template=/view.jsp",
            "javax.portlet.resource-bundle=content.Language",
            "javax.portlet.security-role-ref=power-user,user"
        },
        service = Portlet.class
    )
    public class SecondMavenPortletPortlet extends MVCPortlet {
        @Override
        public void doView(RenderRequest renderRequest, RenderResponse renderResponse)
                throws IOException, PortletException {


            GeometryFactory geometryFactory = new GeometryFactory();

            Point point = geometryFactory.createPoint(new Coordinate(1.0, 2.0));

            System.out.println(point);

            super.doView(renderRequest, renderResponse);
        }
    }

person Amir Ehsan    schedule 09.01.2017    source источник


Ответы (3)


Вот блог сообщества Liferay для добавления зависимостей от модуля OSGi: https://web.liferay.com/web/user.26526/blog/-/blogs/osgi-module-dependencies

Посмотрите, соответствуют ли эти параметры вашим требованиям. Вы должны выбрать вариант 3-й или 4-й, упомянутый в этом блоге. Это сработало в моем случае.

person Vishal Rangras    schedule 15.01.2017
comment
Спасибо, я прочитал эту статью. Но я хочу автоматически добавлять зависимости Maven и их транзитивные зависимости в Manifest.MF окончательного пакета файлов jar. Есть ли у вас предложения? - person Amir Ehsan; 16.01.2017
comment
Извините, но я понятия не имею на данный момент. Дам вам знать, если я столкнусь с чем-нибудь, связанным с вашим требованием. - person Vishal Rangras; 16.01.2017

Мы столкнулись с подобными проблемами и в нашем проекте. Я заметил, что последний ответ был от 15 января, и подумал, что было бы неплохо включить полезный ответ на запись в блоге Liferay, на которую ссылались. Именно это привело нас к осознанию того, что мы должны выбрать вариант 3 или 4 из блога, как упоминалось в предыдущем ответе.

Так что на самом деле это распространенное заблуждение — есть разница между сборкой в ​​gradle с использованием менеджера зависимостей и средой выполнения OSGi, в которой нет подобного менеджера зависимостей.

OSGi намеренно не загружает зависимости, особенно транзитивные зависимости, так как это может привести к нестабильной среде.

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

Так что да, при нормальных обстоятельствах вы должны самостоятельно включать все зависимости и транзитивные зависимости. Тем не менее, некоторые проекты не используют необязательные маркеры в своих транзитивных зависимостях, поэтому OSGi считает их обязательными. Вы должны добавить объявление classpath в файл BND, чтобы принудительно исключить те пакеты, которые вам действительно не нужны.

Это определенно PITA, но это не просто так. Среда OSGi — это ваша среда выполнения, которой вы хотите активно управлять и знать о ней. Как администратор, вы хотите знать, что используют ваши модули, и соответствующим образом управлять их развертыванием. С административной точки зрения вы бы не хотели, чтобы среда загружала что-то сама по себе (и часто это невозможно в любом случае в производственных средах).

person JohnL    schedule 21.04.2017

Если com.vividsolutions.jts не готов к OSGi, вы можете обернуть его через bnd или SpringRoo

person Tom    schedule 12.01.2017