No serializer的解决方法

No serializer found for class org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) )
这个错我们可以到网上搜索,SpringMVC与Jpa集成的时候(有懒加载)就会出现这个问题
(这是因为你需要序列化对象有一个属性是一类类型,而你使用了Hibernate的延迟加载所以这里是个Hibernate的代理对象。该代理对象有些属性不能被序列化所以会报错。)
在类上加属性:生成的时候把这个字段忽略了:
@JsonIgnoreProperties(value{“hibernateLazyInitializer”,“handler”,“fieldHandler”})
网上有很多相应的解决方案(这里我们不做缀述),我选择了一个比较暴力的。大家直接把下面的代码拷备过来使用即可:

第一步:创建一个新的类(重写com.fasterxml.jackson.databind.ObjectMapper)

package cn.itsource.pss.common;

import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;

public class CustomMapper extends ObjectMapper {
    public CustomMapper() {
        this.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        // 设置 SerializationFeature.FAIL_ON_EMPTY_BEANS 为 false
        this.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);
    }
}

第二步:在applicationContext-mvc.xml中配置一下即可

<!-- Spring MVC 配置 -->
<mvc:annotation-driven>
    <mvc:message-converters>
        <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
            <property name="supportedMediaTypes">
                <list>
                    <value>application/json; charset=UTF-8</value>
                    <value>application/x-www-form-urlencoded; charset=UTF-8</value>
                </list>
            </property>
            <!-- No serializer:配置 objectMapper 为我们自定义扩展后的 CustomMapper,解决了返回对象有关系对象的报错问题 -->
            <property name="objectMapper">
                <bean class="cn.itsource.pss.common.CustomMapper"></bean>
            </property>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当出现"AttributeError: module 'pyarrow' has no attribute 'serialize'"错误时,这通常意味着您正在尝试使用pyarrow模块的serialize属性,但该属性在该模块中不存在。这可能是由于您正在使用的pyarrow版本不兼容或未正确安装所致。 解决此问题的步骤如下: 1. 确保您已经正确安装了pyarrow模块,并且在使用前已经成功导入。您可以通过在Python控制台中输入以下命令来检查是否安装了pyarrow: ```python import pyarrow ``` 如果没有任何错误提示,则表示已成功导入该模块。 2. 检查您正在使用的pyarrow版本是否支持serialize属性。您可以通过在Python控制台中运行以下命令来检查pyarrow版本: ```python import pyarrow print(pyarrow.__version__) ``` 确保您使用的是最新版本或与您代码中的文档相匹配的版本。如果版本过低,可以尝试升级pyarrow模块: ```python pip install --upgrade pyarrow ``` 3. 如果您确定您的pyarrow版本正确且已经安装,并且仍然遇到此错误,请检查您的代码中是否存在语法错误或其他导入错误。确保您没有拼写错误,并且正确引用了pyarrow模块。 4. 如果上述方法都无法解决问题,可能是由于其他依赖项与pyarrow发生冲突。您可以尝试卸载并重新安装pyarrow,或者与其他依赖项一起进行版本管理,以确保它们的兼容性。 综上所述,解决"AttributeError: module 'pyarrow' has no attribute 'serialize'"错误的步骤包括确保正确安装了pyarrow模块,检查您的pyarrow版本是否支持serialize属性,检查代码中是否存在其他语法错误或导入错误,并进行必要的升级或版本管理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [AttributeError: module 'tensorflow.compat.v1' has no attribute '](https://download.csdn.net/download/qq_38766019/86272235)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【Python 脚本报错】AttributeError:‘module‘ has no attribute ‘xxx‘的解决方法](https://blog.csdn.net/qq_35091353/article/details/115609471)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值