diff --git a/io_scene_gltf2/__init__.py b/io_scene_gltf2/__init__.py
index 41f09df9d56ccb8477397a3d3fed49bbdca8a46c..3a279780d2408c307fc6d478158453a33dd3c493 100755
--- a/io_scene_gltf2/__init__.py
+++ b/io_scene_gltf2/__init__.py
@@ -15,7 +15,7 @@
 bl_info = {
     'name': 'glTF 2.0 format',
     'author': 'Julien Duroure, Scurest, Norbert Nopper, Urs Hanselmann, Moritz Becher, Benjamin SchmithĂĽsen, Jim Eckerlein, and many external contributors',
-    "version": (1, 7, 30),
+    "version": (1, 7, 31),
     'blender': (2, 91, 0),
     'location': 'File > Import-Export',
     'description': 'Import-Export as glTF 2.0',
diff --git a/io_scene_gltf2/blender/exp/gltf2_blender_gather_drivers.py b/io_scene_gltf2/blender/exp/gltf2_blender_gather_drivers.py
index 561f246c1f2fcaabbe5e75621f029d34b7de0639..ede6bab2b03f9871c6a3ac33e6621bb525a0ae5e 100644
--- a/io_scene_gltf2/blender/exp/gltf2_blender_gather_drivers.py
+++ b/io_scene_gltf2/blender/exp/gltf2_blender_gather_drivers.py
@@ -53,6 +53,11 @@ def get_sk_drivers(blender_armature):
         for sk_c in child.data.shape_keys.animation_data.drivers:
             # Check if driver is valid. If not, ignore this driver channel
             try:
+                # Check if driver is valid.
+                # Try/Except is no more a suffisant check, starting with version Blender 3.0,
+                # Blender crashs when trying to resolve path on invalid driver
+                if not sk_c.is_valid:
+                    continue
                 sk_name = child.data.shape_keys.path_resolve(get_target_object_path(sk_c.data_path)).name
             except:
                 continue