AndServer

Android web server

License

License

GroupId

GroupId

com.yanzhenjie
ArtifactId

ArtifactId

andserver
Last Version

Last Version

1.1.4
Release Date

Release Date

Type

Type

aar
Description

Description

AndServer
Android web server
Project URL

Project URL

https://github.com/yanzhenjie/AndServer
Source Code Management

Source Code Management

https://github.com/yanzhenjie/AndServer

Download andserver

How to add to project

<!-- https://jarcasting.com/artifacts/com.yanzhenjie/andserver/ -->
<dependency>
    <groupId>com.yanzhenjie</groupId>
    <artifactId>andserver</artifactId>
    <version>1.1.4</version>
    <type>aar</type>
</dependency>
// https://jarcasting.com/artifacts/com.yanzhenjie/andserver/
implementation 'com.yanzhenjie:andserver:1.1.4'
// https://jarcasting.com/artifacts/com.yanzhenjie/andserver/
implementation ("com.yanzhenjie:andserver:1.1.4")
'com.yanzhenjie:andserver:aar:1.1.4'
<dependency org="com.yanzhenjie" name="andserver" rev="1.1.4">
  <artifact name="andserver" type="aar" />
</dependency>
@Grapes(
@Grab(group='com.yanzhenjie', module='andserver', version='1.1.4')
)
libraryDependencies += "com.yanzhenjie" % "andserver" % "1.1.4"
[com.yanzhenjie/andserver "1.1.4"]

Dependencies

runtime (2)

Group / Artifact Type Version
com.yanzhenjie.apache : httpcore jar 4.4.9
com.yanzhenjie.apache : fileupload jar 1.3.3

Project Modules

There are no modules declared in this project.

AndServer

Logo

AndServer is an HTTP and reverse proxy server.

Web server and Web framework of Android platform. It provides annotations like SpringMVC, and if you are familiar with SpringMVC, you can master it very quickly.

  • Static html website deployment.
  • Dynamic http api deployment.
  • Reverse proxy server.

Web Server

Deploy a web server:

Server server = AndServer.webServer(context)
    .port(8080)
    .timeout(10, TimeUnit.SECONDS)
    .build();

// startup the server.
server.startup();

...

// shutdown the server.
server.shutdown();

It also has some features, such as inetAddress(InetAddress), serverSocketFactory(ServerSocketFactory) and sslContext(SSLContext), depending on what you want to achieve.

@RestController
@RequestMapping(path = "/user")
public class UserController {

    @PostMapping("/login")
    public String login(@RequestParam("account") String account,
                        @RequestParam("password") String password) {

        ...
        return "Successful.";
    }

    @GetMapping(path = "/{userId}")
    public User info(@PathVariable("userId") String userId,
                     @QueryParam("fields") String fields) {

        User user = findUserById(userId, fields);
        ...

        return user;
    }

    @PutMapping(path = "/{userId}")
    public void modify(@PathVariable("userId") String userId
                       @RequestParam("age") int age) {
        ...
    }
}

The above code will generate the following two http apis:

POST http://.../user/login
GET http://.../user/uid_001?fields=id,name,age
PUT http://.../user/uid_001

For documentation and additional information see the website.

Reverse Proxy Server

Deploy a reverse proxy server:

Server server = AndServer.proxyServer()
    .addProxy("www.example1.com", "http://192.167.1.11:8080")
    .addProxy("example2.com", "https://192.167.1.12:9090")
    .addProxy("55.66.11.11", "http://www.google.com")
    .addProxy("192.168.1.11", "https://github.com:6666")
    .port(80)
    .timeout(10, TimeUnit.SECONDS)
    .build();

// startup the server.
server.startup();

...

// shutdown the server.
server.shutdown();

Note: It is just a reverse proxy and does not have the ability to take care of loading balance.

Download

Add the plugin to your project build script :

buildscript {
    repositories {
        jcenter()
        mavenCentral()
        google()
    }

    dependencies {
        classpath 'com.yanzhenjie.andserver:plugin:2.1.6'
        ...
    }
}
...

And then add AndServer dependency to your module:

apply plugin: 'com.yanzhenjie.andserver'

...

dependencies {
    implementation 'com.yanzhenjie.andserver:api:2.1.6'
    annotationProcessor 'com.yanzhenjie.andserver:processor:2.1.6'
    ...
}

If you are using Kotlin, replace annotationProcessor with kapt.

Contributing

Before submitting pull requests, contributors must abide by the agreement .

License

Copyright 2020 Zhenjie Yan

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Versions

Version
1.1.4
1.1.1
1.1.0
1.0.3
1.0.2
1.0.1