resteasy web Guice集成版本
xxxx:8080/resteasy/messageservice/aaaa
Hello : aaaa
web.xml <context-param> <param-name>resteasy.guice.modules</param-name> <param-value>com.zlg.resteasy.MyGuiceModule</param-value> </context-param> <listener> <listener-class>org.jboss.resteasy.plugins.guice.GuiceResteasyBootstrapServletContextListener</listener-class> </listener> <servlet> <servlet-name>resteasy-servlet</servlet-name> <servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class> </servlet> <servlet-mapping> <servlet-name>resteasy-servlet</servlet-name> <url-pattern>/*</url-pattern> </servlet-mapping> pom.xml <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.jboss.resteasy</groupId> <artifactId>resteasy-guice</artifactId> <version>3.0.16.Final</version> </dependency> </dependencies> <build> <finalName>resteasy</finalName> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <source>1.8</source> <target>1.8</target> <encoding>UTF-8</encoding> <showDeprecation>true</showDeprecation> <showWarnings>true</showWarnings> </configuration> </plugin> </plugins> </build> public class MyGuiceModule implements Module{ @Override public void configure(Binder binder) { // TODO Auto-generated method stub binder.bind(MessageService.class); } } @Path("/messageservice") public class MessageService { public MessageService(){} @GET @Path("/{param}") public Response printMessage(@PathParam("param") String msg) { String result = "Hello : " + msg; return Response.status(200).entity(result).build(); } }
RESTEasy:JAX-RS restful webservices 示例
纯web版本
pom添加依赖:
- <dependencies>
- <dependency>
- <groupId>org.jboss.resteasy</groupId>
- <artifactId>resteasy-jaxrs</artifactId>
- <version>3.0.11.Final</version>
- </dependency>
- </dependencies>
web.xml添加servlet定义
- <servlet>
- <servlet-name>resteasy-servlet</servlet-name>
- <servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class>
- <init-param>
- <param-name>javax.ws.rs.Application</param-name>
- <param-value>test.MyRESTEasyApplication</param-value>
- </init-param>
- </servlet>
- <servlet-mapping>
- <servlet-name>resteasy-servlet</servlet-name>
- <url-pattern>/*</url-pattern>
- </servlet-mapping>
JAX-RS定义
- package test;
- import javax.ws.rs.core.Application;
- import java.util.HashSet;
- import java.util.Set;
- public class MyRESTEasyApplication extends Application {
- private Set<Object> singletons = new HashSet<Object>();
- public MyRESTEasyApplication() { singletons.add(new HelloWorldRestService()); }
- @Override
- public Set<Object> getSingletons() { return singletons; }
- }
- package test;
- import javax.ws.rs.GET;
- import javax.ws.rs.Path;
- import javax.ws.rs.PathParam;
- import javax.ws.rs.core.Response;
- @Path("/hello")
- public class HelloWorldRestService {
- @GET
- public Response defaultResponse() {
- return Response.status(404).entity("404: Default Response ....").build();
- }
- @GET
- @Path("/{param}")
- public Response getName(@PathParam("param") String name) {
- String result = "RESTEasy Hello World : " + name;
- return Response.status(200).entity(result).build();
- }
- }
web Guice集成版本
- <dependencies>
- <dependency>
- <groupId>org.jboss.resteasy</groupId>
- <artifactId>resteasy-guice</artifactId>
- <version>3.0.16.Final</version>
- </dependency>
- </dependencies>
- <context-param>
- <param-name>resteasy.guice.modules</param-name>
- <param-value>guice.hello.MyGuiceModule</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>/*</url-pattern>
- </servlet-mapping>
java代码:
- package guice.hello;
- public interface Greeter {
- String greet(String name);
- }
- package guice.hello;
- import javax.inject.Singleton;
- @Singleton
- public class DefaultGreeter implements Greeter {
- public String greet(String name) {
- System.out.println(this);
- return "Hello " + name;
- }
- }
- package guice.hello;
- import com.google.inject.Binder;
- import com.google.inject.Module;
- // TODO: 可参考 core 模块中的例子:com.conquer.comutils.core.guice.MyGuiceModule
- public class MyGuiceModule implements Module {
- public void configure(final Binder binder) {
- binder.bind(MyResource.class);
- binder.bind(Greeter.class).to(DefaultGreeter.class)
- // 使用 javax.inject.Singleton() 标注 实现类 实现单例
- // .in(com.google.inject.Scopes.SINGLETON)// 这里设置单例,默认不是单例的而是每次创建
- ;
- }
- }
- package guice.hello;
- import javax.inject.Inject;
- import javax.ws.rs.GET;
- import javax.ws.rs.Path;
- import javax.ws.rs.PathParam;
- @Path("hello")
- public class MyResource {
- private final Greeter greeter;
- @Inject
- public MyResource(final Greeter greeter) {
- this.greeter = greeter;
- }
- @GET
- @Path("{name}")
- public String hello(@PathParam("name") final String name) {
- return greeter.greet(name);
- }
- }
@GET、@POST、@PUT、@DELETE 以及 @HEAD 均是 HTTP 请求方法指示符注释
https://www.ibm.com/developerworks/cn/web/wa-jaxrs/
@path: 顾名思义,就是请求的处理路径
Java 资源
JAX-RS 建立了一种特殊的语言来描述资源,正如由其编程模型所表示的。有五种主要条目:根资源、子资源、资源方法、子资源方法以及子资源定位器。
@Path 的使用
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
package com.ibm.jaxrs.sample.organization; import java.util.List; import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.PathParam; @Path(value="/contacts") public class ContactsResource { @GET @Path(value="/{emailAddress:.+@.+\\.[a-z]+}") public ContactInfo getByEmailAddress(@PathParam(value="emailAddress") String emailAddress) { ... } @GET @Path(value="/{lastName}") public ContactInfo getByLastName(@PathParam(value="lastName") String lastName) { ... } } |
ContactsResource
类上的注释表明对 /contacts
路径的所有请求都将由 ContactsResource
根资源处理。
getByEmailAddress
上的 @Path
注释则表明任何发送到 /contacts/{emailAddress}
的请求(其中 emailAddress
代表的是正则表达式 .+@.+\\.[a-z]+
)都将由 getByEmailAddress
处理。
getByLastName
方法上的 @Path
注释指定了发送到 /contacts/{lastName}
路径的所有请求(其中 lastName
代表的是一个与getByEmailAddress
内的正则表达式不匹配的有效的 URL 部分)都将由 getByLastName
方法处理。
https://www.cnblogs.com/jhcelue/p/7053959.html
http://docs.jboss.org/resteasy/docs/3.0.9.Final/userguide/html_single/index.html#d4e2122
RESTEasy has some simple integration with Guice 3.0.
RESTEasy will scan the binding types for a Guice Module for @Path and @Provider annotations. It will register these bindings with RESTEasy. The guice-hello project that comes in the RESTEasy examples/ directory gives a nice example of this.
@Path("hello") public class HelloResource { @GET @Path("{name}") public String hello(@PathParam("name") final String name) { return "Hello " + name; } }
First you start off by specifying a JAX-RS resource class. The HelloResource is just that. Next you create a Guice Module class that defines all your bindings:
import com.google.inject.Module; import com.google.inject.Binder; public class HelloModule implements Module { public void configure(final Binder binder) { binder.bind(HelloResource.class); } }
You put all these classes somewhere within your WAR WEB-INF/classes or in a JAR within WEB-INF/lib. Then you need to create your web.xml file. You need to use the GuiceResteasyBootstrapServletContextListener as follows
<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</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>/*</url-pattern> </servlet-mapping> </web-app>
GuiceResteasyBootstrapServletContextListener is a subclass of ResteasyBootstrap, so you can use any other RESTEasy configuration option within your web.xml file. Also notice that there is a resteasy.guice.modules context-param. This can take a comma delimited list of class names that are Guice Modules.
Add the RequestScopeModule to your modules to allow objects to be scoped to the HTTP request by adding the @RequestScoped annotation to your class. All the objects injectable via the @Context annotation are also injectable, except ServletConfig and ServletContext.
import javax.inject.Inject; import javax.servlet.http.HttpServletRequest; import javax.ws.rs.core.Context; import org.jboss.resteasy.plugins.guice.RequestScoped; @RequestScoped public class MyClass { @Inject @Context private HttpRequest request; }
Add the JaxrsModule to bind javax.ws.rs.ext.RuntimeDelegate, javax.ws.rs.core.Response.ResponseBuilder, javax.ws.rs.core.UriBuilder, javax.ws.rs.core.Variant.VariantListBuilder and org.jboss.resteasy.client.ClientExecutor.
You can configure the stage Guice uses to deploy your modules by specific a context param, resteasy.guice.stage. If this value is not specified, Resteasy uses whatever Guice's default is.
<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</param-value> </context-param> <context-param> <param-name>resteasy.guice.stage</param-name> <param-value>PRODUCTION</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>/*</url-pattern> </servlet-mapping> </web-app>
GuiceResteasyBootstrapServletContextListener can be extended to allow more flexibility in the way the Injector and Modules are created. Three methods can be overridden: getModules(), withInjector() and getStage(). Register your subclass as the listener in the web.xml.
Override getModules() when you need to pass arguments to your modules' constructor or perform more complex operations.
Override withInjector(Injector) when you need to interact with the Injector after it has been created.
Override getStage(ServletContext) to set the Stage yourself.
<web-app> <!-- other tags omitted --> <listener> <listener-class> org.jboss.resteasy.plugins.guice.GuiceResteasyBootstrapServletContextListener </listener-class> </listener> </web-app> public class MyServletContextListener extends GuiceResteasyBootstrapServletContextListener { @Override protected List<? extends Module> getModules(ServletContext context) { return Arrays.asList(new JpaPersistModule("consulting_hours"), new MyModule()); } @Override public void withInjector(Injector injector) { injector.getInstance(PersistService.class).start(); } }