Java極簡 restful 框架,Resty 1.1.0-SNAPSHOT 版,快速接入 Spring

jopen 9年前發布 | 17K 次閱讀 Resty

Resty從最初開發到現在已經經歷了近10個月時間,在github的star數即將進入400,在沒有任何推廣的情況,目前的情況還是比較可觀的,主要感謝關注restful發展的人們。

對于不理解restful的人其實就是一個url地址的規范,但我從來不這么認為,我一直覺得rest是一種理念,就行java教你面向對象一樣,rest教你面向資源,不再以功能來實現接口,以對資源的操作方式來實現接口,目前就我自己使用的情況來說,大多是比較好的反響:

1.接口真的是簡單到了極致(而且非常),比如:
登錄:

curl -X POST http://users.api.demo.com/sessions \
    -H "Content-Type: application/json" \
    -d '{"username": "admin","password":"111111","rememberMe":"false"}'


退出登錄:

curl -X DELETE http://users.api.demo.com/sessions

獲取當前登錄用戶:


curl -X GET http://users.api.demo.com/sessions

等等,接口使用者覺得非常簡潔優雅,利于管理


2.當你開源預測接口的行為時,你可以做更多的全局性處理,比如在實際情況中:針對某種資源做權限,根據GET,POST,DELETE,PUT等操作做ETag和緩存處理,GET使用緩存,POST,DELETE,PUT更新緩存,及時接口分布在不同的項目緩存也具有即時性,等等

3.直面http,不需要你做額外的設計,http已經為你準備好了,快來進入restful的世界吧

扯淡完了,說說Resty Maven的快照版1.1.0-SNAPSHOT的更新內容:

1.快速接入Spring

導入spring的包:


<dependency>
   <groupId>org.springframework</groupId>
   <artifactId>spring-context</artifactId>
   <version>${spring-context.version}</version>
</dependency>

編寫Spring的啟動配置(默認使用注解的方式,使用xml的同學請查閱@ImportResource注解),配置Spring掃描路徑,支持多個



@Configuration
@ComponentScan(basePackages = {"cn.dreampie.service"})
public class HelloApp {

}

在Resty的AppConfig中配置SpringPlugin



public void configPlugin(PluginLoader pluginLoader) {
  pluginLoader.add(new SpringPlugin(HelloApp.class));
}

然后編寫你的Spring class吧



//接口
public interface HelloService {
  public String hello();
}


@Component
public class HelloServiceImpl implements HelloService {
  public String hello() {
    return "hello";
  }
}

在Resource中使用,和原本Spring的方式無區別,你會以為這是一個純Spring應用,但是route部分確比Spring mvc更簡潔



  @Autowired
  private HelloService helloService;


  @GET
  public String get() {
    return helloService.hello();
  }

Spring集成就是這么簡單,這么完美(什么Dubbo+zookeeper早已不在話下)。


2.resty-cache緩存添加過期時間,orm部分使用@Table(expired=10000)

3.resty-security的加密功能提供密鑰

public class Encryptioner {

  public static String md5(String srcStr) {
    return encrypt("MD5", srcStr, null);
  }

  public static String md5(String srcStr, String salt) {
    return encrypt("MD5", srcStr, salt);
  }

  public static String sha1(String srcStr) {
    return encrypt("SHA-1", srcStr, null);
  }

  public static String sha1(String srcStr, String salt) {
    return encrypt("SHA-1", srcStr, salt);
  }

  public static String sha256(String srcStr) {
    return encrypt("SHA-256", srcStr, null);
  }

  public static String sha256(String srcStr, String salt) {
    return encrypt("SHA-256", srcStr, salt);
  }

  public static String sha384(String srcStr) {
    return encrypt("SHA-384", srcStr, null);
  }

  public static String sha384(String srcStr, String salt) {
    return encrypt("SHA-384", srcStr, salt);
  }

  public static String sha512(String srcStr) {
    return encrypt("SHA-512", srcStr, null);
  }

  public static String sha512(String srcStr, String salt) {
    return encrypt("SHA-512", srcStr, salt);
  }
}

4.添加Headers參數獲取所有的header


  @GET("/headers")
  public Headers headers(Headers headers) {
    return headers;
  }

5.添加XForwardedSupports,add config in application.properties  

app.xForwardedSupports=* 或者確定的ip地址 app.xForwardedSupports=127.0.0.1,127.0.0.2

6.修復其他一般性bug和部分代碼重構優化


來自:https://github.com/Dreampie/resty

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!