At the time the sshd process on the remote computer forks to run /usr/bin/xterm there are very few environment variable set. In fact the LANG variable is not set. Hence the xterm process does not know that it should display characters in UTF-8. It falls back to xterms defaults. Whatever that might be.
However, the subshell running inside the xterm runs all setup scripts and alike.
Including setting the LANG environment variable.
One needs to understand the difference between the remote xterm process and the shell process running inside of xterm.
The solution is to run the remote xterm process like this:
/usr/bin/env LANG=en_US.UTF-8 /usr/bin/xterm
env(1) is a utility to run a program in a modified environment.
Setting LANG will make the remote xterm display UTF-8 characters properly.
Eskil...
:-)
P.s: Reading the xterm manual page I also found an easier way to achieve this:
xterm -en en_US.UTF-8
P.P.s: I do not think setting resources in ~/.Xresources will take effect unless you merge them in with xrdb. The xterm process on the Linux computer will query the X server running on your windows computer. At the time where xterm starts it is very unlikely that your X-Win32 server has the xterm* resources set. But you might be able to set resources in X-Win32 if it supports that.
The Liberation font doesn't seem to have this symbol. But using XTerm*faceName: DejaVu Sans Mono
(which is also a truetype font) allows ☠ to be displayed.
EDIT: Do not use LibreOffice or OpenOffice to determine whether a glyph is supported in a font, as it silently falls back to another font: OpenOffice bug 45128.
Best Answer
I struggled with this also for a while. What help with me was installing this:
https://github.com/powerline/fonts
And adding the line
into ~/.Xresources.
After that:
And then reopening xterm.