开发过程当中快速抓包并解析

这几天小编在工做中遇到了一个灵异事件,客户端使用的是安卓原生系统,服务端使用的是java。需求就是客户端在照相的时候能够实时上传照片。后台接收并保存,而且能够在平台上显示。看似简单的功能,确有个很大的坑。有2个平台,192.168.31.87平台是测试环境,192.168.31.239是演示环境,测试环境,演示环境,还有安卓客户端代码都是同样的,连mq,redis,nginx,数据库都是同样的。可是安卓端上传测试环境一直报java.net.SocketException,在演示环境上是正常的。检查服务端代码。我首先用了postman进行测试.php

 

image.png
image.png

 

因为已经上传过一张同样的照片,因此这里返回failed,可是请求是200.说明是调用正常。而后我在微服务上写了个测试类,用httpclient调用结果也是正常。html

 

image.png
image.png


在安卓客户端上传的时候,正常和不正常的log分别是前端

正常:
response-->Response{protocol=http/1.1, code=200, message=OK, url=http://192.168.31.239:8081/api/collDataUpload?para={%22fileName%22:%2220180822_185110_523.jpg%22,%22pno%22:%2220180821%22,%22dkey%22:%2215948c07-c718-4f32-a0af-4b7841fa95a0%22,%22stime%22:%221534935070523%22,%22etime%22:%221534935071000%22}} 不正常: response-->Response{protocol=http/1.1, code=400, message=, url=http://192.168.31.87:8081/api/collDataUpload?para={%22fileName%22:%2220180822_184559_902.jpg%22,%22pno%22:%228230%22,%22dkey%22:%22d351aa68-bace-438f-8d08-89ff598d4e04%22,%22stime%22:%221534934759902%22,%22etime%22:%221534934760000%22}} 

安卓客户端部分代码java

/** * 同步基于post的图片上传 * * @param url * @param file * @return */ public Response uploadPic(String url, File file, String fileName) throws IOException { MultipartBody.Builder builder = new MultipartBody.Builder(); builder.setType(MultipartBody.FORM); Log.i("huang", "files[0].getName()==" + files[0].getName()); //第一个参数要与Servlet中的一致 builder.addFormDataPart("file", fileName, RequestBody.create(MediaType.parse(guessMimeType(fileName)), file)); MultipartBody multipartBody = builder.build(); Request request = new Request.Builder().url(url).post(new ProgressRequestBody(multipartBody, listener)).build(); okHttpClient.newCall(request).enqueue(callback); } 

服务端linux

 

image.png
image.png

而后客户端调用服务端连这个接口都没进来,首先我判断配置文件是否有对文件大小进行过滤,而后看了filter也没什么。百思不得奇解。因而作了不少操做。虽然最后问题仍是没=解决,可是到get到了不少新技能。
很是重要的一个技能:抓包。
···
大体步骤为:
1.首先在linux服务器上执行指令
2.调用接口,而后执行指令把linux文件下载到本地
3.使用Wireshark查看日志
须要使用的linux命令
netstat -tupln | grep 5088
tcpdump -i any -p -s 0 -w /tmp/cap.pcap
sz /tmp/cap.pcap
···nginx

 

image.png
image.png
image.png
image.png
image.png
image.png

而后到开始菜单换中打开redis

 

image.png
image.png

Wireshark这软件,小伙伴百度下载便可
地址栏中能够输入过滤条件:
ip.addr == 192.168.31.182 and http数据库

 

image.png
image.png

 

选中其中你想看的包,右键追溯流--->TCP流或者http流api

image.png
image.png

这里大体解释一下:
Content-Type:是上传文件格式multipart/form-data是指图片。
boundary=XXXX,这是前端传的时候使用的一种形式addBoundary
Content-Length是内容大小
Host:是服务器主机地址
Connection是连接状态
Accept-Encoding是接收的编码格式
User-Agent:是用户上传的形式,这里安卓使用的是okhttp/3.6.0
content-Desposition是上下文的描述
content-Type:内容类型
很开心,又get到了一个新技能,可是个人问题仍是没有解决。目前的解决办法就是本身在写个安卓端,单独用作个按钮,而后用okhttp上传文件到平台。
另外在操做安卓的时候遇到了adb.exe已中止工做,而后开启不了虚拟机的问题。服务器

image.png
image.png

出错画面:

image.png
image.png

通常出现这个错误的缘由都是因为adb的默认端都5037,被其余程序占用了。撸主我就碰到过被酷我音乐,鲁大师和被360mobile的exe程式占用了,后来这些程式所有被我删了!
  首先咱们应该在电脑中查看5037的端口状况,输入 netstat -aon|findstr "5037":
  

 

image.png
image.png

咱们能够看到PID为4476的程式使用了关端口,然我咱们打开任务管理器。

image.png
image.png

咱们能够看到进程为“360MobileLoader.exe *32”的进程占用了5037端口。理论上来讲咱们结束这个进程应该就好了。可是问题来了!

image.png
image.png
image.png
image.png

竟然不让我删除!!!!!!!!PS:我本身的电脑,删不删除还须要你的赞成?

image.png
image.png

选择打“”开文件位置“”,找到对应的exe程式,我这儿使用的是360强制删除,PS:普通删除的方一样不容许我删除。
  我删除了以后,电脑从新注销了一下,adb.exe正常启动起来了。

Genymotion又开启了。小姐姐又回来了哈哈。

 

image.png
image.png

在附送一个知识:无界鼠标.就是一个鼠标键盘控制N台电脑(能够是不一样操做系统)
附上连接

image.png
image.png
相关文章
相关标签/搜索