NanoHTTPD接收post数据

NanoHTTPD是一个可以把移动端当成一个轻量级服务器的框架

使用也比较简单,在github搜索NanoHTTPD,添加依赖jar包即可(这里用的是2.3.2版本的)

接收get方法传过来的数据比较简单,网上搜一下很多

这里要说的是怎么接收post传过来的json数据?网上搜了一下也有很多,但是有很多坑

我实现的接收方法:

if (method.equals(Method.POST)){
    Map<String, String> files = new HashMap<String, String>();
    /*获取header信息,NanoHttpheader不仅仅是HTTPheader,还包括其他信息。*/
    Map<String, String> header = session.getHeaders();

    try {
        session.parseBody(files);
       String param=files.get("postData");

        Log.d(TAG,"header : " + header);
        Log.d(TAG,"files : " + files);
        Log.d(TAG,"param : " + param);
    } catch (IOException e) {
        e.printStackTrace();
    } catch (ResponseException e) {
        e.printStackTrace();
    }

}

其中的param就是传过来的json数据,或者post过来的任意字符串

files.get(postData),中postData 是框架内部自己定义的key  打印的files就可以看见

对header感兴趣的可以打印出来看看

网上好多文章没说到postData这个key,导致不知道如何获取post数据







  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
NanoHTTPD是一个免费、轻量级的(只有一个Java文件) HTTP服务器,可以很好地嵌入到Java程序中。支持 GET, POST, PUT, HEAD 和 DELETE 请求,支持文件上传,占用内存很小。可轻松定制临时文件使用和线程模型。NanoHTTPD for JDK 1.1https://github.com/NanoHttpd/nanohttpd/tree/nanohttpd-for-java1.1示例代码:package fi.iki.elonen.debug;   import fi.iki.elonen.NanoHTTPD; import fi.iki.elonen.ServerRunner;   import java.util.HashMap; import java.util.List; import java.util.Map;   public class DebugServer extends NanoHTTPD {     public DebugServer() {         super(8080);     }       public static void main(String[] args) {         ServerRunner.run(DebugServer.class);     }       @Override public Response serve(IHTTPSession session) {         Map<String, List<String>> decodedQueryParameters =             decodeParameters(session.getQueryParameterString());           StringBuilder sb = new StringBuilder();         sb.append("<html>");         sb.append("<head><title>Debug Server</title></head>");         sb.append("<body>");         sb.append("<h1>Debug Server</h1>");           sb.append("<p><blockquote><b>URI</b> = ").append(             String.valueOf(session.getUri())).append("<br />");           sb.append("<b>Method</b> = ").append(             String.valueOf(session.getMethod())).append("</blockquote></p>");           sb.append("<h3>Headers</h3><p><blockquote>").             append(toString(session.getHeaders())).append("</blockquote></p>");           sb.append("<h3>Parms</h3><p><blockquote>").             append(toString(session.getParms())).append("</blockquote></p>");           sb.append("<h3>Parms (multi values?)</h3><p><blockquote>").             append(toString(decodedQueryParameters)).append("</blockquote></p>");           try {             Map<String, String> files = new HashMap<String, String>();             session.parseBody(files);             sb.append("<h3>Files</h3><p><blockquote>").                 append(toString(files)).append("</blockquote></p>");         } catch (Exception e) {             e.printStackTrace();         }           sb.append("</body>");         sb.append("</html>");         return new Response(sb.toString());     }       private String toString(Map<String, ? extends Object> map) {         if (map.size() == 0) {             return "";         }         return unsortedList(map);     }       private String unsortedList(Map<String, ? extends Object> map) {         StringBuilder sb = new StringBuilder();         sb.append("<ul>");         for (Map.Entry entry : map.entrySet()) {             listItem(sb, entry);         }         sb.append("</ul>");         return sb.toString();     }       private void listItem(StringBuilder sb, Map.Entry entry) {         sb.append("<li><code><b>").append(entry.getKey()).             append("</b> = ").append(entry.getValue()).append("</code></li>");     } } 标签:NanoHTTPD
前端 webhook 是一种用于接收外部系统发送的HTTP POST请求的技术。通过设置 webhook,前端应用可以接收到其他系统发送的POST数据并进行相应的处理。 为了实现前端 webhook 接收 POST 数据,我们可以按照以下步骤进行操作: 1. 首先,在前端应用中定义一个接收 POST 请求的接口。可以使用流行的前端框架(如React、Angular或Vue.js)来创建一个路由或者处理函数。 2. 在该接口中,设置接收 POST 请求的路由,并定义路由处理函数。 3. 在路由处理函数中,使用合适的方式解析和处理 POST 数据。可以使用现有的库,如`body-parser`来解析 POST 请求体中的数据。 4. 在处理函数中,根据需要对接收到的数据进行逻辑处理。例如,可以将数据存储到数据库中,或者通过其他方法进行进一步的处理和分析。 5. 最后,可以根据需要返回适当的响应给调用方。可以是一个简单的成功或失败的响应,也可以是处理后的数据。 需要注意的是,前端 webhook 依赖后端服务器来接收 POST 数据,并且需要保证服务器一直运行以接收数据。在生产环境中,通常将前端应用和服务器分开部署,前端应用作为静态资源通过CDN进行分发,而服务器用于接收POST数据和处理逻辑。 总之,前端 webhook 接收 POST 数据的过程涉及到前端应用设置接口、解析 POST 数据并进行处理,最后返回适当的响应给调用方。通过合适的技术和工具,我们可以轻松实现这一功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值