JSONWSゲストアクセス

Liferay プラットフォームの JSONWS ページは、未認証のユーザーでも Liferay_URL/api/jsonwsで利用可能です。 しかし、これはゲストユーザーがJSONウェブサービスを実行できることを意味するものではありません。 Guestとしてアクセスすると,JSONWS ページに Web サービスが表示されていても,ほとんどの Web サービスは呼び出すことができません. 例えば、ゲストが /announcementsdelivery/update-deliveryを使用する場合、 Guestとしてメソッドを起動すると、以下のエラーが表示されます。

Access denied to com.liferay.announcements.kernel.service.AnnouncementsDeliveryService#updateDelivery

これは、基盤となるサービスが、サービスの種類と目的に応じて Liferay の権限フレームワークによって保護されているからです。例えば、上記の updateDelivery サービスコールを実行するには、ユーザーはユーザーエンティティに対して ADD USER と UPDATE 権限を持っている必要があります。

認証されていないサービスコールは、Liferayプラットフォームインスタンスまたはあなたのプラグインのリモートメソッドが @AccessControlled アノテーションを持つ場合にのみ動作します。 Guestとして呼び出せるサービスが少量あります。例えば、 /country/get-countriesなどです。 これは、次のコードの @AccessControlled(guestAccessEnabled = true) アノテーションによって、その特定のメソッドにゲストからアクセスできるようになるためです。

Line 103 in CountryServiceImpl.java

    @AccessControlled(guestAccessEnabled = true)
    @Override
    public List<Country> getCountries(boolean active) {
        return countryPersistence.findByActive(active);
    }

DXP 7.0 SP7/FP57 および DXP 7.1+ の時点で Guest からアクセス可能なその他のリモートサービスは以下のとおりです。

/assetentry/increment-view-counter

/calendar.calendarbooking/search
/calendar.calendarbooking/searchCount /country/get-countries
/country/get-company-countries [7.4 only]
/pushnotifications.pushnotificationsdevice/add-push-notifications-device /pushnotifications.pushnotificationsdevice/delete-push-notifications-device /region/get-regions /sync.syncdlobject/get-sync-context

APIサービスは、コンパイル時に @AccessControlAdvice アノテーションを使用して、公開するように設定することができます。 この はランタイム設定を許可しておらず、ポータル管理者は 認証なしでサービスを利用できるようにするために ポータルを再コンパイルする必要があることに注意してください。

また、portal-ext.propertiesファイルで、以下のportalプロパティを false、JSON APIページを完全に無効にすることが可能です。

    #
    # Set this property to true if JSON web services are discoverable through
    # the API page.
    #
    jsonws.web.service.api.discoverable=true
この記事は役に立ちましたか?
2人中2人がこの記事が役に立ったと言っています