jersey客户端_每个客户使用Jersey处理的Cookie
jersey客戶端
許多REST服務會將cookie用作身份驗證/授權方案的一部分。 這是一個問題,因為默認情況下,舊的Jersey客戶端將使用單例CookieHandler.getDefault ,大多數情況下該值為null,如果不為null,則在多線程服務器環境中不太可能工作。 (這是因為默認的Jersey客戶端在后臺將使用URL.openConnection)。
現在,您可以通過使用針對Jersey的Apache HTTP客戶端適配器來解決此問題; 但這并不總是可用。 因此,如果您想在服務器環境中將Jersey客戶端與cookie一起使用,則需要做一些反思,以確保您使用自己的私有cookie jar。
僅當您的環境使用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的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux设置内存大小(linux设置内
- 下一篇: 熔喷布报价(熔喷布备案价)