[rfc][icedtea-web] Strip parameters from document-base
Adam Domurad
adomurad at redhat.com
Mon Apr 22 14:05:28 PDT 2013
Ping.
On 04/10/2013 03:02 PM, Adam Domurad wrote:
> [ .. original message snipped ..]
>
> Sorry for the confusion. I spent a bit of time creating a reproducer
> and investigating why we were different from the proprietary plugin to
> begin with.
>
> I have finally found the real reason for the troubles & inconsistency
> here, the basic fix is:
>
>> diff --git a/plugin/icedteanp/java/sun/applet/PluginAppletViewer.java
>> b/plugin/i
>> --- a/plugin/icedteanp/java/sun/applet/PluginAppletViewer.java
>> +++ b/plugin/icedteanp/java/sun/applet/PluginAppletViewer.java
>> @@ -439,8 +439,7 @@ public class PluginAppletViewer extends
>> String height = msgParts[2];
>>
>> int spaceLocation = message.indexOf(' ', "tag".length() + 1);
>> - String documentBase =
>> - UrlUtil.decode(message.substring("tag".length() + 1,
>> spaceLocat
>> + String documentBase = message.substring("tag".length() + 1,
>> spaceLocati
>> String paramString = message.substring(spaceLocation + 1);
>>
>> PluginDebug.debug("Handle = ", handle, "\n",
>
>
> And we're 100% compatible with proprietary plugin, and aren't storing
> invalid URLs. The only remaining fix-up was ...
>
>> diff --git a/netx/net/sourceforge/jnlp/cache/ResourceTracker.java
>> b/netx/net/sourceforge/jnlp/cache/ResourceTracker.java
>> --- a/netx/net/sourceforge/jnlp/cache/ResourceTracker.java
>> +++ b/netx/net/sourceforge/jnlp/cache/ResourceTracker.java
>> @@ -390,7 +390,7 @@ public class ResourceTracker {
>> return resource.localFile;
>>
>> if (location.getProtocol().equalsIgnoreCase("file")) {
>> - File file = new File(location.getFile());
>> + File file = new File(location.toURI().getPath());
>> if (file.exists())
>> return file;
>> }
>> @@ -401,6 +401,9 @@ public class ResourceTracker {
>> ex.printStackTrace();
>>
>> return null; // need an error exception to throw
>> + } catch (URISyntaxException e) {
>> + e.printStackTrace();
>> + return null;
>> }
>> }
>
> Which works around a bad mis-design of URL#getFile() which does not
> decode the URL. This only applies to local files. URL#getFile() should
> be avoided, I think.
>
> Fix ChangeLog:
> 2013-XX-XX Adam Domurad <adomurad at redhat.com>
>
> Ensure document-base is properly encoded.
> * netx/net/sourceforge/jnlp/cache/ResourceTracker.java
> (getCacheFile): Use URL#toUri().getPath() instead of URL#getFile().
> * plugin/icedteanp/java/sun/applet/PluginAppletViewer.java
> (handleInitializationMessage): Don't decode document-base.
>
> Reproducer ChangeLog:
> 2013-XX-XX Adam Domurad <adomurad at redhat.com>
>
> Reproducer for URL parameters (eg ?a=b) in document-base.
> *
> tests/reproducers/simple/URLParametersInDocumentBase/resources/URLParametersInDocumentBase.html:
> Page that loads applet.
> *
> tests/reproducers/simple/URLParametersInDocumentBase/srcs/URLParametersInDocumentBase.java:
> Applet that prints code-base & document-base.
> *
> tests/reproducers/simple/URLParametersInDocumentBase/testcases/URLParametersInDocumentBaseTests.java:
> Test-driver.
>
> The UrlUtils patch is not strictly necessary any more, but I'd still
> like it in (it is unaffected by the changes). It can be just in HEAD
> though.
>
> Please note that I strongly want the fix in 1.3 since without it one
> cannot use Oracle LMS.
>
> Thanks,
> -Adam
More information about the distro-pkg-dev
mailing list