Spring Data MongoDB 去掉_class属性字段

oyhk 学习笔记

Spring Data MongoDB 去掉_class属性字段

 

相信大家使用java 操作mongodb ,很多人会选择了spring data mongodb ,我也是其中一个选择了spring data mongodb,我也相当喜欢spring的东西..哈

在开始的时候,我使用spring data mongodb ,当添加了一条数据的时候,我用MongoVUE查询了数据...如图

看到了_class属性了吗?

简单地说下这个字段,spring data mongodb 为什么要加上去,大概是为了查询数据的类型转换吧...具体大家再去查查了...

但是,你会发现,有这个字段跟没这个字段,在查询数据的时候,同样可以转换成对象....所以...还是不要吧,这样不但数据大了,虽然只是一点点..

但是看着有这个字段也非常不习惯...去掉吧...

下面两种去掉_class这个字段的属性......我个人就喜欢用xml配置方式了....

第一种是注释方式

@Configuration
public class SpringMongoConfig{
 
  public @Bean
  MongoDbFactory mongoDbFactory() throws Exception {
	return new SimpleMongoDbFactory(new Mongo(), "database");
  }
 
  public @Bean
  MongoTemplate mongoTemplate() throws Exception {
 
	//remove _class
	MappingMongoConverter converter = 
		new MappingMongoConverter(mongoDbFactory(), new MongoMappingContext());
	converter.setTypeMapper(new DefaultMongoTypeMapper(null));
 
	MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory(), converter);
 
	return mongoTemplate;
 
  }
 
}

 第二种:xml配置方式

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context" xmlns:mongo="http://www.springframework.org/schema/data/mongo"
	xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd 
	http://www.springframework.org/schema/data/mongo http://www.springframework.org/schema/data/mongo/spring-mongo-1.1.xsd 
	http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd">
	<!-- Default bean name is 'mongo' -->
	<mongo:mongo host="192.168.56.101" port="27018" />
	<mongo:db-factory dbname="mongoTest" mongo-ref="mongo" username="root" password="87980879nihao" />

	<!-- 自动扫描以下包的类 -->
	<mongo:mapping-converter base-package="com.mkfree.**.domain" />

	<bean id="mappingContext" class="org.springframework.data.mongodb.core.mapping.MongoMappingContext" />
	<!-- 配置mongodb映射类型 -->
	<bean id="mappingMongoConverter" class="org.springframework.data.mongodb.core.convert.MappingMongoConverter">
		<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
		<constructor-arg name="mappingContext" ref="mappingContext" />
		<property name="typeMapper" ref="defaultMongoTypeMapper" />
	</bean>

	<!-- 默认Mongodb类型映射 -->
	<bean id="defaultMongoTypeMapper" class="org.springframework.data.mongodb.core.convert.DefaultMongoTypeMapper">
		<constructor-arg name="typeKey">
			<null /><!-- 这里设置为空,可以把 spring data mongodb 多余保存的_class字段去掉 -->
		</constructor-arg>
	</bean>
	<!-- 操作mongodb -->
	<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
		<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
		<constructor-arg name="mongoConverter" ref="mappingMongoConverter" />
	</bean>

</beans>

 好了,现在就配置完成了,那么我再运行一次插入数据的代码,再看看情况,好下图

现在舒服了吧...._class的字段没了...OK,搞定了...

源代码下载:Mongodb.rar

本文章来自:http://blog.mkfree.com/posts/511396a3975a15ea1757d849

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Data MongoDB 中,可以通过自定义 Converter 或使用 Spring Security 的加解密功能实现自动化的加解密。下面分别介绍这两种方式: 1. 自定义 Converter: 通过自定义 Converter,可以在保存到 MongoDB 之前对数据进行加密,在读取数据时进行解密。你可以创建一个实现了 org.springframework.core.convert.converter.Converter 接口的加解密类,然后在 Spring 配置文件中注册该 Converter。 例如,你可以创建一个加解密类,如下所示: ```java public class EncryptionConverter implements Converter<String, String> { @Override public String convert(String source) { // 在这里进行加解密操作 // 返回加解密后的结果 } } ``` 然后,在 Spring 配置文件中注册 Converter: ```xml <bean id="encryptionConverter" class="com.example.EncryptionConverter" /> <bean class="org.springframework.data.mongodb.core.convert.CustomConversions"> <constructor-arg> <list> <ref bean="encryptionConverter" /> </list> </constructor-arg> </bean> ``` 2. 使用 Spring Security 的加解密功能: Spring Security 提供了一套强大的加解密功能,可以用于保护敏感数据。你可以使用 Spring Security 的加解密功能对存储在 MongoDB 中的数据进行自动化的加解密。 首先,需要配置 Spring Security 加解密的相关设置。可以参考 Spring Security 的文档来了解如何配置加解密算法、密钥管理等内容。 然后,在 Spring Data MongoDB 的配置文件中,将 Spring Security 的加解密功能集成到 MongoDB 的操作中。可以使用 Spring Security 的 CryptoModule 来对数据进行加解密。 例如,使用 CryptoModule 对字段进行加解密: ```java @Document(collection = "users") public class User { @Id private String id; @Field(targetType = FieldType.STRING) @Encrypt private String username; // 其他字段... // getter 和 setter 方法... } ``` 在上面的示例中,使用了 @Encrypt 注解来标记需要加密的字段。在读取和保存数据时,Spring Data MongoDB 将自动对该字段进行加解密操作。 需要注意的是,无论是使用自定义 Converter 还是使用 Spring Security 的加解密功能,都需要谨慎处理密钥的管理和保护。确保密钥的安全性非常重要,以免导致数据泄露或其他安全问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值