一、 这篇文章要解决什么问题,能学习到什么?
1 在登录过程中要获取验证码照片,利用http的get操作后,要穿参数过去服务器,就要用post。
2 上述的get和post操作用很多现在网络的框架都能实现,比如volley,但是在获取验证码照片后是要进行一个session的保持的,所以在查阅资料后利用okhttp框架来构建这个项目比较方便快捷。
二、问:什么是session和cookie?
简单来说,cookie就是客户端的会话id,而session就是服务器端的会话id,根据这个id号可以查询到你的会话内容。
(想要了解更多cookie和session的知识可以点击这里)
在本项目中用到的是验证码照片的获取,因为每次刷新验证码的url都会有不同的验证码照片出现,所以需要保存验证码的session,不然别人怎么知道你和哪个验证码进行了“会话”。先上照片:
图分为四个步骤,结合文字更容易理解:
1客户端发个请求验证码照片的请求,带回来了照片和一个jsessionid的字段存在用户的cookie中。
2我们从cookie头中取出这个session,然后打包参数发过去的时候顺便带上这个session,让服务器这个家伙知道是谁发的。
四个步骤两点总结,在加上代码就更好理解了。
三、分析部分重要代码 最后再贴上全部代码
看一下后台那边给我们的数据有什么,有url_randCodeImage用来发送get请求获取照片,还有url_login用来post数据过去,这些就是我们要打包发送过去的数据:
首先是我们的验证码照片的获取与异步加载图片
获取了照片和session之后,我们就打包发送数据过去:
最后来看看我们成功登录后log出来的信息
最后贴上我们的全部代码,希望对过程不太理解的小伙伴有所帮助:
领取专属 10元无门槛券
私享最新 技术干货