java - Oracle ORDS OAuth2,500 错误,来自 oracle.dbtools.common.util.Base64.base64ToByteArray 的 “String length must be a multiple of four”

标签 java oracle oauth fetch-api oracle-ords

我的需要是使用已通过身份验证的用户从 Oracle ORDS 获取 token 。我正在关注this documentation使用 fetch 开发 javascript .

我被困在这个点

$ curl -i -k --user 3NvJRo_a0UwGKx7Q-kivtA..:F5WVwyrWxXj3ykmhSONldQ.. --data "grant_type=client_credentials" https://ol7-121.localdomain:8443/ords/pdb1/testuser1/oauth/token HTTP/1.1 200 OK Server: Apache-Coyote/1.1 X-Frame-Options: SAMEORIGIN Content-Type: application/json Transfer-Encoding: chunked Date: Wed, 29 Jun 2016 12:07:02 GMT

{"access_token":"-zYl-sFyB2iLicAHw2TsRA..","token_type":"bearer","expires_in":3600} $

基于此示例,我将我的curl设置如下,并在主机的命令行中对其进行测试,它按预期响应有效 token

curl -i -k --user Uj1xXqz5pNRoSubJ6v3Hdg..:Npvid_qzM75NrO978NKl0A.. --data "grant_type=client_credentials" http://myhost:8080/ords/myrest/oauth/token

接下来,我尝试以这种方式已验证的curl命令转换为获取请求,但它响应500内部服务器错误:

fetch('http://myhost:8080/ords/myrest/oauth/token',
{
    method: 'POST',
    headers: {
        'Authorization': 'Basic Uj1xXqz5pNRoSubJ6v3Hdg..:Npvid_qzM75NrO978NKl0A..'
    },
    body: 'grant_type=client_credentials'
})...
尽管我正在搜索并尝试不同的变体,但我无法弄清楚我做错了什么或错过了什么。 意见和建议将不胜感激。

************ 编辑:按照评论中的建议,我尝试进一步采取一些措施************

关于OPTIONS请求,我检查了网络 Activity (作为第一次尝试,我使用浏览器的开发人员工具),我发现了带有方法OPTIONS和状态代码200的 header 。

考虑到我已经通过 Tomcat 部署了 ORDS,我修改了/app/oracle/ora_rest/params 中的 default.xml,如 this documentation 中所述。 。现在我可以检索错误的完整描述,并且仍在尝试配置/检查日志。

错误的完整跟踪是:

InternalServerException [statusCode=500, reasons=[An unexpected error with the following message occurred: String length must be a multiple of four.]] at oracle.dbtools.http.errors.ServletResponseExceptionMapper.mapError(ServletResponseExceptionMapper.java:84) at oracle.dbtools.http.errors.ErrorPageRenderer.(ErrorPageRenderer.java:43) at oracle.dbtools.http.errors.ErrorPageRenderer.(ErrorPageRenderer.java:35) at oracle.dbtools.http.errors.ErrorPageFilter.doFilter(ErrorPageFilter.java:119) at oracle.dbtools.http.filters.HttpFilter.doFilter(HttpFilter.java:47) at oracle.dbtools.http.filters.FilterChainImpl.doFilter(FilterChainImpl.java:64) at oracle.dbtools.http.auth.ForceAuthFilter.doFilter(ForceAuthFilter.java:44) at oracle.dbtools.http.filters.HttpFilter.doFilter(HttpFilter.java:47) at oracle.dbtools.http.filters.FilterChainImpl.doFilter(FilterChainImpl.java:64) at oracle.dbtools.http.filters.Filters.filter(Filters.java:47) at oracle.dbtools.http.entrypoint.EntryPoint.service(EntryPoint.java:82) at oracle.dbtools.http.entrypoint.EntryPointServlet.service(EntryPointServlet.java:49) at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) at oracle.dbtools.rt.web.HttpEndpointBase.dispatchableServices(HttpEndpointBase.java:116) at oracle.dbtools.rt.web.HttpEndpointBase.service(HttpEndpointBase.java:81) at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:475) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:624) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:341) at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:495) at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:767) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1354) at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:745) Caused by: java.lang.IllegalArgumentException: String length must be a multiple of four. at oracle.dbtools.common.util.Base64.base64ToByteArray(Base64.java:43) at oracle.dbtools.common.util.Base64.base64ToByteArray(Base64.java:23) at oracle.dbtools.http.auth.HttpBasicAuthenticationHandler.extractCredentials(HttpBasicAuthenticationHandler.java:38) at oracle.dbtools.http.auth.HttpBasicAuthenticationHandler.(HttpBasicAuthenticationHandler.java:21) at oracle.dbtools.http.auth.HttpBasicAuthentication.(HttpBasicAuthentication.java:15) at oracle.dbtools.http.auth.AuthenticationFilter.authenticate(AuthenticationFilter.java:69) at oracle.dbtools.http.auth.AuthenticationFilter.doFilter(AuthenticationFilter.java:62) at oracle.dbtools.http.filters.HttpFilter.doFilter(HttpFilter.java:47) at oracle.dbtools.http.filters.FilterChainImpl.doFilter(FilterChainImpl.java:64) at oracle.dbtools.url.mapping.RequestMapperImpl.doFilter(RequestMapperImpl.java:125) at oracle.dbtools.url.mapping.URLMappingBase.doFilter(URLMappingBase.java:103) at oracle.dbtools.url.mapping.filter.URLMappingFilter.doFilter(URLMappingFilter.java:124) at oracle.dbtools.http.filters.HttpFilter.doFilter(HttpFilter.java:47) at oracle.dbtools.http.filters.FilterChainImpl.doFilter(FilterChainImpl.java:64) at oracle.dbtools.http.cors.CORSResponseFilter.doFilter(CORSResponseFilter.java:83) at oracle.dbtools.http.filters.HttpResponseFilter.doFilter(HttpResponseFilter.java:45) at oracle.dbtools.http.filters.FilterChainImpl.doFilter(FilterChainImpl.java:64) at oracle.dbtools.http.errors.ErrorPageFilter.doFilter(ErrorPageFilter.java:94) ... 34 more

最佳答案

线路

[...]Caused by: java.lang.IllegalArgumentException: String length must be a multiple of four. at oracle.dbtools.common.util.Base64.base64ToByteArray(Base64.java:43) [...]

引导我修改传递 client_id:client_secret (authdata) base64 转换的请求 header (window.btoa(authdata)),如下所示:

fetch('http://myhost:8080/ords/myrest/oauth/token',
    {
        method: 'POST',
        headers: {
            'Authorization': 'Basic ' + window.btoa(authdata),
            'Content-Type': 'application/x-www-form-urlencoded'
        },
        body: 'grant_type=client_credentials'
    })...

提取现在可以正确响应 access_token 值,我可以使用它来发出授权的 GET 请求。

关于java - Oracle ORDS OAuth2,500 错误,来自 oracle.dbtools.common.util.Base64.base64ToByteArray 的 “String length must be a multiple of four”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53444681/

相关文章:

java - OpenCV 模板匹配 Max Min 取值范围是多少?需要作为theshold/c++/java

sql - 只打印列中的最大值

c# - 无效字符错误SQL,OracleDataReader

mysql - Oracle DB,mysql不能做什么?

ios - 如何生成签名方法OAuth1

ios - 在 Swift 3 中处理 Google 登录时遇到问题

java - 渲染多层图 block

java - 在不知道类型的情况下在Java中创建集合?

Twitter 不让我添加 127.0.0.1 作为回调 URL?

java - 如何使用 'ADD'按钮重复添加JPanel?如何在ActionListener()中调用JPanel?