每个客户使用Jersey处理的Cookie
許多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处理的Cookie的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 电脑顿号怎么打出来电脑上如何打出顿号
- 下一篇: 路由器怎么改ip地址电信天邑路由器如何改