I have a Python script running Aspose.Words, when I call aspose.words.License.set_license I get the following error: No usable version of libssl was found
I use libssl in many of my other Python scripts and everything works fine, only the Aspose.Words module is having an issue.
I have the following versions of things installed:
openssl version = OpenSSL 3.0.13 30 Jan 2024 (Library: OpenSSL 3.0.13 30 Jan 2024)
import aspose.words as aw
aspose_license = aw.License()
def set_aspose_license():
try:
print("Setting Aspose License")
aspose_license.set_license("Aspose.Words.Product.Family.lic")
print("License set successfully.")
except RuntimeError as err:
print("\nThere was an error setting the license: {0}".format(err))
if __name__ == '__main__':
print("Starting Program")
set_aspose_license()
Print output:
Starting Program
Setting Aspose License
No usable version of libssl was found
The file “Aspose.Words.Product.Family.lic” exists in the same directory as main.py, if I change the file name to “Aspose.Words.Product.Family” I get the following error: There was an error setting the license: Proxy error(FileNotFoundException): Cannot find license ‘Aspose.Words.Product.Family’ which proves that the correctly named file is accessible.
One thing to note, when I change the name of the license file I don’t get a libssl error.
Two questions:
Why do I need libssl to set the Aspose license?
If libssl works for every other Python script I have (20+), what makes Aspose different?
We have opened the following new ticket(s) in our internal issue tracking system and will deliver their fixes according to the terms mentioned in Free Support Policies.
Issue ID(s): WORDSPYTHON-5
You can obtain Paid Support Services if you need support on a priority basis, along with the direct access to our Paid Support management team.
@alexey.noskov Thank you for your response. Unfortunately my company’s security policy is preventing me from installing libssl1.1.1.0g (it says it’s outdated and contains exploited vulnerabilities).
When will Aspose.Words for Python support a newer version of netcore that can use libssl3?
Or is there a workaround I can use to get Aspose.Words working?
@AlainGyger I am afraid there is no other workaround of this issue than the one suggested above.
There are no estimates regarding this issue yet. But we will keep you updated and let you know once it is resolved.
I paid $839.50 for a license for Aspose.Words that I’m unable to use because it depends on a library that the library’s author says should not be used (i.e. “All older versions (including 1.1.1, 1.1.0, 1.0.2, 1.0.0 and 0.9.8) are now out of support and should not be used.” - Downloads | Library).
I’ve done some searching on this forum and on StackExchange and see that many other people are having this same issue. They’re all being told to install a vulnerable version of libssl as the “solution”, which seems like a recipe for disaster.
Unfortunately Aspose.Words is the only software that I’ve been able to find that does what I need.
OpenSSL charges $25,000 annually to get security updates back ported into libssl1 … how much would it cost for Aspose to expedite this bug fix?
For other people who are getting this error, I have a temporary solution (until this issue is fixed) to run a Python script that uses Aspose and needs the outdated version of libssl … you can download the old openssl source code, compile it, and force your system to use that version each time you run your script.
BIG WARNING: This will cause Python to use an old, unsupported, and vulnerable version of libssl, so it’s not safe to use in production (IMHO), but it’s better than installing an old version of libssl system-wide.
The steps I took to make this work:
Make sure you have all the programs needed to get and compile software
sudo apt install build-essential wget
Make a directory called “oldlibssl” in your home folder
mkdir $HOME/oldlibssl
Move to that directory
cd $HOME/oldlibssl
Download the latest old version of libssl (as of October 2024)
Use LD_PRELOAD (From the man page - “A list of additional, user-specified, ELF shared objects to be loaded before all others. This feature can be used to selectively override functions in other shared objects.”) to force python to use the old version of libssl, both libssl and libcrypto must be specified.
This library interception only affects the command following it, it’s not permanent and must be specified each time this script is run.
As the issue been resolved? We can’t use libssl version 1.1 because we’re on a secured air-gapped network structure. Please fix this ASAP. What I found strange is that it worked earlier on a different machine and now it no longer works and both location has OpenSSL 3.0.2 installed.
It seems like the libraries for Python are less important, why? Even the documentation is poor and I had to resolve to C# documentation to get the correct information I needed. As, well, certain examples in the Python library documentation is not even in Python, but part are in C++, C# and even Javascript. Please put the same effor in your Python library as with your other supported languages.
This is not just complaining, but I hope that this is constructive cristism for your dev team.
@Nextria Unfortunately, the issue is not resolved yet. I will forward the information to our development team.
Regarding the documentation. our main product is .NET version of Aspose.Words. Then C# code is ported to Java and C++. Python version is build as a wrapper of .NET version of Aspose.Words. So all samples and documentation is first made for C# and then ported to other supported languages. If you have example where the documentation is not accurate or have incorrect code examples, please provide them here, we will fit the documentation.
Cookie Notice
To provide you with the best experience, we use cookies for personalization, analytics, and ads. By using our site, you agree to our cookie policy.
Enables storage, such as cookies, related to analytics.