Mars-Java 一个不再需要容器的JavaWeb开发框架

基本概念

Mars-Java是一个不需要容器的Java开发框架,不需要Tomcat,不需要JBoss,不需要Netty,甚至连Servlet都不需要。

一个纯基于JRE类库开发的Http服务,一个不需要容器的Java开发框架。

他可以快速的开发出一个后端Http服务,支持MVC,IOC,AOP,数据库操作,声明式事务等常用的特性,并且他更小,更快,更简单。

为什么要用Mars-Java

当我们需要开发一些中小型网站的时候,如果使用Java,那么往往会走向两个极端,要么使用非常简单的JDBC+Servlet,要么使用非常巨大化的Springboot+Mybatis,那么有没有一个折中的方案呢?当用户量可以预见的不会太多(多见于B端应用),又或者仅仅是一个逻辑不复杂的展示型网站,这个时候我们怎么办? 这个时候就可以使用Mars-Java了。

它非常的小,不到Springboot+Mybatis的一半,它功能齐全,包含了Springboot常用的几大功能,并且有自己的持久层封装。同时它也有自己的生态,目前有一个小型的分布式组件Mars-Cloud。

几乎可以解决你日常中的所有需求。

Mars-Java的工作原理

一、启动流程

Mars-Java 一个不再需要容器的JavaWeb开发框架_第1张图片

二、MVC工作流程

Mars-Java 一个不再需要容器的JavaWeb开发框架_第2张图片

MVC支持的请求方式

目前为止MVC支持GET,POST两种请求方式,这也是用的最多的两种方式,其他的暂时不支持。

传参方式支持以下三种:

  • application/x-www-form-urlencoded
  • multipart/form-data
  • application/json

数据库操作

一、简单的单表操作

// 根据主键查询一条数据
@MarsGet(tableName = "userinfo",primaryKey = "id")
public abstract `Return type` selectById(int id);

// 插入一条数据
@MarsUpdate(tableName = "userinfo",operType = OperType.INSERT)
public abstract int insert(`Entity object parameter`);

// 根据主键删除一条数
@MarsUpdate(tableName = "userinfo",operType = OperType.DELETE,primaryKey = "id")
public abstract int delete(int id);

// 根据主键修改一条数据
@MarsUpdate(tableName = "userinfo",operType = OperType.UPDATE,primaryKey = "id")
public abstract int update(`Entity object parameter`);

二、简单的分页操作

// 如果你的sql语句是固定的,那么只需要这样就可以分页了
@MarsSelect(sql = "select * from userinfo where name = #{name} and age = ${age}", resultType = 要返回的实体类.clss,page = true)
public abstract PageModel<要返回的实体类> selectList(PageParamModel pageParamModel);

// 如果你的sql语句不固定,那么就这样
public PageModel<要返回的实体类> findPage(PageParamModel pageParamModel) throws Exception {
    String sql = "select * from userinfo where name like #{name}";
    return JdbcTemplate.get().selectPageList(sql,pageParamModel,DemoEntity.class);
}

声明式API

一、 先声明一下

@MarsApi(refBean = "expApiService")
public interface ExpApi {

    /**
     * get请求示例
     * http://127.0.0.1:8080/expGetRequest?name=张三&names=王五&names=赵六
     * @param expVO
     * @return
     */
    List expGetRequest(ExpVO expVO);
}

二、实现这个接口就好

@MarsBean("expApiService")
public class ExpApiService implements ExpApi {


    /**
     * 这个方法上加了aop监听
     * @param expVO
     * @return
     */
    @Override
    @MarsAop(className = ExpAop.class)
    public List expGetRequest(ExpVO expVO) {

        // 打印接收到的参数,看是否接收成功
        System.out.println(expVO.getName());
        System.out.println(JSON.toJSONString(expVO.getNames()));

        // 返回数据
        return getExpResultData();
    }
}

对,你们没看错,Controller层没了,为什么会这样呢?这得从Controller的作用说起,在实际开发中,Controller基本上起到两个作用,一个是参数校验,一个是响应数据。

在Mars-Java中,参数校验被封装掉了,直接用注解即可,响应数据,这个本来就没什么,直接返回就好,不需要去Controller里再返回一次了。

所以,干脆去掉了,让使用者专注在业务逻辑上。

坚守的基本理念

Mars-Java 从出身的那天起,就是基于一个理念的:它要小,越小越好,他要简单,越容易用越好。

为了达到这个理念,我们一直在坚持几件事:

  1. 绝不玩花哨的东西,大家会什么,我们就做什么,而不是制定新规则给大家用。
  2. 尽可能的去提取市面上的精华,去掉不要的东西。

第一点很好理解,也是没少被吐槽的地方,那就是第一眼看上去没什么新意,这其实很好解释:

因为无论怎么变,都是用Java写的嘛,本质上一点区别都没。那既然大家已经习惯了用筷子吃饭,我为什么要去推刀叉给大家呢?大家的最终目的无非就是用工具做出一个符合需求的项目嘛,没必要给使用者添加学习成本。

与其把重点放在发明刀叉上,不如把筷子的质量提高一些,让使用者能够更好地用餐。所以,我们坚持 尽量不玩花哨的东西,不制造新玩法。如果有人感兴趣,拿起来就可以直接用,完全不需要花大量时间学习。

----------------------------------------------------------------------------------

第二点也很好理解,这个项目做到现在为止已经有一年多了,我们提取了最常用的IOC,AOP,MVC,数据库操作,并自己做了实现。同时只保留了Bean的单例,去掉了不常用Scope。

现在,又去掉了第三方容器,完全基于JRE类库开发了一个Http服务,这个服务只保留了最常用的几个地方:

  • 传参:支持raw,formdata,表单提交
  • 图片上传:支持一次性传多个
  • 图片下载
  • Json响应:后端给前端返回Json数据

接下来的发展方向是一步步的 去掉第三方依赖,并挑选这些依赖中最常用的特性,自己实现。

----------------------------------------------------------------------------------

官网地址:http://www.mars-framework.com/

你可能感兴趣的:(开源,java,框架)