Subsonic + Tomcat8 + Special Characters

Need help? Post your questions here.

Moderator: moderators

Subsonic + Tomcat8 + Special Characters

Postby SmplyUnprdctble » Thu Oct 19, 2017 4:40 am

The problem I'm having is if a song has a special character in the filename, Subsonic has issues recognizing it. If the filename has no special characters, Subsonic reads and displays it fine if the special character is in the ID3.

Example Filename:
03 - Tu Vacío.mp3
Has the ID3 tag of "Tu Vacío" as the title.

In Subsonic, it tries to think it's another folder and shows this weird character:
03 - Tu Vac��o.mp3

This happens with any extended character I come across. I hunted around for a while to finally determine it's the filename Subsonic does not like.


Little bit of history:
When I first came across Subsonic, I used the "Standalone Version" [.deb installation] for Ubuntu. I had a problem with special characters (probably doing something similar, I don't fully recall), and whatever research I did way back then told me to install Tomcat and use the WAR installation. It worked beautifully, I was happy, all was well. [I just looked at my old posts and it was at least a problem with ID3 tags back then, I don't know if I had special characters in filenames then]

Then, I don't know the exact spot where things fell apart. I've gone through a combination of "I'm not listening to this music" and swapping Linux installations and re-ripping my entire library after a hard drive crash, and the aforementioned problem now exists again, and seems a tad worse.

The answers I'm finding involve adding the LANG to the Subsonic startup file. This isn't quite the same method as a WAR installation, but I've gone through to verify Tomcat8 is running with UTF-8.

I thought it could have something to do with the SMB mountpoint my music is housed in, but Emby sees the music fine (Subsonic is SO much better for music... except on the Roku interface :D).

So, at this point, I'm at a loss for debugging.


Now, for the tldr basic information required:
Problem Description: Special Characters [e.g. accent characters] are showing as �� [one special character shows as two question-mark chars] and the file tries to express itself as a subfolder in Subsonic.
Troubleshooting Steps: Tried moving the files to local filesystem, no luck. Renaming without special character works, but is annoying with auto-rip / auto-tag having to be intervened with these random incidents.
Playback Application and Version: Standard Subsonic Web Interface
Subsonic Version: 6.1.1 (build 2a8e8d) – May 31, 2017
Server Version: Apache Tomcat/8.0.14 (Debian), java 1.7.0_151, HSQLDB, Linux (98.1 MB / 123.8 MB)
Hardware Platform: TurnKey GNU/Linux 14.1 / Debian 8.9 Jessie
Java Memory Limit: Looks like 128M? Default Tomcat8 installation preference.
Problem Filename: 03 - Tu Vacío.mp3

Code: Select all
subsonic/transcode# ./ffmpeg -i /mnt/Music/Enrique\ Iglesias/Bailamos\ -\ Greatest\ Hits/03\ -\ Tu\ Vacío.mp3
ffmpeg version 3.1.3-static http://johnvansickle.com/ffmpeg/  Copyright (c) 2000-2016 the FFmpeg developers
  built with gcc 5.4.1 (Debian 5.4.1-1) 20160803
  configuration: --enable-gpl --enable-version3 --enable-static --disable-debug --enable-libmp3lame --enable-libx264 --enable-libx265 --enable-libwebp --enable-libspeex --enable-libvorbis --enable-libvpx --enable-libfreetype --enable-fontconfig --enable-libxvid --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvo-amrwbenc --enable-gray --enable-libopenjpeg --enable-libopus --enable-libass --enable-gnutls --enable-libvidstab --enable-libsoxr --enable-frei0r --enable-libfribidi --disable-indev=sndio --disable-outdev=sndio --enable-librtmp --enable-libmfx --enable-libzimg --cc=gcc-5
  libavutil      55. 28.100 / 55. 28.100
  libavcodec     57. 48.101 / 57. 48.101
  libavformat    57. 41.100 / 57. 41.100
  libavdevice    57.  0.101 / 57.  0.101
  libavfilter     6. 47.100 /  6. 47.100
  libswscale      4.  1.100 /  4.  1.100
  libswresample   2.  1.100 /  2.  1.100
  libpostproc    54.  0.100 / 54.  0.100
Input #0, mp3, from '/mnt/Music/Enrique Iglesias/Bailamos - Greatest Hits/03 - Tu Vacío.mp3':
  Metadata:
    title           : Tu Vacío
    artist          : Enrique Iglesias
    album           : Bailamos - Greatest Hits
    genre           : Latin
    track           : 3
    encoder         : MediaMonkey 4.1.14
    album_artist    : Enrique Iglesias
    date            : 1999
  Duration: 00:03:57.04, start: 0.025056, bitrate: 321 kb/s
    Stream #0:0: Audio: mp3, 44100 Hz, stereo, s16p, 320 kb/s
    Metadata:
      encoder         : LAME3.99r
    Stream #0:1: Video: mjpeg, yuvj420p(pc, bt470bg/unknown/unknown), 500x500 [SAR 50:50 DAR 1:1], 90k tbr, 90k tbn, 90k tbc
    Metadata:
      comment         : Cover (front)
At least one output file must be specified


Code: Select all
[10/18/17 11:00:23 PM EDT]   WARN   JaudiotaggerParser   Failed to update tags for file Tu Vacio
[10/18/17 11:00:23 PM EDT]   WARN   TagService   Failed to update tags for 7003
[10/18/17 11:00:46 PM EDT]   WARN   JaudiotaggerParser   Failed to update tags for file Tu Vacio
[10/18/17 11:00:46 PM EDT]   WARN   TagService   Failed to update tags for 7003
[10/18/17 11:00:57 PM EDT]   WARN   JaudiotaggerParser   Failed to update tags for file Tu Vacio
[10/18/17 11:00:57 PM EDT]   WARN   TagService   Failed to update tags for 7003
[10/18/17 11:00:57 PM EDT]   WARN   JaudiotaggerParser   Failed to update tags for file El Muro
[10/18/17 11:00:57 PM EDT]   WARN   TagService   Failed to update tags for 5214
[10/18/17 11:13:46 PM EDT]   WARN   FileUtil   Failed to list children for /mnt/Music/Enrique Iglesias/Bailamos - Greatest Hits/03 - Tu Vac��o.mp3
[10/18/17 11:39:40 PM EDT]   WARN   FileUtil   Failed to list children for /mnt/Music/Enrique Iglesias/Bailamos - Greatest Hits/03 - Tu Vac��o.mp3
[10/18/17 11:50:04 PM EDT]   INFO   TranscodeInputStream   Starting transcoder: /var/subsonic/transcode/ffmpeg -i /mnt/Music/Enrique Iglesias/Escape/13 - Heroe.mp3 -map 0:0 -b:a 192k -v 0 -f mp3 -
[10/19/17 12:08:53 AM EDT]   WARN   FileUtil   Failed to list children for /mnt/Music/Enrique Iglesias/Bailamos - Greatest Hits/03 - Tu Vac��o.mp3


Code: Select all
/etc/fstab:
//<SMBServerAddress>/Music           /mnt/Music      cifs    iocharset=utf8,credentials=/etc/.smbcredentials,dir_mode=0775,uid=tomcat8,gid=tomcat8


SMBServer: Western Digital MyCloud PR4100 Firmware 2.30.165
(Don't think there's anything awry here since it has a problem on local FS, but including it for completeness)

Any suggestions would be appreciated.

Thanks!!
SmplyUnprdctble
 
Posts: 21
Joined: Thu Apr 22, 2010 3:33 pm

Re: Subsonic + Tomcat8 + Special Characters

Postby lonesomerider » Fri Oct 20, 2017 10:03 am

I see that your music is mounted. is it a CIFS mount? did you add iocharset=utf8 to the mount configuration?

Character set to use for converting 16 bit Unicode characters on CD to 8 bit characters. The default is iso8859-1


else check if the user for subsonic has the right locale:

Code: Select all
sudo -u subsonic locale


maybe your file has not a correct encoding (see links below)

interesting could be also
https://stackoverflow.com/questions/1545625/java-cant-open-a-file-with-surrogate-unicode-values-in-the-filename
and
https://stackoverflow.com/questions/64038/setting-java-locale-settings
/lonesomerider

Image
lonesomerider
 
Posts: 26
Joined: Fri Oct 20, 2017 9:09 am
Location: Switzerland

Re: Subsonic + Tomcat8 + Special Characters

Postby SmplyUnprdctble » Fri Oct 20, 2017 1:15 pm

CIFS was mounted with utf8 charset (it's in my post, but easily missed :D)

However, with your locale comment, you're a genius.

LANG & LANGUAGE are set to en.UTF-8, however, the rest were set to "C". I modified /etc/default/locale to change LC_CTYPE to C.UTF-8:

Code: Select all
[b]~# cat /etc/default/locale[/b]
#  File generated by update-locale
LANG=en_US.UTF-8
LANGUAGE=en_US.UTF-8
LC_ALL=C
LC_CTYPE=C.UTF-8


it works! Thank you muchly!
SmplyUnprdctble
 
Posts: 21
Joined: Thu Apr 22, 2010 3:33 pm


Return to Help

Who is online

Users browsing this forum: No registered users and 17 guests