Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG] 3.116.1 throws TypeLoadException in Debian 10(buster) #3123

Open
1 task done
kobruleht opened this issue Dec 19, 2024 · 2 comments
Open
1 task done

[BUG] 3.116.1 throws TypeLoadException in Debian 10(buster) #3123

kobruleht opened this issue Dec 19, 2024 · 2 comments
Labels

Comments

@kobruleht
Copy link

kobruleht commented Dec 19, 2024

Description

ASP.NET 9 MVC application is running in Debian 10 (buster) server. It use captcha

https://github.com/VahidN/DNTCaptcha.Core

nuget package whose latest version requires Skiasharp 3.116.1

https://www.nuget.org/packages/SkiaSharp.NativeAssets.Linux.NoDependencies/3.116.1

After upgrading to SkiaSharp to latest version 3.116.1

in NuGet running application throws System.TypeInitializationException

Code

using SkiaSharp;

public static class Thumbnail
{
public static byte[] MakeMeAGoodThumbnail(byte[] source, int imageHeight, int imageWidth)
{
// https://stackoverflow.com/questions/73860277/what-is-the-decent-approach-to-resizing-images-in-asp-net-core
SKBitmap image = SKBitmap.Decode(source);
var ratioX = (double)imageWidth / image.Width;
var ratioY = (double)imageHeight / image.Height;
var ratio = Math.Min(ratioX, ratioY);
var newWidth = (int)(image.Width * ratio);
var newHeight = (int)(image.Height * ratio);
var info = new SKImageInfo(newWidth, newHeight);
image = image.Resize(info, SKFilterQuality.High);
using var ms = new MemoryStream();
image.Encode(ms, SKEncodedImageFormat.Png, 100);
return ms.ToArray();
}
}

Expected Behavior

It should work in Debian 10 like previous version https://www.nuget.org/packages/SkiaSharp.NativeAssets.Linux.NoDependencies/3.116.0

Actual Behavior

System.TypeInitializationException: The type initializer for 'SkiaSharp.SKData' threw an exception.
---> System.DllNotFoundException: Unable to load shared library 'libSkiaSharp' or one of its dependencies. In order to help diagnose loading problems, consider using a tool like strace. If you're using glibc, consider setting the LD_DEBUG environment variable:
/lib/x86_64-linux-gnu/libm.so.6: version `GLIBC_2.29' not found (required by /var/www/myapp/libSkiaSharp.so)
libSkiaSharp.so: cannot open shared object file: No such file or directory
/var/www/myapp/liblibSkiaSharp.so: cannot open shared object file: No such file or directory
/var/www/myapp/libSkiaSharp: cannot open shared object file: No such file or directory
/var/www/myapp/liblibSkiaSharp: cannot open shared object file: No such file or directory

  at SkiaSharp.SkiaApi.sk_data_new_empty()
  at SkiaSharp.SkiaApi.sk_data_new_empty()  at SkiaSharp.SKData..cctor()
  --- End of inner exception stack trace ---
  at SkiaSharp.SKData.Create(IntPtr address, Int32 length)
  at SkiaSharp.SKBitmap.Decode(ReadOnlySpan`1 buffer)
  at SkiaSharp.SKBitmap.Decode(Byte[] buffer)
....

Version of SkiaSharp

3.116.1 (Current)

Last Known Good Version of SkiaSharp

2.88.9 (Previous)

IDE / Editor

Visual Studio (Windows)

Platform / Operating System

Linux

Platform / Operating System Version

Debian GNU/Linux 10 (buster)

Devices

Debian VPS server

Relevant Screenshots

No response

Relevant Log Output

No response

Code of Conduct

  • I agree to follow this project's Code of Conduct
@dallonxu
Copy link

Expected Behavior
It should work in Debian 10 like previous version https://www.nuget.org/packages/SkiaSharp.NativeAssets.Linux.NoDependencies/3.116.0

It should be 2.88.9 instead of 3.116.0?

@kobruleht
Copy link
Author

No.

3.116.0 works in Debian 10
3.116.1 requires new GLIBC which is not available on Debian 10

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: New
Development

No branches or pull requests

2 participants