日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

        歡迎訪問 生活随笔!

        生活随笔

        當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

        编程问答

        jersey客户端_每个客户使用Jersey处理的Cookie

        發布時間:2023/12/3 编程问答 30 豆豆
        生活随笔 收集整理的這篇文章主要介紹了 jersey客户端_每个客户使用Jersey处理的Cookie 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

        jersey客戶端

        許多REST服務會將cookie用作身份驗證/授權方案的一部分。 這是一個問題,因為默認情況下,舊的Jersey客戶端將使用單例CookieHandler.getDefault ,大多數情況下該值為null,如果不為null,則在多線程服務器環境中不太可能工作。 (這是因為默認的Jersey客戶端在后臺將使用URL.openConnection)。

        現在,您可以通過使用針對Jersey的Apache HTTP客戶端適配器來解決此問題; 但這并不總是可用。 因此,如果您想在服務器環境中將Jersey客戶端與cookie一起使用,則需要做一些反思,以確保您使用自己的私有cookie jar。

        final CookieHandler ch = new CookieManager();Client client = new Client(new URLConnectionClientHandler(new HttpURLConnectionFactory() {@Overridepublic HttpURLConnection getHttpURLConnection(URL uRL) throws IOException {HttpURLConnection connect = (HttpURLConnection) uRL.openConnection();try {Field cookieField = connect.getClass().getDeclaredField("cookieHandler");cookieField.setAccessible(true);MethodHandle mh = MethodHandles.lookup().unreflectSetter(cookieField);mh.bindTo(connect).invoke(ch);} catch (Throwable e) {e.printStackTrace();}return connect;}}));

        僅當您的環境使用JDK隨附的sun.net.www.protocol.http.HttpURLConnection的內部實現時,這才起作用。 對于WLS的現代版本,情況似乎如此。

        對于JAX-RS 2.0,可以使用Jersey 2.x特定的ClientConfig類和HttpUrlConnectorProvider進行類似的更改。

        final CookieHandler ch = new CookieManager();Client client =ClientBuilder.newClient(new ClientConfig().connectorProvider(new HttpUrlConnectorProvider().connectionFactory(new HttpUrlConnectorProvider.ConnectionFactory() {@Overridepublic HttpURLConnection getConnection(URL uRL) throws IOException {HttpURLConnection connect = (HttpURLConnection) uRL.openConnection();try {Field cookieField = connect.getClass().getDeclaredField("cookieHandler");cookieField.setAccessible(true);MethodHandle mh = MethodHandles.lookup().unreflectSetter(cookieField);mh.bindTo(connect).invoke(ch);} catch (Throwable e) {e.printStackTrace();}return connect;}})));

        2015年2月11日更新:似乎在某些情況下,尤其是使用https,我已經看到HttpURLConnection包裹在另一個類中,要解決此問題,只需使用反射即可訪問委托字段的值。 我已經更新了代碼示例以反映此問題。

        翻譯自: https://www.javacodegeeks.com/2015/02/per-client-cookie-handling-jersey.html

        jersey客戶端

        總結

        以上是生活随笔為你收集整理的jersey客户端_每个客户使用Jersey处理的Cookie的全部內容,希望文章能夠幫你解決所遇到的問題。

        如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。