guice + mybatis+ resteasy

本文介绍如何在Web应用中配置Guice依赖注入框架与RESTEasy结合使用,包括设置上下文参数、监听器和Servlet配置,以及自定义模块实现与数据库交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

web.xml

<web-app>
	<display-name>Guice Hello</display-name>

	<context-param>
		<param-name>resteasy.guice.modules</param-name>
		<param-value>org.jboss.resteasy.examples.guice.hello.HelloModule,org.jboss.resteasy.examples.guice.hello.MybaitsModule</param-value>
	</context-param>
	
	
	<context-param>
		<param-name>resteasy.servlet.mapping.prefix</param-name>
		<param-value>/resteasy</param-value>
	</context-param>


	<listener>
		<listener-class>
			org.jboss.resteasy.plugins.guice.GuiceResteasyBootstrapServletContextListener
		</listener-class>
	</listener>

	<servlet>
		<servlet-name>Resteasy</servlet-name>
		<servlet-class>
			org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher
		</servlet-class>
	</servlet>

	<servlet-mapping>
		<servlet-name>Resteasy</servlet-name>
		<url-pattern>/resteasy/*</url-pattern>
	</servlet-mapping>

</web-app>

Module.java

import java.util.Properties;

import com.google.inject.Binder;
import com.google.inject.Module;
import com.google.inject.name.Names;

public class HelloModule implements Module {
	
	
	public void configure(final Binder binder) {
		
		Properties myBatisProperties = new Properties();
		myBatisProperties.setProperty("mybatis.environment.id", "test");
		myBatisProperties.setProperty("JDBC.schema", "test");
		myBatisProperties.setProperty("JDBC.driver", "com.mysql.jdbc.Driver");
		myBatisProperties.setProperty("JDBC.host", "127.0.0.1");
//		myBatisProperties.setProperty("derby.create", "true");
		myBatisProperties.setProperty("JDBC.username", "root");
		myBatisProperties.setProperty("JDBC.password", "1");
		myBatisProperties.setProperty("JDBC.autoCommit", "false");
		Names.bindProperties(binder, myBatisProperties);
		
		binder.bind(HelloResource.class);
		binder.bind(Greeter.class).to(DefaultGreeter.class);

	}

}

MybaitsModule.java

public class MybaitsModule extends MyBatisModule {

	@Override
	protected void initialize() {
		
		// mysql
		install(JdbcHelper.MySQL);
		
		// DataSource
        bindDataSourceProviderType(PooledDataSourceProvider.class);
        bindTransactionFactoryType(JdbcTransactionFactory.class);
        
        // 数据库操作
        addMapperClass(UserMapper.class);
        
        // 逻辑操作
        bind(FooService.class).to(FooServiceMapperImpl.class);

	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值