You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@struts.apache.org by "ASF GitHub Bot (JIRA)" <ji...@apache.org> on 2017/08/23 20:09:00 UTC

[jira] [Commented] (WW-4843) DefaultUrlHelper().buildUrl() not outputting port when used as parameter

    [ https://issues.apache.org/jira/browse/WW-4843?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16138992#comment-16138992 ] 

ASF GitHub Bot commented on WW-4843:
------------------------------------

GitHub user aleksandr-m opened a pull request:

    https://github.com/apache/struts/pull/163

    WW-4843 DefaultUrlHelper().buildUrl() not outputting port when used as parameter

    

You can merge this pull request into a Git repository by running:

    $ git pull https://github.com/aleksandr-m/struts feature/WW-4843

Alternatively you can review and apply these changes as the patch at:

    https://github.com/apache/struts/pull/163.patch

To close this pull request, make a commit to your master/trunk branch
with (at least) the following in the commit message:

    This closes #163
    
----
commit 0b9e68ed16341c585d48d301ceacfb9e74438552
Author: Aleksandr Mashchenko <am...@apache.org>
Date:   2017-08-23T20:05:29Z

    WW-4843 DefaultUrlHelper().buildUrl() not outputting port when used as parameter

----


> DefaultUrlHelper().buildUrl() not outputting port when used as parameter
> ------------------------------------------------------------------------
>
>                 Key: WW-4843
>                 URL: https://issues.apache.org/jira/browse/WW-4843
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core
>    Affects Versions: 2.3.33
>            Reporter: k918912
>             Fix For: 2.3.x, 2.5.x
>
>
> This is related to WW-1950.
> If you use the method DefaultUrlHelper().buildUrl() and set forceAddSchemeHostAndPort to true Struts2 does not always add the port. This is a problem if you intend to use the output as a parameter.
> Example code:
> {code:java}
> Map<String, Object> parameters = new HashMap<String, Object>();
> String backUrlParameters = new DefaultUrlHelper().buildUrl("someurl.html", getServletRequest(), getServletResponse(), null, null, true, false, true, true);
> parameters.put("backUrl", backUrlParameters);
> String backUrl = new DefaultUrlHelper().buildUrl("someurl2.html", getServletRequest(), getServletResponse(), parameters, null, false, false, false, false);
> {code}
> The resulting parameter appended to backUrl does not have the port, even with setting forceAddSchemeHostAndPort to true.
> Resulting URL:
> http://localhost:8080/someurl2.html?backUrl=http%3A%2F%2Flocalhost%2Fsomeurl.html
> My current workaround is to use:
> {code:java}
> String backUrlParameters = new DefaultUrlHelper().buildUrl("someurl.html", getServletRequest(), getServletResponse(), null, getServletRequest().getScheme(), true, false, true, true);
> {code}
> This gives Struts2 the same scheme that is currently used but makes it think that there could be a change. Result is that the port in the parameter URL is appended.
> My environment is Struts2 2.3.33 but I didn't see a code change in that area between 2.3 and 2.5, nonetheless I only selected the version I actually tested this on.



--
This message was sent by Atlassian JIRA
(v6.4.14#64029)